diff --git a/tests/assets/components/create/custom-constellation/.eslintrc.json b/tests/assets/components/create/custom-constellation/.eslintrc.json
deleted file mode 100644
index ddf04a80..00000000
--- a/tests/assets/components/create/custom-constellation/.eslintrc.json
+++ /dev/null
@@ -1,177 +0,0 @@
-{
- "root": true,
- "extends": ["@pega"],
- "parserOptions": {
- "project": "tsconfig.json",
- "ecmaVersion": 13,
- "warnOnUnsupportedTypeScriptVersion": false
- },
- "settings": {
- "import/resolver": {
- "typescript": {},
- "node": {
- "extensions": [".js", ".jsx"]
- }
- }
- },
- "ignorePatterns": [
- "node_modules", "packages/*/lib", "!.storybook", ".storybook/public"
- ],
- "rules": {
-
- // Prettier recommends running separately from a linter.
- // https://prettier.io/docs/en/integrating-with-linters.html#notes
- "prettier/prettier": "off",
-
- // Disable rules from shared configs we're not ready for yet.
- "sonarjs/cognitive-complexity": "off",
- "sonarjs/no-identical-functions": "off",
- "sonarjs/no-duplicate-string": "off",
- "sonarjs/no-nested-template-literals": "off",
-
- //
- // JA - Override some default lint handling here
- "@typescript-eslint/array-type": ["error", { "default": "generic" }],
- // "import/extensions": ["warn", "never"], // Turning off for now (see below)
-
- //
- // Initial release: turning these off; phase in to "warn" or "error" over time
- // For "quotes" and "@typescript-eslint/quotes", see override below for .ts/.tsx files
- "import/extensions": ["off", "never"],
- "import/named": "off",
- "import/no-cycle": "off",
- "import/no-duplicates": "off",
- "import/no-extraneous-dependencies": "off",
- "import/no-named-as-default": "off",
- "import/no-named-as-default-member": "off",
- "import/no-self-import": "off",
- "import/no-unresolved": "off",
- "import/no-useless-path-segments": "off",
- "import/order": "off",
- "import/prefer-default-export": "off",
- "import/no-relative-packages": "off",
-
- "no-else-return": "off",
- "no-restricted-syntax": "off",
- "no-underscore-dangle": "off",
-
- "jsx-a11y/alt-text": "off",
- "jsx-a11y/anchor-is-valid": "off",
- "jsx-a11y/click-events-have-key-events": "off",
- "jsx-a11y/label-has-associated-control": "off",
- "jsx-a11y/no-static-element-interactions": "off",
-
-
- "sonarjs/prefer-immediate-return": "off",
- "sonarjs/no-redundant-boolean": "off",
-
- "@typescript-eslint/dot-notation": "off", // prefer warn but needs different parserOptions
- "@typescript-eslint/naming-convention": "off", // prefer warn but needs different parserOptions
- "@typescript-eslint/ban-types": "off", // also, see override below
-
- //
- // Initial release: set to error
- "@typescript-eslint/no-inferrable-types": "off",
- "eqeqeq": "off",
- "no-alert": "off",
- "no-console": "off",
- "no-fallthrough": "error",
- "no-undef": "off",
- "no-unused-vars": "off",
- "no-var": "off",
- "prefer-const": "off",
- "yoda": "error",
- "no-irregular-whitespace": "off",
- "no-empty": "off",
- "no-new-object": "off",
-
- "import/no-mutable-exports": "error",
- "sonarjs/max-switch-cases": "error",
- "sonarjs/no-collapsible-if": "off",
- "sonarjs/no-all-duplicated-branches": "off",
- "sonarjs/no-duplicated-branches": "off",
- "sonarjs/no-gratuitous-expressions": "off",
- "sonarjs/no-ignored-return": "off",
- "sonarjs/no-small-switch": "off",
- "sonarjs/prefer-object-literal": "off",
- "sonarjs/prefer-single-boolean-return": "off",
- "@typescript-eslint/no-shadow": "off",
- "array-callback-return": "off",
- "camelcase": "error",
- "default-case": "off",
- "func-names": "error",
- "no-case-declarations": "error",
- "no-lonely-if": "off",
- "no-nested-ternary": "error",
- "no-plusplus": "off",
- "no-restricted-globals": "off",
- "no-restricted-properties": "off",
- "no-shadow": "off",
- "radix": "off",
- "spaced-comment": "off",
-
- "import/newline-after-import": "off",
- "sonarjs/no-nested-switch": "off",
- "@typescript-eslint/no-array-constructor": "off",
- "@typescript-eslint/no-empty-function": "off",
- "@typescript-eslint/no-unused-vars": "off",
- "@typescript-eslint/no-useless-constructor": "off",
- "@typescript-eslint/no-unused-expressions": "off",
- "class-methods-use-this": "off",
- "guard-for-in": "off",
- "no-unneeded-ternary": "off",
- "no-unused-expressions": "off",
- "operator-assignment": "off",
- "prefer-template": "off",
- "vars-on-top": "off",
-
- "no-use-before-define": "off", // doc for @typescript-eslint/no-use-before-define says to turn off the base implementation
- "@typescript-eslint/no-use-before-define": "error"
-
- },
- "overrides": [
- {
- "files": "*.@(ts|tsx)",
- "rules": {
- "@typescript-eslint/method-signature-style": ["off", "property"],
- // "@typescript-eslint/ban-types": [
- // "warn",
- // {
- // "types": {
- // "Omit": "Please use the 'OmitStrict' type from 'src/types/' instead.",
- // "object": false,
- // "Function": false
- // },
- // "extendDefaults": true
- // }
- // ],
-
- "quotes": "off",
- "@typescript-eslint/quotes": "off"
- // [
- // "error",
- // "single",
- // {
- // "avoidEscape": true,
- // "allowTemplateLiterals": false
- // }
- // ]
- }
- },
- {
- "files": "*.@(js|jsx|ts|tsx|mdx)",
- "rules": {
- }
- },
- {
- "files": ".storybook/*.js",
- "extends": ["@pega/eslint-config/script"]
- },
- {
- "files": "*/**/mocks/**.@(mocks|styles).@(tsx|ts)",
- "rules": {
- "import/prefer-default-export": ["off"]
- }
- }
- ]
-}
diff --git a/tests/assets/components/create/custom-constellation/_custom-constellation.md b/tests/assets/components/create/custom-constellation/_custom-constellation.md
deleted file mode 100644
index e23e4799..00000000
--- a/tests/assets/components/create/custom-constellation/_custom-constellation.md
+++ /dev/null
@@ -1,5 +0,0 @@
-# The **components/custom-constellation** directory
-
-The **src/components/custom-constellation** directory contains the code for Constellation-related _associated_ components of custom components that you create and use with the **Angular SDK**.
-These _associated_ components are used to show the preview of the custom component in App Studio when you are authoring your application and App Studio needs to use the Constellation
-design system version of your custom component.
diff --git a/tests/assets/components/create/custom-constellation/field/Pega_DXIL_MyTestText/demo.stories.jsx b/tests/assets/components/create/custom-constellation/field/Pega_DXIL_MyTestText/demo.stories.jsx
deleted file mode 100644
index 0bff1470..00000000
--- a/tests/assets/components/create/custom-constellation/field/Pega_DXIL_MyTestText/demo.stories.jsx
+++ /dev/null
@@ -1,51 +0,0 @@
-import { useState } from 'react';
-import { withKnobs } from '@storybook/addon-knobs';
-
-import { stateProps, configProps } from './mock.stories';
-
-import PegaDxilMyTestText from './index.jsx';
-
-export default {
- title: 'PegaDxilMyTestText',
- decorators: [withKnobs],
- component: PegaDxilMyTestText
-};
-
-export const basePegaDxilMyTestText = () => {
- // eslint-disable-next-line react-hooks/rules-of-hooks
- const [value, setValue] = useState(configProps.value);
-
- const props = {
- value,
- placeholder: configProps.placeholder,
- label: configProps.label,
- testId: configProps.testId,
- hasSuggestions: configProps.hasSuggestions,
-
- getPConnect: () => {
- return {
- getStateProps: () => {
- return stateProps;
- },
- getActionsApi: () => {
- return {
- updateFieldValue: (propName, theValue) => {
- setValue(theValue);
- },
- triggerFieldChange: () => {/* nothing */}
- };
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- setInheritedProps: () => {/* nothing */},
- resolveConfigProps: () => {/* nothing */}
- };
- }
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/create/custom-constellation/field/Pega_DXIL_MyTestText/index.jsx b/tests/assets/components/create/custom-constellation/field/Pega_DXIL_MyTestText/index.jsx
deleted file mode 100644
index c223d42a..00000000
--- a/tests/assets/components/create/custom-constellation/field/Pega_DXIL_MyTestText/index.jsx
+++ /dev/null
@@ -1,60 +0,0 @@
-import PropTypes from 'prop-types';
-import { Input, Label } from '@pega/cosmos-react-core';
-
-import StyledPegaDxilMyTestTextWrapper from './styles';
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-const PegaDxilMyTestText = props => {
- const { getPConnect, value, placeholder, disabled, readOnly, required, label, testId } = props;
-
- const pConn = getPConnect();
- const actions = pConn.getActionsApi();
- const propName = pConn?.getStateProps()?.value;
-
- const handleOnChange = event => {
- const { value: updatedValue } = event.target;
- actions.updateFieldValue(propName, updatedValue);
- };
-
- return (
-
- {label}
-
-
- );
-};
-
-PegaDxilMyTestText.defaultProps = {
- value: '',
- placeholder: '',
- disabled: false,
- readOnly: false,
- required: false,
- testId: null
-};
-
-PegaDxilMyTestText.propTypes = {
- label: PropTypes.string,
- value: PropTypes.string,
- placeholder: PropTypes.string,
- getPConnect: PropTypes.func.isRequired,
- disabled: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- readOnly: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- required: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- testId: PropTypes.string
-};
-
-export default PegaDxilMyTestText;
diff --git a/tests/assets/components/create/custom-constellation/field/Pega_DXIL_MyTestText/mock.stories.js b/tests/assets/components/create/custom-constellation/field/Pega_DXIL_MyTestText/mock.stories.js
deleted file mode 100644
index fd283d8b..00000000
--- a/tests/assets/components/create/custom-constellation/field/Pega_DXIL_MyTestText/mock.stories.js
+++ /dev/null
@@ -1,13 +0,0 @@
-export const configProps = {
- value: '',
- label: 'Text Sample',
- placeholder: 'Text Placeholder',
- helperText: 'Text Helper Text',
- testId: 'Text-12345678',
- hasSuggestions: false
-};
-
-export const stateProps = {
- value: '.TextSample',
- hasSuggestions: false
-};
diff --git a/tests/assets/components/create/custom-constellation/field/Pega_DXIL_MyTestText/styles.js b/tests/assets/components/create/custom-constellation/field/Pega_DXIL_MyTestText/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/create/custom-constellation/field/Pega_DXIL_MyTestText/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/create/custom-constellation/field/_field.md b/tests/assets/components/create/custom-constellation/field/_field.md
deleted file mode 100644
index da26dc3e..00000000
--- a/tests/assets/components/create/custom-constellation/field/_field.md
+++ /dev/null
@@ -1,5 +0,0 @@
-# The **custom-constellation/field** directory
-
-The **src/components/custom-constellation/field** directory contains the code for the Constellation-based associated component for any custom **field** component you have created for use with the **Angular SDK**.
-
-For each component in the **src/components/custom-constellation/field** directory, there will be a matching component in the **src/components/custom-sdk/field** directory.
diff --git a/tests/assets/components/create/custom-constellation/template/_template.md b/tests/assets/components/create/custom-constellation/template/_template.md
deleted file mode 100644
index 75835038..00000000
--- a/tests/assets/components/create/custom-constellation/template/_template.md
+++ /dev/null
@@ -1,5 +0,0 @@
-# The **custom-constellation/template** directory
-
-The **src/components/custom-constellation/template** directory contains the code for the Constellation-based associated component for any custom **template** component you have created for use with the **Angular SDK**.
-
-For each component in the **src/components/custom-constellation/template** directory, there will be a matching component in the **src/components/custom-sdk/template** directory.
diff --git a/tests/assets/components/create/custom-constellation/widget/_widget.md b/tests/assets/components/create/custom-constellation/widget/_widget.md
deleted file mode 100644
index 11871a8a..00000000
--- a/tests/assets/components/create/custom-constellation/widget/_widget.md
+++ /dev/null
@@ -1,5 +0,0 @@
-# The **custom-constellation/widget** directory
-
-The **src/components/custom-constellation/widget** directory contains the code for the Constellation-based associated component for any custom **widget** component you have created for use with the **Angular SDK**.
-
-For each component in the **src/components/custom-constellation/widget** directory, there will be a matching component in the **src/components/custom-sdk/widget** directory.
diff --git a/tests/assets/components/create/custom-sdk/_custom-sdk.md b/tests/assets/components/create/custom-sdk/_custom-sdk.md
deleted file mode 100644
index d19acbaf..00000000
--- a/tests/assets/components/create/custom-sdk/_custom-sdk.md
+++ /dev/null
@@ -1,5 +0,0 @@
-# The **components/custom-sdk** directory
-
-The **src/components/custom-sdk** directory contains the code for custom components that you create and use with the **Angular SDK**.
-
-When you run the **npm run create** command to create new components, the generated code that you can use as a starting point for your component development will be placed in type-specific and component-specific folders in **src/components/custom-sdk**.
diff --git a/tests/assets/components/create/custom-sdk/field/_field.md b/tests/assets/components/create/custom-sdk/field/_field.md
deleted file mode 100644
index 99d479f7..00000000
--- a/tests/assets/components/create/custom-sdk/field/_field.md
+++ /dev/null
@@ -1,6 +0,0 @@
-# The **custom-sdk/field** directory
-
-The **src/components/custom-sdk/field** directory contains the code for the custom **field** components you want to create and use with the **Angular SDK**.
-
-When you run the **npm run create** command to create new _field_ components, the generated code that you can use as a starting point for your component development
-will be placed in component-specific folders in **src/components/custom-sdk/field**.
diff --git a/tests/assets/components/create/custom-sdk/field/pega-dxil-my-test-text/config.json b/tests/assets/components/create/custom-sdk/field/pega-dxil-my-test-text/config.json
deleted file mode 100644
index 41631ad2..00000000
--- a/tests/assets/components/create/custom-sdk/field/pega-dxil-my-test-text/config.json
+++ /dev/null
@@ -1,83 +0,0 @@
-{
- "name": "Pega_DXIL_MyTestText",
- "label": "My Test Text",
- "description": "My Test Text Description",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyTestText",
- "type": "Field",
- "subtype": "Text",
- "icon": "images/pz-url-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- },
- {
- "label": "Advanced",
- "format": "GROUP",
- "collapsible": true,
- "properties": [
- {
- "name": "testId",
- "label": "Test ID",
- "format": "TEXT",
- "ignorePattern": "[^-_\\p{N}\\p{L}]",
- "includeAnnotations": false
- }
- ]
- }
- ],
- "defaultConfig": {
- "label": "@L $this.label"
- }
-}
diff --git a/tests/assets/components/create/custom-sdk/field/pega-dxil-my-test-text/pega-dxil-my-test-text.component.html b/tests/assets/components/create/custom-sdk/field/pega-dxil-my-test-text/pega-dxil-my-test-text.component.html
deleted file mode 100644
index d135b05c..00000000
--- a/tests/assets/components/create/custom-sdk/field/pega-dxil-my-test-text/pega-dxil-my-test-text.component.html
+++ /dev/null
@@ -1,14 +0,0 @@
-
-
-
-
-
-
diff --git a/tests/assets/components/create/custom-sdk/field/pega-dxil-my-test-text/pega-dxil-my-test-text.component.scss b/tests/assets/components/create/custom-sdk/field/pega-dxil-my-test-text/pega-dxil-my-test-text.component.scss
deleted file mode 100644
index bee2b661..00000000
--- a/tests/assets/components/create/custom-sdk/field/pega-dxil-my-test-text/pega-dxil-my-test-text.component.scss
+++ /dev/null
@@ -1,30 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- opacity: 54%;
- font-size: 0.7rem;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
-
-.psdk-grid-filter {
- display: grid;
- grid-template-columns: repeat(2, minmax(0, 1fr));
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
-
-.psdk-details-fields-label {
- color: rgba(0, 0, 0, 0.54);
- margin: 8px 0px;
-}
\ No newline at end of file
diff --git a/tests/assets/components/create/custom-sdk/field/pega-dxil-my-test-text/pega-dxil-my-test-text.component.spec.ts b/tests/assets/components/create/custom-sdk/field/pega-dxil-my-test-text/pega-dxil-my-test-text.component.spec.ts
deleted file mode 100644
index 61422dd6..00000000
--- a/tests/assets/components/create/custom-sdk/field/pega-dxil-my-test-text/pega-dxil-my-test-text.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyTestTextComponent } from './pega-dxil-my-test-text.component';
-
-describe('PegaDxilMyTestTextComponent', () => {
- let component: PegaDxilMyTestTextComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyTestTextComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyTestTextComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/create/custom-sdk/field/pega-dxil-my-test-text/pega-dxil-my-test-text.component.ts b/tests/assets/components/create/custom-sdk/field/pega-dxil-my-test-text/pega-dxil-my-test-text.component.ts
deleted file mode 100644
index 04ac61c8..00000000
--- a/tests/assets/components/create/custom-sdk/field/pega-dxil-my-test-text/pega-dxil-my-test-text.component.ts
+++ /dev/null
@@ -1,145 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-test-text',
- templateUrl: './pega-dxil-my-test-text.component.html',
- styleUrls: ['./pega-dxil-my-test-text.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class PegaDxilMyTestTextComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formatAs$: string;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: string = '';
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- componentReference: string = '';
- formattedValue$: string;
- format$: string = 'text';
- formattedUrl$: string = '';
-
- constructor(private angularPConnect: AngularPConnectService, private utils: Utils) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- this.checkAndUpdate();
- }
-
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
-
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
-
- // TDB - get formats
- switch (this.formatAs$) {
- case 'text':
- this.formattedValue$ = this.value$;
- break;
- case 'date':
- this.formattedValue$ = this.generateDate(this.value$);
- break;
- case 'date-time':
- this.formattedValue$ = this.generateDateTime(this.value$);
- break;
- case 'time':
- if (this.value$) {
- const timeParts = this.value$.split(':');
- this.formattedValue$ = `${timeParts[0]}:${timeParts[1]}`;
- } else {
- this.formattedValue$ = '';
- }
- break;
- case 'url':
- this.formattedUrl$ = this.generateUrl(this.value$);
- this.formattedValue$ = this.value$;
- break;
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- generateUrl(sVal): string {
- if (sVal.indexOf('https://') == 0 || sVal.indexOf('http://') == 0) {
- } else {
- // assume no http
- sVal = 'http://' + sVal;
- }
-
- return sVal;
- }
-
- generateDate(sVal): string {
- if (!sVal) return '';
- // const value = new Intl.DateTimeFormat('default', {
- // year: 'numeric',
- // month: 'numeric',
- // day: 'numeric'
- // }).format(new Date(sVal + "T00:00"));
-
- return this.utils.generateDate(sVal, 'Date-Long-Custom-YYYY');
- }
-
- generateDateTime(sVal): string {
- if (!sVal) return '';
- if (sVal.length === 10) return this.generateDate(sVal);
- let value = sVal.substring(0, sVal.length - 1);
- // value = new Intl.DateTimeFormat('default', {
- // year: 'numeric',
- // month: 'numeric',
- // day: 'numeric',
- // hour: 'numeric',
- // minute: 'numeric',
- // second: 'numeric',
- // hour12: true,
- // }).format(new Date(value))
-
- return this.utils.generateDateTime(value, 'DateTime-Long-YYYY-Custom');
- }
-}
diff --git a/tests/assets/components/create/custom-sdk/template/_template.md b/tests/assets/components/create/custom-sdk/template/_template.md
deleted file mode 100644
index f5875c69..00000000
--- a/tests/assets/components/create/custom-sdk/template/_template.md
+++ /dev/null
@@ -1,6 +0,0 @@
-# The **custom-sdk/template** directory
-
-The **src/components/custom-sdk/template** directory contains the code for the custom **template** components you want to create and use with the **Angular SDK**.
-
-When you run the **npm run create** command to create new _template_ components, the generated code that you can use as a starting point for your component development
-will be placed in component-specific folders in **src/components/custom-sdk/template**.
diff --git a/tests/assets/components/create/custom-sdk/widget/_widget.md b/tests/assets/components/create/custom-sdk/widget/_widget.md
deleted file mode 100644
index ca4cf89e..00000000
--- a/tests/assets/components/create/custom-sdk/widget/_widget.md
+++ /dev/null
@@ -1,6 +0,0 @@
-# The **custom-sdk/widget** directory
-
-The **src/components/custom-sdk/widget** directory contains the code for the custom **widget** components you want to create and use with the **Angular SDK**.
-
-When you run the **npm run create** command to create new _widget_ components, the generated code that you can use as a starting point for your component
-development will be placed in component-specific folders in **src/components/custom-sdk/widget**.
diff --git a/tests/assets/components/create/override-sdk/_override-sdk.md b/tests/assets/components/create/override-sdk/_override-sdk.md
deleted file mode 100644
index bd18b767..00000000
--- a/tests/assets/components/create/override-sdk/_override-sdk.md
+++ /dev/null
@@ -1,5 +0,0 @@
-# The **components/override-sdk** directory
-
-The **src/components/override-sdk** directory contains the code for components for which you want to override the default implementation for use with the **Angular SDK**.
-
-When you run the **npm run override** command to override the default implementation of a component, the generated code that you can use as a starting point for your component development will be placed in type-specific and component-specific folders in **src/components/override-sdk**.
diff --git a/tests/assets/components/create/override-sdk/designSystemExtension/_designSystemExtension.md b/tests/assets/components/create/override-sdk/designSystemExtension/_designSystemExtension.md
deleted file mode 100644
index 341a695c..00000000
--- a/tests/assets/components/create/override-sdk/designSystemExtension/_designSystemExtension.md
+++ /dev/null
@@ -1,6 +0,0 @@
-# The **override-sdk/designSystemExtension** directory
-
-The **src/components/override-sdk/designSystemExtension** directory contains the code for components that **extend** the design system and for which you want to override the default implementation for use with the **Angular SDK**.
-
-When you run the **npm run create** command to override the default implementation of a **design system extension** component, the generated code that you can use
-as a starting point for your component development will be placed in type-specific and component-specific folders in **src/components/override-sdk/designSystemExtension**.
diff --git a/tests/assets/components/create/override-sdk/field/_field.md b/tests/assets/components/create/override-sdk/field/_field.md
deleted file mode 100644
index 2ede8890..00000000
--- a/tests/assets/components/create/override-sdk/field/_field.md
+++ /dev/null
@@ -1,6 +0,0 @@
-# The **override-sdk/field** directory
-
-The **src/components/override-sdk/field** directory contains the code for **field** components for which you want to override the default implementation for use with the **Angular SDK**.
-
-When you run the **npm run create** command to override the default implementation of a **field** component, the generated code that you can use as a starting point
-for your component development will be placed in type-specific and component-specific folders in **src/components/override-sdk/field**.
diff --git a/tests/assets/components/create/override-sdk/field/auto-complete/auto-complete.component.html b/tests/assets/components/create/override-sdk/field/auto-complete/auto-complete.component.html
deleted file mode 100644
index 2d7f86d8..00000000
--- a/tests/assets/components/create/override-sdk/field/auto-complete/auto-complete.component.html
+++ /dev/null
@@ -1,33 +0,0 @@
-
-
-
-
-
-
-
- {{ label$ }}
-
-
-
- {{ opt.value }}
-
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/create/override-sdk/field/auto-complete/auto-complete.component.scss b/tests/assets/components/create/override-sdk/field/auto-complete/auto-complete.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/create/override-sdk/field/auto-complete/auto-complete.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/create/override-sdk/field/auto-complete/auto-complete.component.spec.ts b/tests/assets/components/create/override-sdk/field/auto-complete/auto-complete.component.spec.ts
deleted file mode 100644
index bc91b1db..00000000
--- a/tests/assets/components/create/override-sdk/field/auto-complete/auto-complete.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { AutoCompleteComponent } from './auto-complete.component';
-
-describe('AutoCompleteComponent', () => {
- let component: AutoCompleteComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ AutoCompleteComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(AutoCompleteComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/create/override-sdk/field/auto-complete/auto-complete.component.ts b/tests/assets/components/create/override-sdk/field/auto-complete/auto-complete.component.ts
deleted file mode 100644
index 0621dc93..00000000
--- a/tests/assets/components/create/override-sdk/field/auto-complete/auto-complete.component.ts
+++ /dev/null
@@ -1,318 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatOptionModule } from '@angular/material/core';
-import { MatAutocompleteModule } from '@angular/material/autocomplete';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-import { DatapageService } from '@pega/angular-sdk-library';
-import { handleEvent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-auto-complete',
- templateUrl: './auto-complete.component.html',
- styleUrls: ['./auto-complete.component.scss'],
- standalone: true,
- imports: [
- CommonModule,
- ReactiveFormsModule,
- MatFormFieldModule,
- MatInputModule,
- MatAutocompleteModule,
- MatOptionModule,
- forwardRef(() => ComponentMapperComponent)
- ]
-})
-export class AutoCompleteComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- PCore$: any;
- configProps$: any;
-
- label$: string = '';
- value$: string = '';
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- options$: Array;
- componentReference: string = '';
- testId: string;
- listType: string;
- columns = [];
-
- helperText: string;
- fieldControl = new FormControl('', null);
- parameters: {};
- hideLabel: any;
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils,
- private dataPageService: DatapageService
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // starting very simple...
-
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- if (this.configProps$['value'] != undefined) {
- const index = this.options$?.findIndex((element) => element.key === this.configProps$['value']);
- this.value$ = index > -1 ? this.options$[index].value : this.configProps$['value'];
- }
-
- this.testId = this.configProps$['testId'];
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
- this.listType = this.configProps$['listType'];
- const displayMode = this.configProps$['displayMode'];
- let datasource = this.configProps$['datasource'];
- let columns = this.configProps$['columns'];
- this.hideLabel = this.configProps$['hideLabel'];
- const { deferDatasource, datasourceMetadata } = this.configProps$;
- this.helperText = this.configProps$['helperText'];
- this.parameters = this.configProps$?.parameters;
- const context = this.pConn$.getContextName();
- // convert associated to datapage listtype and transform props
- // Process deferDatasource when datapage name is present. WHhen tableType is promptList / localList
- if (deferDatasource && datasourceMetadata?.datasource?.name) {
- this.listType = 'datapage';
- datasource = datasourceMetadata.datasource.name;
- this.parameters = this.flattenParameters(datasourceMetadata?.datasource?.parameters);
- const displayProp = datasourceMetadata.datasource.propertyForDisplayText.startsWith('@P')
- ? datasourceMetadata.datasource.propertyForDisplayText.substring(3)
- : datasourceMetadata.datasource.propertyForDisplayText;
- const valueProp = datasourceMetadata.datasource.propertyForValue.startsWith('@P')
- ? datasourceMetadata.datasource.propertyForValue.substring(3)
- : datasourceMetadata.datasource.propertyForValue;
- columns = [
- {
- key: 'true',
- setProperty: 'Associated property',
- value: valueProp
- },
- {
- display: 'true',
- primary: 'true',
- useForSearch: true,
- value: displayProp
- }
- ];
- }
- if (columns) {
- this.columns = this.preProcessColumns(columns);
- }
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
- if (this.listType === 'associated') {
- this.options$ = this.utils.getOptionList(this.configProps$, this.pConn$.getDataObject());
- }
-
- if (!displayMode && this.listType !== 'associated') {
- const workListData = this.PCore$.getDataApiUtils().getData(datasource, {});
-
- workListData.then((workListJSON: Object) => {
- const optionsData: Array = [];
- const results = workListJSON['data'].data;
- const displayColumn = this.getDisplayFieldsMetaData(this.columns);
- results?.forEach((element) => {
- const obj = {
- key: element.pyGUID || element[displayColumn.primary],
- value: element[displayColumn.primary]?.toString()
- };
- optionsData.push(obj);
- });
- this.options$ = optionsData;
- });
- }
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- flattenParameters(params = {}) {
- const flatParams = {};
- Object.keys(params).forEach((key) => {
- const { name, value: theVal } = params[key];
- flatParams[name] = theVal;
- });
-
- return flatParams;
- }
-
- getDisplayFieldsMetaData(columnList) {
- const displayColumns = columnList.filter((col) => col.display === 'true');
- const metaDataObj: any = { key: '', primary: '', secondary: [] };
- const keyCol = columnList.filter((col) => col.key === 'true');
- metaDataObj.key = keyCol.length > 0 ? keyCol[0].value : 'auto';
- for (let index = 0; index < displayColumns.length; index += 1) {
- if (displayColumns[index].primary === 'true') {
- metaDataObj.primary = displayColumns[index].value;
- } else {
- metaDataObj.secondary.push(displayColumns[index].value);
- }
- }
- return metaDataObj;
- }
-
- preProcessColumns(columnList) {
- return columnList?.map((col) => {
- const tempColObj = { ...col };
- tempColObj.value = col.value && col.value.startsWith('.') ? col.value.substring(1) : col.value;
- return tempColObj;
- });
- }
-
- isSelected(buttonValue: string): boolean {
- if (this.value$ === buttonValue) {
- return true;
- }
-
- return false;
- }
-
- fieldOnChange(event: any) {
- // this works - this.pConn$.setValue( this.componentReference, `property: ${this.componentReference}`);
- // this works - this.pConn$.setValue( this.componentReference, this.fieldControl.value);
- // PConnect wants to use changeHandler for onChange
- // this.angularPConnect.changeHandler( this, event);
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- optionChanged(event: any) {
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- let key = '';
- if (event?.target?.value) {
- const index = this.options$?.findIndex((element) => element.value === event.target.value);
- key = index > -1 ? (key = this.options$[index].key) : event.target.value;
- }
-
- const value = key;
- const actionsApi = this.pConn$?.getActionsApi();
- const propName = this.pConn$?.getStateProps().value;
- handleEvent(actionsApi, 'changeNblur', propName, value);
- if (this.configProps$?.onRecordChange) {
- event.target.value = value;
- this.configProps$.onRecordChange(event);
- }
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
diff --git a/tests/assets/components/create/override-sdk/field/auto-complete/config.json b/tests/assets/components/create/override-sdk/field/auto-complete/config.json
deleted file mode 100644
index b3e56275..00000000
--- a/tests/assets/components/create/override-sdk/field/auto-complete/config.json
+++ /dev/null
@@ -1,60 +0,0 @@
-{
- "name": "AutoComplete",
- "description": "Picklist",
- "type": "Field",
- "subtype": "PICKERS",
- "icon": "",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/create/override-sdk/infra/_infra.md b/tests/assets/components/create/override-sdk/infra/_infra.md
deleted file mode 100644
index 5d1cef65..00000000
--- a/tests/assets/components/create/override-sdk/infra/_infra.md
+++ /dev/null
@@ -1,6 +0,0 @@
-# The **override-sdk/infra** directory
-
-The **src/components/override-sdk/infra** directory contains the code for **infrastructure** components for which you want to override the default implementation for use with the **Angular SDK**.
-
-When run the **npm run create** command to override the default implementation of an **infrastructure** component, the generated code that you can use as a
-starting point for your component development will be placed in type-specific and component-specific folders in **src/components/override-sdk/infra**.
diff --git a/tests/assets/components/create/override-sdk/template/_template.md b/tests/assets/components/create/override-sdk/template/_template.md
deleted file mode 100644
index c77fa60b..00000000
--- a/tests/assets/components/create/override-sdk/template/_template.md
+++ /dev/null
@@ -1,6 +0,0 @@
-# The **override-sdk/template** directory
-
-The **src/components/override-sdk/template** directory contains the code for **template** components for which you want to override the default implementation for use with the **Angular SDK**.
-
-When you run the **npm run create** command to override the default implementation of a **template** component, the generated code that you can use as a
-starting point for your component development will be placed in type-specific and component-specific folders in **src/components/override-sdk/template**.
diff --git a/tests/assets/components/create/override-sdk/widget/_widget.md b/tests/assets/components/create/override-sdk/widget/_widget.md
deleted file mode 100644
index 8acacb0a..00000000
--- a/tests/assets/components/create/override-sdk/widget/_widget.md
+++ /dev/null
@@ -1,6 +0,0 @@
-# The **override-sdk/widget** directory
-
-The **src/components/override-sdk/widget** directory contains the code for **widget** components for which you want to override the default implementation for use with the **Angular SDK**.
-
-When you run the **npm run create** command to override the default implementation of a **widget** component, the generated code that you can use as a
-starting point for your component development will be placed in type-specific and component-specific folders in **src/components/override-sdk/widget**.
diff --git a/tests/assets/components/createAll/custom-constellation/.eslintrc.json b/tests/assets/components/createAll/custom-constellation/.eslintrc.json
deleted file mode 100644
index ddf04a80..00000000
--- a/tests/assets/components/createAll/custom-constellation/.eslintrc.json
+++ /dev/null
@@ -1,177 +0,0 @@
-{
- "root": true,
- "extends": ["@pega"],
- "parserOptions": {
- "project": "tsconfig.json",
- "ecmaVersion": 13,
- "warnOnUnsupportedTypeScriptVersion": false
- },
- "settings": {
- "import/resolver": {
- "typescript": {},
- "node": {
- "extensions": [".js", ".jsx"]
- }
- }
- },
- "ignorePatterns": [
- "node_modules", "packages/*/lib", "!.storybook", ".storybook/public"
- ],
- "rules": {
-
- // Prettier recommends running separately from a linter.
- // https://prettier.io/docs/en/integrating-with-linters.html#notes
- "prettier/prettier": "off",
-
- // Disable rules from shared configs we're not ready for yet.
- "sonarjs/cognitive-complexity": "off",
- "sonarjs/no-identical-functions": "off",
- "sonarjs/no-duplicate-string": "off",
- "sonarjs/no-nested-template-literals": "off",
-
- //
- // JA - Override some default lint handling here
- "@typescript-eslint/array-type": ["error", { "default": "generic" }],
- // "import/extensions": ["warn", "never"], // Turning off for now (see below)
-
- //
- // Initial release: turning these off; phase in to "warn" or "error" over time
- // For "quotes" and "@typescript-eslint/quotes", see override below for .ts/.tsx files
- "import/extensions": ["off", "never"],
- "import/named": "off",
- "import/no-cycle": "off",
- "import/no-duplicates": "off",
- "import/no-extraneous-dependencies": "off",
- "import/no-named-as-default": "off",
- "import/no-named-as-default-member": "off",
- "import/no-self-import": "off",
- "import/no-unresolved": "off",
- "import/no-useless-path-segments": "off",
- "import/order": "off",
- "import/prefer-default-export": "off",
- "import/no-relative-packages": "off",
-
- "no-else-return": "off",
- "no-restricted-syntax": "off",
- "no-underscore-dangle": "off",
-
- "jsx-a11y/alt-text": "off",
- "jsx-a11y/anchor-is-valid": "off",
- "jsx-a11y/click-events-have-key-events": "off",
- "jsx-a11y/label-has-associated-control": "off",
- "jsx-a11y/no-static-element-interactions": "off",
-
-
- "sonarjs/prefer-immediate-return": "off",
- "sonarjs/no-redundant-boolean": "off",
-
- "@typescript-eslint/dot-notation": "off", // prefer warn but needs different parserOptions
- "@typescript-eslint/naming-convention": "off", // prefer warn but needs different parserOptions
- "@typescript-eslint/ban-types": "off", // also, see override below
-
- //
- // Initial release: set to error
- "@typescript-eslint/no-inferrable-types": "off",
- "eqeqeq": "off",
- "no-alert": "off",
- "no-console": "off",
- "no-fallthrough": "error",
- "no-undef": "off",
- "no-unused-vars": "off",
- "no-var": "off",
- "prefer-const": "off",
- "yoda": "error",
- "no-irregular-whitespace": "off",
- "no-empty": "off",
- "no-new-object": "off",
-
- "import/no-mutable-exports": "error",
- "sonarjs/max-switch-cases": "error",
- "sonarjs/no-collapsible-if": "off",
- "sonarjs/no-all-duplicated-branches": "off",
- "sonarjs/no-duplicated-branches": "off",
- "sonarjs/no-gratuitous-expressions": "off",
- "sonarjs/no-ignored-return": "off",
- "sonarjs/no-small-switch": "off",
- "sonarjs/prefer-object-literal": "off",
- "sonarjs/prefer-single-boolean-return": "off",
- "@typescript-eslint/no-shadow": "off",
- "array-callback-return": "off",
- "camelcase": "error",
- "default-case": "off",
- "func-names": "error",
- "no-case-declarations": "error",
- "no-lonely-if": "off",
- "no-nested-ternary": "error",
- "no-plusplus": "off",
- "no-restricted-globals": "off",
- "no-restricted-properties": "off",
- "no-shadow": "off",
- "radix": "off",
- "spaced-comment": "off",
-
- "import/newline-after-import": "off",
- "sonarjs/no-nested-switch": "off",
- "@typescript-eslint/no-array-constructor": "off",
- "@typescript-eslint/no-empty-function": "off",
- "@typescript-eslint/no-unused-vars": "off",
- "@typescript-eslint/no-useless-constructor": "off",
- "@typescript-eslint/no-unused-expressions": "off",
- "class-methods-use-this": "off",
- "guard-for-in": "off",
- "no-unneeded-ternary": "off",
- "no-unused-expressions": "off",
- "operator-assignment": "off",
- "prefer-template": "off",
- "vars-on-top": "off",
-
- "no-use-before-define": "off", // doc for @typescript-eslint/no-use-before-define says to turn off the base implementation
- "@typescript-eslint/no-use-before-define": "error"
-
- },
- "overrides": [
- {
- "files": "*.@(ts|tsx)",
- "rules": {
- "@typescript-eslint/method-signature-style": ["off", "property"],
- // "@typescript-eslint/ban-types": [
- // "warn",
- // {
- // "types": {
- // "Omit": "Please use the 'OmitStrict' type from 'src/types/' instead.",
- // "object": false,
- // "Function": false
- // },
- // "extendDefaults": true
- // }
- // ],
-
- "quotes": "off",
- "@typescript-eslint/quotes": "off"
- // [
- // "error",
- // "single",
- // {
- // "avoidEscape": true,
- // "allowTemplateLiterals": false
- // }
- // ]
- }
- },
- {
- "files": "*.@(js|jsx|ts|tsx|mdx)",
- "rules": {
- }
- },
- {
- "files": ".storybook/*.js",
- "extends": ["@pega/eslint-config/script"]
- },
- {
- "files": "*/**/mocks/**.@(mocks|styles).@(tsx|ts)",
- "rules": {
- "import/prefer-default-export": ["off"]
- }
- }
- ]
-}
diff --git a/tests/assets/components/createAll/custom-constellation/_custom-constellation.md b/tests/assets/components/createAll/custom-constellation/_custom-constellation.md
deleted file mode 100644
index e23e4799..00000000
--- a/tests/assets/components/createAll/custom-constellation/_custom-constellation.md
+++ /dev/null
@@ -1,5 +0,0 @@
-# The **components/custom-constellation** directory
-
-The **src/components/custom-constellation** directory contains the code for Constellation-related _associated_ components of custom components that you create and use with the **Angular SDK**.
-These _associated_ components are used to show the preview of the custom component in App Studio when you are authoring your application and App Studio needs to use the Constellation
-design system version of your custom component.
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/Boolean.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/Boolean.js
deleted file mode 100644
index 231eff52..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/Boolean.js
+++ /dev/null
@@ -1,38 +0,0 @@
-function Boolean(value, { allowEmpty = true, tick = "", cross = "" } = {}) {
- if (
- (!allowEmpty && !value) ||
- value === false ||
- value?.toString()?.toLowerCase() === "false" ||
- value === 0 ||
- value === "0"
- ) {
- return cross || "";
- }
- if (
- value === true ||
- value?.toString()?.toLowerCase() === "true" ||
- value === 1 ||
- value === "1"
- ) {
- return tick || "";
- }
- if (
- allowEmpty &&
- (value === "null" ||
- value === "" ||
- value === null ||
- typeof value === "undefined")
- ) {
- return "––";
- }
- return value;
-}
-
-export default {
- TrueFalse: (value, options) =>
- Boolean(value, {
- ...options,
- tick: "True",
- cross: "False"
- })
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/boolean-format.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/boolean-format.js
deleted file mode 100644
index a54a334b..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/boolean-format.js
+++ /dev/null
@@ -1,26 +0,0 @@
-import Boolean from "./Boolean";
-
-
-export default {
- ...Boolean
-};
-
-
-
-export function format(value, type) {
- let formattedValue;
-
- switch (type?.toLowerCase()) {
-
-
- case "boolean":
- case "checkbox": {
- formattedValue = Boolean.TrueFalse(value, { allowEmpty: false });
- break;
- }
-
- default:
- formattedValue = value;
- }
- return formattedValue;
-}
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/demo.stories.jsx
deleted file mode 100644
index 7906dae0..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/demo.stories.jsx
+++ /dev/null
@@ -1,61 +0,0 @@
-import { useState } from 'react';
-import { withKnobs } from '@storybook/addon-knobs';
-
-import { configProps, stateProps } from './mock.stories';
-
-import PegaDxilMyBoolean from './index';
-
-export default {
- title: 'PegaDxilMyBoolean',
- decorators: [withKnobs],
- component: PegaDxilMyBoolean
-};
-
-export const basePegaDxilMyBoolean = () => {
- // eslint-disable-next-line react-hooks/rules-of-hooks
- const [value, setValue] = useState(configProps.value);
-
- const props = {
- value,
- label: configProps.label,
- helperText: configProps.helperText,
- caption: configProps.caption,
- validatemessage: configProps.validatemessage,
- hideLabel: configProps.hideLabel,
- testId: configProps.testId,
- additionalProps: configProps.additionalProps,
- displayMode: configProps.displayMode,
- variant: configProps.variant,
- trueLabel: configProps.trueLabel,
- falseLabel: configProps.falseLabel,
- disabled: configProps.disabled,
- readOnly: configProps.readOnly,
- required: configProps.required,
- getPConnect: () => {
- return {
- getStateProps: () => {
- return stateProps;
- },
- getActionsApi: () => {
- return {
- updateFieldValue: (propName, theValue) => {
- setValue(theValue);
- },
- triggerFieldChange: () => { /* nothing */}
- };
- },
- getValidationApi: () => {
- return {
- validate: () => { /* nothing */}
- };
- }
- };
- }
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/event-utils.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/event-utils.js
deleted file mode 100644
index 8b806f56..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/event-utils.js
+++ /dev/null
@@ -1,18 +0,0 @@
-const handleEvent = (actions, eventType, propName, value) => {
- switch (eventType) {
- case "change":
- actions.updateFieldValue(propName, value);
- break;
- case "blur":
- actions.triggerFieldChange(propName, value);
- break;
- case "changeNblur":
- actions.updateFieldValue(propName, value);
- actions.triggerFieldChange(propName, value);
- break;
- default:
- break;
- }
-};
-
-export default handleEvent;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/index.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/index.jsx
deleted file mode 100644
index f91c390d..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/index.jsx
+++ /dev/null
@@ -1,170 +0,0 @@
-import {
- Checkbox as CosmosCheckbox,
- CheckboxGroup,
- FieldValueList,
- Text
-} from "@pega/cosmos-react-core";
-import PropTypes from "prop-types";
-
-// includes in bundle
-import handleEvent from "./event-utils";
-
-import StyledPegaDxilMyBooleanWrapper from './styles';
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-const PegaDxilMyBoolean = props => {
- const {
- getPConnect,
- value,
- label,
- helperText,
- caption,
- validatemessage,
- hideLabel,
- testId,
- additionalProps,
- displayMode,
- variant,
- trueLabel,
- falseLabel
- } = props;
- const pConn = getPConnect();
- const actions = pConn.getActionsApi();
- const propName = pConn.getStateProps().value;
-
- let { readOnly, required, disabled } = props;
- [readOnly, required, disabled] = [readOnly, required, disabled].map(
- (prop) => prop === true || (typeof prop === 'string' && prop === 'true')
- );
-
- let status = "";
- if (validatemessage !== "") {
- status = "error";
- }
-
- const aCosmosCheckbox = (
- {
- handleEvent(actions, "changeNblur", propName, event.target.checked);
- }}
- onBlur={(event) => {
- pConn.getValidationApi().validate(event.target.checked);
- }}
- data-testid={testId}
- />
- );
-
- const parentTestId = testId ? `${testId}-parent` : testId;
-
- let displayComponent;
- if (displayMode) {
- displayComponent = ;
- }
-
- if (displayMode === 'DISPLAY_ONLY') {
- return ( displayComponent );
- }
-
- if (displayMode === "LABELS_LEFT") {
- return (
-
-
-
- );
- }
-
- if (displayMode === "STACKED_LARGE_VAL") {
- return (
-
-
- {displayComponent}
-
- )
- }
- ]}
- />
-
- );
- }
-
-
- return (
-
-
- {aCosmosCheckbox}
-
-
- );
-
-
-};
-
-
-PegaDxilMyBoolean.defaultProps = {
- validatemessage: '',
- value: false,
- label: '',
- hideLabel: false,
- helperText: '',
- disabled: false,
- readOnly: false,
- required: false,
- testId: null,
- additionalProps: {},
- displayMode: null,
- variant: 'inline',
- displayValue: 'Yes/No',
- trueLabel: '',
- falseLabel: ''
-};
-
-PegaDxilMyBoolean.propTypes = {
- getPConnect: PropTypes.func.isRequired,
- validatemessage: PropTypes.string,
- label: PropTypes.string,
- hideLabel: PropTypes.bool,
- helperText: PropTypes.string,
- value: PropTypes.bool,
- caption: PropTypes.string.isRequired,
- disabled: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- readOnly: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- required: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- testId: PropTypes.string,
- additionalProps: PropTypes.objectOf(PropTypes.any),
- displayMode: PropTypes.string,
- variant: PropTypes.string,
- displayValue: PropTypes.string,
- trueLabel: PropTypes.string,
- falseLabel: PropTypes.string
-};
-
-export default PegaDxilMyBoolean;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/mock.stories.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/mock.stories.js
deleted file mode 100644
index a2f8eb1c..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/mock.stories.js
+++ /dev/null
@@ -1,21 +0,0 @@
-export const configProps = {
- value: true,
- label: 'Boolean label',
- helperText: 'Test helper text',
- caption: 'Boolean caption',
- validatemessage: '',
- hideLabel: false,
- testId: '12345678',
- additionalProps: {},
- displayMode: '',
- variant: '',
- trueLabel: 'True',
- falseLabel: 'False',
- disabled: false,
- readOnly: false,
- required: true
-};
-
-export const stateProps = {
- value: '.Test'
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/styles.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyBoolean/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyCurrency/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyCurrency/demo.stories.jsx
deleted file mode 100644
index 869b26ce..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyCurrency/demo.stories.jsx
+++ /dev/null
@@ -1,53 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-
-import { configProps, fieldMetadata, stateProps } from './mock.stories.js';
-
-import PegaDxilMyCurrency from './index.jsx';
-
-export default {
- title: 'PegaDxilMyCurrency',
- decorators: [withKnobs],
- component: PegaDxilMyCurrency
-};
-
-export const basePegaDxilMyCurrency = () => {
-
- const props = {
- value: Number(configProps.value),
- placeholder: configProps.placeholder,
- label: configProps.label,
- helperText: configProps.helperText,
- showGroupSeparators: configProps.showGroupSeparators,
- allowDecimals: configProps.allowDecimals,
- currencyISOCode: configProps.currencyISOCode,
- alwaysShowISOCode: configProps.alwaysShowISOCode,
- hasSuggestions: configProps.hasSuggestions,
- testId: configProps.testId,
- fieldMetadata,
-
- getPConnect: () => {
- return {
- getStateProps: () => {
- return stateProps;
- },
- getActionsApi: () => {
- return {
- updateFieldValue: () => {/* nothing */},
- triggerFieldChange: () => {/* nothing */}
- };
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- setInheritedProps: () => {/* nothing */},
- resolveConfigProps: () => {/* nothing */},
- clearErrorMessages: () => {/* nothing */}
- };
- }
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyCurrency/event-utils.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyCurrency/event-utils.js
deleted file mode 100644
index 8b806f56..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyCurrency/event-utils.js
+++ /dev/null
@@ -1,18 +0,0 @@
-const handleEvent = (actions, eventType, propName, value) => {
- switch (eventType) {
- case "change":
- actions.updateFieldValue(propName, value);
- break;
- case "blur":
- actions.triggerFieldChange(propName, value);
- break;
- case "changeNblur":
- actions.updateFieldValue(propName, value);
- actions.triggerFieldChange(propName, value);
- break;
- default:
- break;
- }
-};
-
-export default handleEvent;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyCurrency/index.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyCurrency/index.jsx
deleted file mode 100644
index f8c747af..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyCurrency/index.jsx
+++ /dev/null
@@ -1,296 +0,0 @@
-import { useState, useEffect } from 'react';
-import {
- CurrencyInput as CosmosCurrency,
- CurrencyDisplay,
- NumberDisplay,
- FieldValueList,
- Text,
- useAfterInitialEffect
-} from '@pega/cosmos-react-core';
-import PropTypes from 'prop-types';
-
-// includes in bundle
-import handleEvent from './event-utils';
-import { suggestionsHandler } from './suggestions-handler';
-
-import StyledPegaDxilMyCurrencyWrapper from './styles';
-
-const formatValue = (value) => {
- if (!value && value !== 0) return '';
- const [integer, decimal = ''] = value.toString().split('.');
- return `${integer}.${decimal.padEnd(3, '0')}`;
-};
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-const PegaDxilMyCurrency = props => {
- const {
- getPConnect,
- value,
- placeholder,
- validatemessage,
- label,
- hideLabel,
- helperText,
- testId,
- allowDecimals,
- currencyISOCode,
- alwaysShowISOCode,
- displayMode,
- additionalProps,
- variant,
- formatter,
- negative,
- notation,
- isTableFormatter,
- hasSuggestions
- } = props;
- let { currencyDisplay } = props;
- const pConn = getPConnect();
- const actions = pConn.getActionsApi();
- const propName = pConn.getStateProps().value;
- const [currencyValue, setCurrencyValue] = useState(() => formatValue(value));
-
- let { readOnly, required, disabled } = props;
-
- [readOnly, required, disabled] = [readOnly, required, disabled].map(
- (prop) => prop === true || (typeof prop === 'string' && prop === 'true')
- );
-
- const [status, setStatus] = useState(hasSuggestions ? 'pending' : undefined);
-
- useEffect(() => {
- if (validatemessage !== '') {
- setStatus('error');
- }
- if (hasSuggestions) {
- setStatus('pending');
- } else if (!hasSuggestions && status !== 'success') {
- setStatus(validatemessage !== '' ? 'error' : undefined);
- }
- }, [validatemessage, hasSuggestions]);
-
- useAfterInitialEffect(() => {
- setCurrencyValue(formatValue(value));
- }, [value]);
-
- const { decimalPrecision, currencyDecimalPrecision } = props;
- let noOfDecimals = parseInt(decimalPrecision, 10);
- if (Number.isNaN(noOfDecimals)) noOfDecimals = undefined;
- let noOfFractionDigits = currencyDecimalPrecision === 'auto' ? undefined : parseInt(currencyDecimalPrecision, 10);
-
- if (displayMode === 'LABELS_LEFT' || displayMode === 'STACKED_LARGE_VAL' || displayMode === 'DISPLAY_ONLY') {
- let displayComp;
- let { showGroupSeparators } = props;
- if (displayMode === 'LABELS_LEFT' && isTableFormatter) {
- noOfFractionDigits = undefined;
- showGroupSeparators = true;
- if (formatter === 'Currency-Code') {
- currencyDisplay = 'code';
- }
- }
-
- const displayValue = !value && value !== 0 ? undefined : Number(currencyValue);
-
-
- displayComp = (
-
- );
-
-
-
-
- if (['Integer', 'Decimal', 'Percentage', 'Decimal-Auto'].includes(formatter)) {
- let unit;
-
- switch (formatter) {
- case 'Integer': {
- noOfDecimals = 0;
- break;
- }
- case 'Decimal': {
- break;
- }
- case 'Decimal-Auto': {
- noOfDecimals = Number.isInteger(currencyValue) ? 0 : 2;
- break;
- }
- case 'Percentage': {
- showGroupSeparators = false;
- unit = 'percent';
- break;
- }
- // no default
- }
-
- displayComp = (
-
- );
- }
-
-
- switch (displayMode) {
- case 'DISPLAY_ONLY': {
- return ( displayComp ) ;
- }
- case 'LABELS_LEFT': {
- return (
-
-
-
- );
- }
- case 'STACKED_LARGE_VAL': {
- return (
-
-
- {displayComp}
-
- )
- }
- ]}
- />
-
- );
- }
- // no default
- }
- }
-
- const onResolveSuggestionHandler = (accepted) => {
- suggestionsHandler(accepted, pConn, setStatus);
- };
-
- return (
-
- {
- if (hasSuggestions) {
- setStatus(undefined);
- }
- setCurrencyValue(enteredValue);
- pConn.clearErrorMessages({
- property: propName
- });
- }}
- onBlur={(enteredValue) => {
- const parsedValue = enteredValue !== '' ? Number(enteredValue) : enteredValue;
- if (!readOnly && (!value || value !== parsedValue)) {
- handleEvent(actions, 'changeNblur', propName, parsedValue);
- if (hasSuggestions) {
- pConn.ignoreSuggestion();
- }
- }
- }}
- onResolveSuggestion={onResolveSuggestionHandler}
- />
-
- );
-}
-
-PegaDxilMyCurrency.defaultProps = {
- value: 0,
- placeholder: '',
- validatemessage: '',
- helperText: '',
- hideLabel: false,
- disabled: false,
- readOnly: false,
- required: false,
- decimalPrecision: null,
- allowDecimals: true,
- currencyISOCode: 'USD',
- isoCodeSelection: 'constant',
- testId: null,
- displayMode: null,
- additionalProps: {},
- variant: 'inline',
- showGroupSeparators: false,
- formatter: 'defaultCurrency',
- currencyDisplay: 'symbol',
- negative: 'minus-sign',
- notation: 'standard',
- currencyDecimalPrecision: 'auto',
- isTableFormatter: false,
- alwaysShowISOCode: false,
- hasSuggestions: false
-};
-
-PegaDxilMyCurrency.propTypes = {
- value: PropTypes.number,
- placeholder: PropTypes.string,
- label: PropTypes.string.isRequired,
- decimalPrecision: PropTypes.number,
- allowDecimals: PropTypes.bool,
- currencyISOCode: PropTypes.string,
- isoCodeSelection: PropTypes.string,
- hideLabel: PropTypes.bool,
- getPConnect: PropTypes.func.isRequired,
- validatemessage: PropTypes.string,
- helperText: PropTypes.string,
- disabled: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- readOnly: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- required: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- testId: PropTypes.string,
- displayMode: PropTypes.string,
- additionalProps: PropTypes.objectOf(PropTypes.any),
- variant: PropTypes.string,
- showGroupSeparators: PropTypes.bool,
- formatter: PropTypes.string,
- currencyDisplay: PropTypes.string,
- negative: PropTypes.string,
- notation: PropTypes.string,
- currencyDecimalPrecision: PropTypes.string,
- isTableFormatter: PropTypes.bool,
- alwaysShowISOCode: PropTypes.bool,
- hasSuggestions: PropTypes.bool
-};
-
-export default PegaDxilMyCurrency;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyCurrency/mock.stories.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyCurrency/mock.stories.js
deleted file mode 100644
index adaecb3f..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyCurrency/mock.stories.js
+++ /dev/null
@@ -1,23 +0,0 @@
-export const configProps = {
- value: '',
- label: 'Currency Sample',
- currencyISOCode: 'USD',
- allowDecimals: true,
- alwaysShowISOCode: true,
- placeholder: 'Currency Placeholder',
- helperText: 'Currency Helper Text',
- testId: 'currency-12345678',
- hasSuggestions: false
-};
-
-export const stateProps = {
- value: '.CurrencySample',
- hasSuggestions: false
-};
-
-export const fieldMetadata = {
- classID: 'DIXL-MediaCo-Work-NewService',
- type: 'Decimal',
- displayAs: 'pxCurrency',
- label: 'Currency sample'
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyCurrency/styles.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyCurrency/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyCurrency/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyCurrency/suggestions-handler.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyCurrency/suggestions-handler.js
deleted file mode 100644
index 901cd99e..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyCurrency/suggestions-handler.js
+++ /dev/null
@@ -1,10 +0,0 @@
-/* eslint-disable import/prefer-default-export */
-export const suggestionsHandler = (accepted, pConn, setStatus) => {
- if (accepted) {
- pConn.acceptSuggestion();
- setStatus('success');
- } else {
- pConn.ignoreSuggestion();
- setStatus(undefined);
- }
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/DateFormatter.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/DateFormatter.js
deleted file mode 100644
index d0572897..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/DateFormatter.js
+++ /dev/null
@@ -1,61 +0,0 @@
-import dayjs from 'dayjs';
-import relativeTime from 'dayjs/plugin/relativeTime.js';
-import localizedFormat from 'dayjs/plugin/localizedFormat.js';
-import utc from 'dayjs/plugin/utc.js';
-import timezone from 'dayjs/plugin/timezone.js';
-
-dayjs.extend(relativeTime);
-dayjs.extend(localizedFormat);
-dayjs.extend(utc);
-dayjs.extend(timezone);
-
-const types = ['fromNow', 'customFormat'];
-
-
-
-// value should be in ISO 8601 format.
-function DateFormatter(
- value,
- { type = types[1], format = "DD/MM/YYYY", tzone } = {}
-) {
- if (!value) return value;
- switch (type) {
- case types[1]:
- if (tzone) return dayjs(value).tz(tzone).format(format);
- return dayjs(value).format(format);
- case types[0]:
- return dayjs(value).from(dayjs());
- default:
- return value;
- }
-}
-
-// value should be in hh:mm:ss format (00:00:00 - 23:59:59).
-function TimeFormatter(value, options) {
- if (!value) return value;
- const { locale = "en-US" } = options;
- const timeOnlyRegex = /^(?:[01]\d|2[0123]):(?:[012345]\d):(?:[012345]\d)$/;
- if (value.length === 8 && timeOnlyRegex.test(value)) {
- const tempDate = new Date();
- const hours = parseInt(value.substr(0, 2), 10);
- const minutes = parseInt(value.substr(3, 2), 10);
- const seconds = parseInt(value.substr(6, 2), 10);
- tempDate.setHours(hours);
- tempDate.setMinutes(minutes);
- tempDate.setSeconds(seconds);
- return tempDate.toLocaleTimeString(locale);
- }
- return DateFormatter(value, options);
-}
-
-export default {
- Date: (value, options) => DateFormatter(value, { type: 'customFormat', ...options }),
- 'Date-Time-Default': (value, options) =>
- DateFormatter(value, { ...options, type: 'customFormat', format: 'lll' }),
- 'Time-Default': (value, options) =>
- TimeFormatter(value, {
- ...options,
- type: 'customFormat',
- format: 'hh:mm A'
- })
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/FormattedText.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/FormattedText.jsx
deleted file mode 100644
index 76cec590..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/FormattedText.jsx
+++ /dev/null
@@ -1,41 +0,0 @@
-import { FieldValueList } from '@pega/cosmos-react-core';
-import PropTypes from 'prop-types';
-
-import { format } from './date.js';
-
-export default function FormattedText(props) {
- const { formatType, label, value, testId, hideLabel, variant, additionalProps } = props;
-
- let text = value;
-
- text = format(text, formatType, additionalProps);
-
- const fields = [
- {
- id: label.toLowerCase(),
- name: hideLabel ? '' : label,
- value: text
- }
- ];
- return ;
-}
-
-FormattedText.defaultProps = {
- formatType: 'none',
- variant: 'stacked',
- value: undefined,
- label: '',
- testId: null,
- hideLabel: false,
- additionalProps: {}
-};
-
-FormattedText.propTypes = {
- formatType: PropTypes.string,
- variant: PropTypes.oneOf(['inline', 'stacked']),
- value: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.bool]),
- label: PropTypes.string,
- testId: PropTypes.string,
- additionalProps: PropTypes.objectOf(PropTypes.any),
- hideLabel: PropTypes.bool
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/date.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/date.js
deleted file mode 100644
index f6fdcf3a..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/date.js
+++ /dev/null
@@ -1,439 +0,0 @@
-/* eslint-disable no-undef */
-import dayjs from 'dayjs';
-import DateFormatter from './DateFormatter.js';
-
-import relativeTime from 'dayjs/plugin/relativeTime.js';
-import localizedFormat from 'dayjs/plugin/localizedFormat.js';
-import utc from 'dayjs/plugin/utc.js';
-import timezone from 'dayjs/plugin/timezone.js';
-
-dayjs.extend(relativeTime);
-dayjs.extend(localizedFormat);
-dayjs.extend(utc);
-dayjs.extend(timezone);
-
-function isIsoDate(str) {
- if (!/\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}.\d{3}Z/.test(str)) return false;
- const d = new Date(str);
- return d.toISOString() === str;
-}
-
-function getDateObject(text) {
- // TODO - cleanup formatters util functions as DX APIs are returning values per ISO std now.
- const timeStamp = text.replace(/-/g, '');
- const isDateTime = timeStamp.indexOf('GMT') !== -1;
- const year = parseInt(timeStamp.substr(0, 4), 10);
- const month = parseInt(timeStamp.substr(4, 2), 10) - 1;
- const day = parseInt(timeStamp.substr(6, 2), 10);
-
- const date = new Date();
-
- date.setDate(day);
- date.setMonth(month);
- date.setFullYear(year);
-
- if (isDateTime) {
- const hours = parseInt(timeStamp.substr(9, 2), 10);
- const minutes = parseInt(timeStamp.substr(11, 2), 10);
- const seconds = parseInt(timeStamp.substr(13, 2), 10);
- const ms = parseInt(timeStamp.substr(16, 3), 10);
- date.setHours(hours);
- date.setMinutes(minutes);
- date.setSeconds(seconds);
- date.setMilliseconds(ms);
- }
-
- return date;
-}
-
-function parseDateInISO(value) {
- const isMilliSeconds = new RegExp('^[0-9]+$').exec(value);
- if (isMilliSeconds) {
- const date = new Date(parseInt(value, 10));
- return date.toISOString();
- }
-
- if (isIsoDate(value)) {
- const date = new Date(value);
- return date.toISOString();
- }
-
- return value ? getDateObject(value).toISOString() : value;
-}
-
-export default {
- ...DateFormatter
-};
-
-export const datetimedisplayformatter = formatter => {
- const objectvalues = {};
- switch (formatter) {
- case 'DateTime-Long': {
- objectvalues.variantVal = 'datetime';
- objectvalues.formatVal = 'long';
- break;
- }
- case 'DateTime-Short': {
- objectvalues.variantVal = 'date';
- objectvalues.formatVal = 'short';
- break;
- }
- case 'DateTime-Since': {
- objectvalues.variantVal = 'relative';
- break;
- }
- case 'Time-Only': {
- objectvalues.variantVal = 'time';
- objectvalues.formatVal = 'short';
- break;
- }
- // no default
- }
- return objectvalues;
-};
-
-export const formatExists = formatterVal => {
- const formatterValues = ['DateTime-Long', 'DateTime-Short', 'DateTime-Since', 'Time-Only'];
- let isformatter = false;
- if (formatterValues.includes(formatterVal)) {
- isformatter = true;
- }
- return isformatter;
-};
-
-/**
- * Return relative time in fromNow for the given datetime
- * @description Convert and return the given datetime in dayJSObject
- *
- * @param {string} text datetime
- * @returns {object} datetime as a dayjs object
- */
-export const getDayJSObject = text => {
- const momObj = dayjs(text);
- if (momObj.isValid()) return momObj;
- const timeStamp = text;
- const isDateTime = timeStamp.indexOf('GMT') !== -1;
- const year = parseInt(timeStamp.substr(0, 4), 10);
- const month = parseInt(timeStamp.substr(4, 2), 10) - 1;
- const day = parseInt(timeStamp.substr(6, 2), 10);
-
- const CurrentTz = PCore.getLocaleUtils().getTimeZoneInUse();
-
- let mom = new Date();
-
- mom.setUTCDate(day);
- mom.setUTCMonth(month);
- mom.setUTCFullYear(year);
-
- /* istanbul ignore else */
- if (isDateTime) {
- const hours = parseInt(timeStamp.substr(9, 2), 10);
- const minutes = parseInt(timeStamp.substr(11, 2), 10);
- const seconds = parseInt(timeStamp.substr(13, 2), 10);
- const ms = parseInt(timeStamp.substr(16, 3), 10);
- mom.setUTCHours(hours);
- mom.setUTCMinutes(minutes);
- mom.setUTCSeconds(seconds);
- mom.setUTCMilliseconds(ms);
- }
-
- mom = dayjs(
- mom.toLocaleString('en-US', {
- timeZone: CurrentTz
- })
- );
-
- return mom;
-};
-
-/**
- * Return relative time in fromNow for the given datetime
- *
- * @param {string} time datetime
- * @returns {object} relative time from now
- */
-export const getRelativeTime = time => {
- let relativetime = '';
- if (dayjs(time).isUTC()) {
- relativetime = dayjs(time).fromNow();
- } else {
- const dayjstime = getDayJSObject(time);
- relativetime = dayjs(dayjstime).fromNow();
- }
- return relativetime;
-};
-
-/**
- * Return year for the date passed
- *
- * @param {string} value from which Year needs to be taken out
- * @returns {number} year for the date passed
- */
-export const getFullYear = value =>
- value ? new Date(value).getFullYear() : new Date().getFullYear();
-
-/**
- * Return maxDate for the date passed
- *
- * @param {number} nextYears next number of years
- * @param {number} currentYear current year
- * @param {number} yearFromValue year set on value in redux
- *
- * @returns {string} maxDate calculated based on inputs
- */
-export const getMaxDate = (nextYears, currentYear, yearFromValue) => {
- if (Number.isNaN(nextYears)) {
- nextYears = 20;
- }
- let maxYear = currentYear + nextYears;
- if (yearFromValue > maxYear) {
- maxYear = yearFromValue;
- }
- return `${maxYear}-01-01`;
-};
-
-/**
- * Return minDate for the date passed
- *
- * @param {number} previousYears previous number of years
- * @param {number} currentYear current year
- * @param {number} yearFromValue year set on value in redux
- *
- * @returns {string} minDate calculated based on inputs
- */
-export const getMinDate = (previousYears, currentYear, yearFromValue) => {
- if (Number.isNaN(previousYears)) {
- previousYears = 100;
- }
- let minYear = currentYear - previousYears;
- if (yearFromValue < minYear) {
- minYear = yearFromValue;
- }
- return `${minYear}-12-31`;
-};
-
-/**
- * Return clockFormat after parsing
- *
- * @param {number | string} clockFormat chosen by user
- *
- * @returns {number} clockFormat
- */
-export const parseClockFormat = clockFormat =>
- typeof clockFormat === 'string' ? parseInt(clockFormat, 10) : clockFormat;
-
-/**
- * Return datetime value string off to seconds
- *
- * @param {string} datetime in ISO format
- * @param {boolean} withSeconds to specify if seconds is needed or not
- *
- * @returns {string} datetime after stripping of ms and seconds if selected to
- */
-export const correctDateTimeToSeconds = (datetime, withSeconds) => {
- if (withSeconds) {
- return `${datetime.substring(0, datetime.indexOf('Z'))}.000Z`;
- }
- return `${datetime.substring(0, datetime.lastIndexOf(':'))}:00.000Z`;
-};
-
-/**
- * Return time value string off to seconds
- *
- * @param {string} datetime in ISO format
- * @param {boolean} withSeconds to specify if seconds is needed or not
- *
- * @returns {string} just time after stripping of ms and seconds if selected to
- */
-export const timeCorrectedToSeconds = (datetime, withSeconds) => {
- if (withSeconds) {
- return datetime.substring(datetime.indexOf('T') + 1, datetime.indexOf('.'));
- }
- return `${datetime.substring(datetime.indexOf('T') + 1, datetime.lastIndexOf(':'))}:00`;
-};
-
-/**
- * This function handles the cosmos blur handler of DateTime components
- *
- * @param {string | undefined} errorState for the selected datetime value
- * @param {string} actualValue present in redux
- * @param {string} formattedValue retrieved by trimming ISO to just Date/Time, also applying timezone if DateTime
- * @param {object} actions object which has fire and blur callbacks
- * @param {string} propName name of the property bound
- * @param {object} pConn component's PConnect object which is useful to invoke validationApi
- *
- * @returns {void}
- */
-export const datetimeFireChangeBlurEvents = (
- errorState,
- actualValue,
- formattedValue,
- actions,
- propName,
- pConn
-) => {
- // TODO - clean up, we should not rely on timestamp from cosmos to check InComplete validation
- // above triggerFieldChange should have validated this
- if (errorState) {
- pConn.getValidationApi().validate(errorState);
- }
- // BUG-640834 In errorState presist old values avoiding store update & re-render.
- else {
- if (formattedValue !== actualValue) {
- actions.updateFieldValue(propName, formattedValue);
- }
- actions.triggerFieldChange(propName, formattedValue);
- }
-};
-
-/**
- * Return Date format for the locale passed
- *
- * @param {string} locale locale string
- * @param {object} options options for format string
- * @returns {string} dateformat for the locale
- * Example : getDateFormat("pl-PL") returns "DD.MM.YYYY"
- */
-export const getDateFormat = (locale, options) => {
- return new Intl.DateTimeFormat(locale, options)
- .formatToParts()
- .map(({ type, value }) => {
- switch (type) {
- case 'day':
- return 'DD';
- case 'month':
- return 'MM';
- case 'year':
- return 'YYYY';
- case 'hour':
- return 'hh';
- case 'minute':
- return 'mm';
- case 'second':
- return 'ss';
- case 'dayPeriod':
- return 'A';
- case 'literal':
- return value;
- default:
- return '';
- }
- })
- .join('');
-};
-
-/**
- * Return boolean for the locale passed to specify if locale uses 12 hour format
- *
- * @param {string} locale locale string
- * @returns {boolean} True or False for the locale
- * Example : getDateFormat("pl-PL") returns false
- */
-export const is12HClockFormat = locale => {
- const meridiem = new Intl.DateTimeFormat(locale, {
- hour: 'numeric'
- })
- .formatToParts()
- .find(({ type }) => type === 'dayPeriod');
- return !!(meridiem === null || meridiem === undefined ? undefined : meridiem.value);
-};
-
-/**
- * Return Option object for Time formatting
- *
- * @param {boolean} withSeconds true or false depending on seconds to be included
- * @param {boolean} is12h 12 hour format
- * @returns {object} options object time formatting
- * Example : getTimeOptions(false, true) returns {hour: 'numeric',minute: 'numeric',hour12: true}
- */
-export const getTimeOptions = (withSeconds, is12h = false) => {
- return {
- hour: 'numeric',
- minute: 'numeric',
- ...(withSeconds && { second: 'numeric' }),
- hour12: is12h
- };
-};
-
-/**
- * Return Option object for Datetime formatting
- *
- * @param {boolean} withSeconds true or false depending on seconds to be included
- * @param {boolean} is12h 12 hour format
- * @returns {object} options object datetime formatting
- * Example : getDateTimeOptions(false, true) returns {year: 'numeric',month: 'numeric',day: 'numeric',hour: 'numeric',minute: 'numeric',hour12: true}
- */
-export const getDateTimeOptions = (withSeconds, is12h = false) => {
- return {
- year: 'numeric',
- month: 'numeric',
- day: 'numeric',
- ...getTimeOptions(withSeconds, is12h)
- };
-};
-
-export function getCurrentTimezone(tzone) {
- if (tzone) return tzone;
- return PCore?.getLocaleUtils?.().getTimeZoneInUse?.();
-}
-
-export function format(value, type, options) {
- let formattedValue;
-
- switch (type?.toLowerCase()) {
- case 'currency': {
- const defaultOptions = {
- locale: getLocale(),
- position: 'before',
- decPlaces: 2
- };
- const params = { ...defaultOptions, ...options };
- formattedValue = Currency.Currency(value, params);
- break;
- }
-
- case 'decimal': {
- const defaultOptions = { locale: getLocale(), decPlaces: 2 };
- const params = { ...defaultOptions, ...options };
- formattedValue = Currency.Decimal(value, params);
- break;
- }
-
- case 'integer': {
- const defaultOptions = { locale: getLocale() };
- const params = { ...defaultOptions, ...options };
- formattedValue = Currency.Integer(value, params);
- break;
- }
-
- case 'date': {
- const defaultOptions = {
- format: 'MMM DD, YYYY',
- timezone: getCurrentTimezone()
- };
- const params = { ...defaultOptions, ...options };
- formattedValue = DateFormatter.Date(parseDateInISO(value), params);
- break;
- }
-
- case 'datetime': {
- const defaultOptions = {
- format: 'MMM DD, YYYY h:mm A',
- timezone: getCurrentTimezone()
- };
- const params = { ...defaultOptions, ...options };
- formattedValue = DateFormatter.Date(parseDateInISO(value), params);
- break;
- }
-
- case 'boolean':
- case 'checkbox': {
- formattedValue = Boolean.TrueFalse(value, { allowEmpty: false });
- break;
- }
-
- default:
- formattedValue = value;
- }
- return formattedValue;
-}
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/demo.stories.jsx
deleted file mode 100644
index 3dbf1084..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/demo.stories.jsx
+++ /dev/null
@@ -1,73 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-import { configProps, stateProps } from './mock.stories';
-import PegaDxilMyDate from './index.jsx';
-
-export default {
- title: 'PegaDxilMyDate',
- decorators: [withKnobs],
- component: PegaDxilMyDate
-};
-
-if (!window.PCore) {
- window.PCore = {};
-}
-
-window.PCore.getEnvironmentInfo = () => {
- return {
- getLocale: () => {
- return 'en-GB';
- }
- };
-};
-
-export const basePegaDxilMyDate = () => {
- const props = {
- getPConnect: () => {
- return {
- getActionsApi: () => {
- return {
- updateFieldValue: () => {/* nothing */},
- triggerFieldChange: () => {/* nothing */}
- };
- },
- getValidationApi: () => {
- return {
- validate: () => {/* nothing */}
- };
- },
- getStateProps: () => {
- return stateProps;
- },
- getConfigProps: () => {
- return configProps;
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- clearErrorMessages: () => {/* nothing */}
- };
- },
- value: configProps.value,
- validatemessage: configProps.validatemessage,
- label: configProps.label,
- hideLabel: configProps.hideLabel,
- helperText: configProps.helperText,
- nextYearRange: configProps.nextYearRange,
- previousYearRange: configProps.previousYearRange,
- showWeekNumber: configProps.showWeekNumber,
- testId: configProps.testId,
- showAsFormattedText: configProps.showAsFormattedText,
- additionalProps: configProps.additionalProps,
- displayMode: configProps.displayMode,
- variant: configProps.variant,
- hasSuggestions: configProps.hasSuggestions,
- disabled: configProps.disabled,
- readOnly: configProps.readOnly,
- required: configProps.required
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/index.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/index.jsx
deleted file mode 100644
index de22f856..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/index.jsx
+++ /dev/null
@@ -1,256 +0,0 @@
-/* eslint-disable no-undef */
-import { useEffect, useState } from 'react';
-import { DateInput, FieldValueList, DateTimeDisplay, Text, } from '@pega/cosmos-react-core';
-import PropTypes from 'prop-types';
-import FormattedText from "./FormattedText.jsx";
-
-import StyledPegaDxilMyDateWrapper from './styles';
-
-// includes in bundle
-import {
- datetimedisplayformatter,
- formatExists,
- getFullYear,
- getMaxDate,
- getMinDate,
- datetimeFireChangeBlurEvents,
- getDateFormat
-} from "./date.js";
-import { suggestionsHandler } from './suggestions-handler';
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-const PegaDxilMyDate = props => {
- const {
- getPConnect,
- value,
- validatemessage,
- label,
- hideLabel,
- helperText,
- nextYearRange,
- previousYearRange,
- showWeekNumber,
- testId,
- showAsFormattedText,
- additionalProps,
- displayMode,
- variant,
- hasSuggestions
- } = props;
-
- let {formatter} = props;
- const pConn = getPConnect();
- const actions = pConn.getActionsApi();
- const propName = pConn?.getStateProps()?.value;
-
- let { readOnly, required, disabled } = props;
- [readOnly, required, disabled] = [readOnly, required, disabled].map(
- (prop) => prop === true || (typeof prop === "string" && prop === "true")
- );
-
- const [status, setStatus] = useState(hasSuggestions ? 'pending' : '');
-
- useEffect(() => {
- if (validatemessage !== '') {
- setStatus('error');
- }
- if (hasSuggestions) {
- setStatus('pending');
- } else if (!hasSuggestions && status !== 'success') {
- setStatus(validatemessage !== '' ? 'error' : undefined);
- }
- }, [validatemessage, hasSuggestions]);
-
- // calculate min and max range of calendar
- const currentYear = getFullYear();
- const yearFromValue = getFullYear(value);
- const maxDate = getMaxDate(
- parseInt(nextYearRange, 10),
- currentYear,
- yearFromValue
- );
- const minDate = getMinDate(
- parseInt(previousYearRange, 10),
- currentYear,
- yearFromValue
- );
-
- const onResolveSuggestionHandler = (accepted) => {
- suggestionsHandler(accepted, pConn, setStatus);
- };
-
-
-
- function handleBlur(onBlurValue) {
- const { valueAsISOString: date, state: errorState } = onBlurValue;
- const trimmedDate = date ? date.substring(0, date.indexOf('T')) : date;
- datetimeFireChangeBlurEvents(errorState, value, trimmedDate, actions, propName, pConn);
- const isValueChanged = !(value === undefined && trimmedDate === '') && value !== trimmedDate;
- if (hasSuggestions && isValueChanged) {
- pConn.ignoreSuggestion();
- }
- }
-
- function handleChange(onChangeValue) {
- const { valueAsISOString: date } = onChangeValue;
- const trimmedDate = date ? date.substring(0, date.indexOf('T')) : date;
- if (hasSuggestions && value !== trimmedDate) {
- setStatus(undefined);
- }
- pConn.clearErrorMessages({
- property: propName
- })
- }
-
- if (displayMode === 'LABELS_LEFT' || displayMode === 'STACKED_LARGE_VAL' || displayMode === 'DISPLAY_ONLY') {
- let variantValue = "date";
- let formatValue = "long";
- if(pConn && pConn.getConfigProps()){
- const runtimeformatter = pConn.getConfigProps()?.formatter;
- if(formatter !== runtimeformatter){
- formatter = runtimeformatter;
- }
- }
- if(formatter !== "" && formatExists(formatter)){
- const {variantVal,formatVal} = datetimedisplayformatter(formatter);
- variantValue = variantVal;
- formatValue = formatVal;
- }
- const displayComp = (
-
- );
- switch(displayMode){
- case 'DISPLAY_ONLY': {
- return ( displayComp );
- }
- case "LABELS_LEFT" : {
- return (
-
-
-
-
- );
- }
- case "STACKED_LARGE_VAL" : {
- return (
-
- {displayComp} }]}
- />
-
-
- );
- }
- // no default
- }
- }
-
-
- let dateComponent;
-
- if (readOnly && showAsFormattedText) {
- const environmentInfo = PCore.getEnvironmentInfo();
- const locale = environmentInfo && environmentInfo.getLocale();
- const textAdditionalProps = {
- format: getDateFormat(locale),
- fieldType: 'Date'
- };
- dateComponent = (
-
-
-
- );
- } else {
- dateComponent = (
-
-
-
- );
- }
- return dateComponent;
-}
-
-
-
-PegaDxilMyDate.defaultProps = {
- value: undefined,
- validatemessage: "",
- helperText: "",
- hideLabel: false,
- disabled: false,
- readOnly: false,
- required: false,
- showWeekNumber: false,
- nextYearRange: "",
- previousYearRange: "",
- testId: null,
- showAsFormattedText: false,
- additionalProps: {},
- displayMode: null,
- variant: "inline",
- formatter: "defaultDate",
- hasSuggestions: false
-};
-
-PegaDxilMyDate.propTypes = {
- value: PropTypes.string,
- label: PropTypes.string.isRequired,
- hideLabel: PropTypes.bool,
- getPConnect: PropTypes.func.isRequired,
- validatemessage: PropTypes.string,
- helperText: PropTypes.string,
- disabled: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- readOnly: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- required: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- showWeekNumber: PropTypes.bool,
- nextYearRange: PropTypes.string,
- previousYearRange: PropTypes.string,
- testId: PropTypes.string,
- showAsFormattedText: PropTypes.bool,
- additionalProps: PropTypes.objectOf(PropTypes.any),
- displayMode: PropTypes.string,
- variant: PropTypes.string,
- formatter: PropTypes.string,
- hasSuggestions: PropTypes.bool
-};
-
-export default PegaDxilMyDate;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/mock.stories.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/mock.stories.js
deleted file mode 100644
index 54c66ae7..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/mock.stories.js
+++ /dev/null
@@ -1,23 +0,0 @@
-export const configProps = {
- value: '2023-01-31T12:23:00.000Z',
- validatemessage: '',
- label: 'Date Label',
- hideLabel: false,
- helperText: 'Date helper text',
- nextYearRange: '10',
- previousYearRange: '10',
- showWeekNumber: true,
- testId: '12345678',
- showAsFormattedText: true,
- additionalProps: {},
- displayMode: '',
- variant: '',
- hasSuggestions: false,
- readOnly: false,
- required: false,
- disabled: false
-};
-
-export const stateProps = {
- value: '.DateLabel'
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/styles.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/suggestions-handler.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/suggestions-handler.js
deleted file mode 100644
index 901cd99e..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDate/suggestions-handler.js
+++ /dev/null
@@ -1,10 +0,0 @@
-/* eslint-disable import/prefer-default-export */
-export const suggestionsHandler = (accepted, pConn, setStatus) => {
- if (accepted) {
- pConn.acceptSuggestion();
- setStatus('success');
- } else {
- pConn.ignoreSuggestion();
- setStatus(undefined);
- }
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/date-time.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/date-time.js
deleted file mode 100644
index 7fb4d071..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/date-time.js
+++ /dev/null
@@ -1,92 +0,0 @@
-import dayjs from "dayjs";
-import relativeTime from 'dayjs/plugin/relativeTime.js';
-import localizedFormat from 'dayjs/plugin/localizedFormat.js';
-import utc from 'dayjs/plugin/utc.js';
-import timezone from 'dayjs/plugin/timezone.js';
-
-dayjs.extend(relativeTime);
-dayjs.extend(localizedFormat);
-dayjs.extend(utc);
-dayjs.extend(timezone);
-
-const types = ["fromNow", "customFormat"];
-
-// value should be in ISO 8601 format.
-function DateFormatter(
- value,
- { type = types[1], format = "DD/MM/YYYY", tzone, fieldType } = {}
-) {
- if (!value) return value;
- switch (type) {
- case types[1]:
- if (tzone && fieldType !== 'Date') return dayjs(value).tz(tzone).format(format); // Date only value should be formatted without timezone
- return dayjs(value).format(format);
- case types[0]:
- return dayjs(value).from(dayjs());
- default:
- return value;
- }
-}
-// value should be in hh:mm:ss format (00:00:00 - 23:59:59).
-function TimeFormatter(value, options) {
- if (!value) return value;
- const { locale = "en-US" } = options;
- const timeOnlyRegex = /^(?:[01]\d|2[0123]):(?:[012345]\d):(?:[012345]\d)$/;
- if (value.length === 8 && timeOnlyRegex.test(value)) {
- const { timeOptions = {} } = options;
- const tempDate = new Date();
- const hours = parseInt(value.substr(0, 2), 10);
- const minutes = parseInt(value.substr(3, 2), 10);
- const seconds = parseInt(value.substr(6, 2), 10);
- tempDate.setHours(hours);
- tempDate.setMinutes(minutes);
- tempDate.setSeconds(seconds);
- return tempDate.toLocaleTimeString(locale, timeOptions);
- }
- return DateFormatter(value, options);
-}
-
-export const DateTimeShortFormatter = (value, options) => {
- return DateFormatter(value, {
- ...options,
- type: "customFormat",
- format: "MMM DD, YYYY"
- });
-}
-
-export default {
- "DateTime-Long": (value, options) =>
- DateFormatter(value, { ...options, type: "customFormat", format: "LLL" }),
- "DateTime-Short": DateTimeShortFormatter,
- "DateTime-Since": (value) => DateFormatter(value, { type: "fromNow" }),
- "Time-Only": (value, options) =>
- TimeFormatter(value, {
- ...options,
- type: "customFormat",
- format: "hh:mm:ss A"
- }),
- convertToTimezone: (value, options) => {
- return value && options && options.timezone
- ? DateFormatter(value, {
- ...options,
- type: "customFormat",
- format: "YYYY-MM-DDTHH:mm:ss"
- })
- : value;
- },
- convertFromTimezone: (value, tzone) =>
- value && tzone
- ? dayjs.tz(value, tzone).utc().format("YYYY-MM-DDTHH:mm:ss[Z]")
- : value,
- Date: (value, options) =>
- DateFormatter(value, { type: "customFormat", ...options }),
- "Date-Default": DateTimeShortFormatter,
- "Date-Time-Default": (value, options) =>
- DateFormatter(value, { ...options, type: "customFormat", format: "lll" }),
- "Time-Default": (value, options) =>
- TimeFormatter(value, {
- ...options,
- type: "customFormat",
- format: "hh:mm A"
- })
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/date-utils.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/date-utils.js
deleted file mode 100644
index fad402d1..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/date-utils.js
+++ /dev/null
@@ -1,288 +0,0 @@
-/* eslint-disable no-undef */
-import dayjs from "dayjs";
-import relativeTime from 'dayjs/plugin/relativeTime.js';
-import localizedFormat from 'dayjs/plugin/localizedFormat.js';
-import utc from 'dayjs/plugin/utc.js';
-import timezone from 'dayjs/plugin/timezone.js';
-
-dayjs.extend(relativeTime);
-dayjs.extend(localizedFormat);
-dayjs.extend(utc);
-dayjs.extend(timezone);
-
-/**
- * Return relative time in fromNow for the given datetime
- * @description Convert and return the given datetime in dayJSObject
- *
- * @param {string} text datetime
- * @returns {object} datetime as a dayjs object
- */
-export const getDayJSObject = (text) => {
- const momObj = dayjs(text);
- if (momObj.isValid()) return momObj;
- const timeStamp = text;
- const isDateTime = timeStamp.indexOf("GMT") !== -1;
- const year = parseInt(timeStamp.substr(0, 4), 10);
- const month = parseInt(timeStamp.substr(4, 2), 10) - 1;
- const day = parseInt(timeStamp.substr(6, 2), 10);
-
- const CurrentTz = PCore.getLocaleUtils().getTimeZoneInUse();
-
- let mom = new Date();
-
- mom.setUTCDate(day);
- mom.setUTCMonth(month);
- mom.setUTCFullYear(year);
-
- /* istanbul ignore else */
- if (isDateTime) {
- const hours = parseInt(timeStamp.substr(9, 2), 10);
- const minutes = parseInt(timeStamp.substr(11, 2), 10);
- const seconds = parseInt(timeStamp.substr(13, 2), 10);
- const ms = parseInt(timeStamp.substr(16, 3), 10);
- mom.setUTCHours(hours);
- mom.setUTCMinutes(minutes);
- mom.setUTCSeconds(seconds);
- mom.setUTCMilliseconds(ms);
- }
-
- mom = dayjs(
- mom.toLocaleString("en-US", {
- timeZone: CurrentTz
- })
- );
-
- return mom;
-};
-
-/**
- * Return relative time in fromNow for the given datetime
- *
- * @param {string} time datetime
- * @returns {object} relative time from now
- */
-export const getRelativeTime = (time) => {
- let relativetime = "";
- if (dayjs(time).isUTC()) {
- relativetime = dayjs(time).fromNow();
- } else {
- const dayjstime = getDayJSObject(time);
- relativetime = dayjs(dayjstime).fromNow();
- }
- return relativetime;
-};
-
-/**
- * Return year for the date passed
- *
- * @param {string} value from which Year needs to be taken out
- * @returns {number} year for the date passed
- */
-export const getFullYear = (value) =>
- value ? new Date(value).getFullYear() : new Date().getFullYear();
-
-/**
- * Return maxDate for the date passed
- *
- * @param {number} nextYears next number of years
- * @param {number} currentYear current year
- * @param {number} yearFromValue year set on value in redux
- *
- * @returns {string} maxDate calculated based on inputs
- */
-export const getMaxDate = (nextYears, currentYear, yearFromValue) => {
- if (Number.isNaN(nextYears)) {
- nextYears = 20;
- }
- let maxYear = currentYear + nextYears;
- if (yearFromValue > maxYear) {
- maxYear = yearFromValue;
- }
- return `${maxYear}-01-01`;
-};
-
-/**
- * Return minDate for the date passed
- *
- * @param {number} previousYears previous number of years
- * @param {number} currentYear current year
- * @param {number} yearFromValue year set on value in redux
- *
- * @returns {string} minDate calculated based on inputs
- */
-export const getMinDate = (previousYears, currentYear, yearFromValue) => {
- if (Number.isNaN(previousYears)) {
- previousYears = 100;
- }
- let minYear = currentYear - previousYears;
- if (yearFromValue < minYear) {
- minYear = yearFromValue;
- }
- return `${minYear}-12-31`;
-};
-
-/**
- * Return clockFormat after parsing
- *
- * @param {number | string} clockFormat chosen by user
- *
- * @returns {number} clockFormat
- */
-export const parseClockFormat = (clockFormat) =>
- typeof clockFormat === "string" ? parseInt(clockFormat, 10) : clockFormat;
-
-/**
- * Return datetime value string off to seconds
- *
- * @param {string} datetime in ISO format
- * @param {boolean} withSeconds to specify if seconds is needed or not
- *
- * @returns {string} datetime after stripping of ms and seconds if selected to
- */
-export const correctDateTimeToSeconds = (datetime, withSeconds) => {
- if (withSeconds) {
- return `${datetime.substring(0, datetime.indexOf("Z"))}.000Z`;
- }
- return `${datetime.substring(0, datetime.lastIndexOf(":"))}:00.000Z`;
-};
-
-/**
- * Return time value string off to seconds
- *
- * @param {string} datetime in ISO format
- * @param {boolean} withSeconds to specify if seconds is needed or not
- *
- * @returns {string} just time after stripping of ms and seconds if selected to
- */
-export const timeCorrectedToSeconds = (datetime, withSeconds) => {
- if (withSeconds) {
- return datetime.substring(datetime.indexOf("T") + 1, datetime.indexOf("."));
- }
- return `${datetime.substring(
- datetime.indexOf("T") + 1,
- datetime.lastIndexOf(":")
- )}:00`;
-};
-
-/**
- * This function handles the cosmos blur handler of DateTime components
- *
- * @param {string | undefined} errorState for the selected datetime value
- * @param {string} actualValue present in redux
- * @param {string} formattedValue retrieved by trimming ISO to just Date/Time, also applying timezone if DateTime
- * @param {object} actions object which has fire and blur callbacks
- * @param {string} propName name of the property bound
- * @param {object} pConn component's PConnect object which is useful to invoke validationApi
- *
- * @returns {void}
- */
-export const datetimeFireChangeBlurEvents = (
- errorState,
- actualValue,
- formattedValue,
- actions,
- propName,
- pConn
-) => {
-
- // TODO - clean up, we should not rely on timestamp from cosmos to check InComplete validation
- // above triggerFieldChange should have validated this
- if (errorState) {
- pConn.getValidationApi().validate(errorState);
- }
- // BUG-640834 In errorState presist old values avoiding store update & re-render.
- else{
- if (formattedValue !== actualValue) {
- actions.updateFieldValue(propName, formattedValue);
- }
- actions.triggerFieldChange(propName, formattedValue);
- }
-};
-
-/**
- * Return Date format for the locale passed
- *
- * @param {string} locale locale string
- * @param {object} options options for format string
- * @returns {string} dateformat for the locale
- * Example : getDateFormat("pl-PL") returns "DD.MM.YYYY"
- */
-export const getDateFormat = (locale, options) => {
- return new Intl.DateTimeFormat(locale, options)
- .formatToParts()
- .map(({ type, value }) => {
- switch (type) {
- case "day":
- return "DD";
- case "month":
- return "MM";
- case "year":
- return "YYYY";
- case "hour":
- return "hh";
- case "minute":
- return "mm";
- case "second":
- return "ss";
- case "dayPeriod":
- return "A";
- case "literal":
- return value;
- default:
- return "";
- }
- })
- .join("");
-};
-
-/**
- * Return boolean for the locale passed to specify if locale uses 12 hour format
- *
- * @param {string} locale locale string
- * @returns {boolean} True or False for the locale
- * Example : getDateFormat("pl-PL") returns false
- */
-export const is12HClockFormat = (locale) => {
- const meridiem = new Intl.DateTimeFormat(locale, {
- hour: "numeric"
- })
- .formatToParts()
- .find(({ type }) => type === "dayPeriod");
- return !!(meridiem === null || meridiem === undefined
- ? undefined
- : meridiem.value);
-};
-
-/**
- * Return Option object for Time formatting
- *
- * @param {boolean} withSeconds true or false depending on seconds to be included
- * @param {boolean} is12h 12 hour format
- * @returns {object} options object time formatting
- * Example : getTimeOptions(false, true) returns {hour: 'numeric',minute: 'numeric',hour12: true}
- */
-export const getTimeOptions = (withSeconds, is12h = false) => {
- return {
- hour: "numeric",
- minute: "numeric",
- ...(withSeconds && { second: "numeric" }),
- hour12: is12h
- };
-};
-
-/**
- * Return Option object for Datetime formatting
- *
- * @param {boolean} withSeconds true or false depending on seconds to be included
- * @param {boolean} is12h 12 hour format
- * @returns {object} options object datetime formatting
- * Example : getDateTimeOptions(false, true) returns {year: 'numeric',month: 'numeric',day: 'numeric',hour: 'numeric',minute: 'numeric',hour12: true}
- */
-export const getDateTimeOptions = (withSeconds, is12h = false) => {
- return {
- year: "numeric",
- month: "numeric",
- day: "numeric",
- ...getTimeOptions(withSeconds, is12h)
- };
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/date.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/date.js
deleted file mode 100644
index 072a6a1e..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/date.js
+++ /dev/null
@@ -1,331 +0,0 @@
-/* eslint-disable no-undef */
-import dayjs from 'dayjs';
-import relativeTime from 'dayjs/plugin/relativeTime.js';
-import localizedFormat from 'dayjs/plugin/localizedFormat.js';
-import utc from 'dayjs/plugin/utc.js';
-import timezone from 'dayjs/plugin/timezone.js';
-
-dayjs.extend(relativeTime);
-dayjs.extend(localizedFormat);
-dayjs.extend(utc);
-dayjs.extend(timezone);
-
-export const datetimedisplayformatter = (formatter) => {
- const objectvalues = {};
- switch (formatter) {
- case "DateTime-Long": {
- objectvalues.variantVal = "datetime";
- objectvalues.formatVal = "long";
- break;
- }
- case "DateTime-Short": {
- objectvalues.variantVal = "date";
- objectvalues.formatVal = "short";
- break;
- }
- case "DateTime-Since": {
- objectvalues.variantVal = "relative";
- break;
- }
- case "Time-Only": {
- objectvalues.variantVal = "time";
- objectvalues.formatVal = "short";
- break;
- }
- // no default
- }
- return objectvalues;
-};
-
-export const formatExists = (formatterVal) => {
- const formatterValues = [
- "DateTime-Long",
- "DateTime-Short",
- "DateTime-Since",
- "Time-Only"
- ];
- let isformatter = false;
- if (formatterValues.includes(formatterVal)) {
- isformatter = true;
- }
- return isformatter;
-};
-
-
-
-/**
- * Return relative time in fromNow for the given datetime
- * @description Convert and return the given datetime in dayJSObject
- *
- * @param {string} text datetime
- * @returns {object} datetime as a dayjs object
- */
-export const getDayJSObject = (text) => {
- const momObj = dayjs(text);
- if (momObj.isValid()) return momObj;
- const timeStamp = text;
- const isDateTime = timeStamp.indexOf("GMT") !== -1;
- const year = parseInt(timeStamp.substr(0, 4), 10);
- const month = parseInt(timeStamp.substr(4, 2), 10) - 1;
- const day = parseInt(timeStamp.substr(6, 2), 10);
-
- const CurrentTz = PCore.getLocaleUtils().getTimeZoneInUse();
-
- let mom = new Date();
-
- mom.setUTCDate(day);
- mom.setUTCMonth(month);
- mom.setUTCFullYear(year);
-
- /* istanbul ignore else */
- if (isDateTime) {
- const hours = parseInt(timeStamp.substr(9, 2), 10);
- const minutes = parseInt(timeStamp.substr(11, 2), 10);
- const seconds = parseInt(timeStamp.substr(13, 2), 10);
- const ms = parseInt(timeStamp.substr(16, 3), 10);
- mom.setUTCHours(hours);
- mom.setUTCMinutes(minutes);
- mom.setUTCSeconds(seconds);
- mom.setUTCMilliseconds(ms);
- }
-
- mom = dayjs(
- mom.toLocaleString("en-US", {
- timeZone: CurrentTz
- })
- );
-
- return mom;
-};
-
-/**
- * Return relative time in fromNow for the given datetime
- *
- * @param {string} time datetime
- * @returns {object} relative time from now
- */
-export const getRelativeTime = (time) => {
- let relativetime = "";
- if (dayjs(time).isUTC()) {
- relativetime = dayjs(time).fromNow();
- } else {
- const dayjstime = getDayJSObject(time);
- relativetime = dayjs(dayjstime).fromNow();
- }
- return relativetime;
-};
-
-/**
- * Return year for the date passed
- *
- * @param {string} value from which Year needs to be taken out
- * @returns {number} year for the date passed
- */
-export const getFullYear = (value) =>
- value ? new Date(value).getFullYear() : new Date().getFullYear();
-
-/**
- * Return maxDate for the date passed
- *
- * @param {number} nextYears next number of years
- * @param {number} currentYear current year
- * @param {number} yearFromValue year set on value in redux
- *
- * @returns {string} maxDate calculated based on inputs
- */
-export const getMaxDate = (nextYears, currentYear, yearFromValue) => {
- if (Number.isNaN(nextYears)) {
- nextYears = 20;
- }
- let maxYear = currentYear + nextYears;
- if (yearFromValue > maxYear) {
- maxYear = yearFromValue;
- }
- return `${maxYear}-01-01`;
-};
-
-/**
- * Return minDate for the date passed
- *
- * @param {number} previousYears previous number of years
- * @param {number} currentYear current year
- * @param {number} yearFromValue year set on value in redux
- *
- * @returns {string} minDate calculated based on inputs
- */
-export const getMinDate = (previousYears, currentYear, yearFromValue) => {
- if (Number.isNaN(previousYears)) {
- previousYears = 100;
- }
- let minYear = currentYear - previousYears;
- if (yearFromValue < minYear) {
- minYear = yearFromValue;
- }
- return `${minYear}-12-31`;
-};
-
-/**
- * Return clockFormat after parsing
- *
- * @param {number | string} clockFormat chosen by user
- *
- * @returns {number} clockFormat
- */
-export const parseClockFormat = (clockFormat) =>
- typeof clockFormat === "string" ? parseInt(clockFormat, 10) : clockFormat;
-
-/**
- * Return datetime value string off to seconds
- *
- * @param {string} datetime in ISO format
- * @param {boolean} withSeconds to specify if seconds is needed or not
- *
- * @returns {string} datetime after stripping of ms and seconds if selected to
- */
-export const correctDateTimeToSeconds = (datetime, withSeconds) => {
- if (withSeconds) {
- return `${datetime.substring(0, datetime.indexOf("Z"))}.000Z`;
- }
- return `${datetime.substring(0, datetime.lastIndexOf(":"))}:00.000Z`;
-};
-
-/**
- * Return time value string off to seconds
- *
- * @param {string} datetime in ISO format
- * @param {boolean} withSeconds to specify if seconds is needed or not
- *
- * @returns {string} just time after stripping of ms and seconds if selected to
- */
-export const timeCorrectedToSeconds = (datetime, withSeconds) => {
- if (withSeconds) {
- return datetime.substring(datetime.indexOf("T") + 1, datetime.indexOf("."));
- }
- return `${datetime.substring(
- datetime.indexOf("T") + 1,
- datetime.lastIndexOf(":")
- )}:00`;
-};
-
-/**
- * This function handles the cosmos blur handler of DateTime components
- *
- * @param {string | undefined} errorState for the selected datetime value
- * @param {string} actualValue present in redux
- * @param {string} formattedValue retrieved by trimming ISO to just Date/Time, also applying timezone if DateTime
- * @param {object} actions object which has fire and blur callbacks
- * @param {string} propName name of the property bound
- * @param {object} pConn component's PConnect object which is useful to invoke validationApi
- *
- * @returns {void}
- */
-export const datetimeFireChangeBlurEvents = (
- errorState,
- actualValue,
- formattedValue,
- actions,
- propName,
- pConn
-) => {
-
- // TODO - clean up, we should not rely on timestamp from cosmos to check InComplete validation
- // above triggerFieldChange should have validated this
- if (errorState) {
- pConn.getValidationApi().validate(errorState);
- }
- // BUG-640834 In errorState presist old values avoiding store update & re-render.
- else{
- if (formattedValue !== actualValue) {
- actions.updateFieldValue(propName, formattedValue);
- }
- actions.triggerFieldChange(propName, formattedValue);
- }
-};
-
-/**
- * Return Date format for the locale passed
- *
- * @param {string} locale locale string
- * @param {object} options options for format string
- * @returns {string} dateformat for the locale
- * Example : getDateFormat("pl-PL") returns "DD.MM.YYYY"
- */
-export const getDateFormat = (locale, options) => {
- return new Intl.DateTimeFormat(locale, options)
- .formatToParts()
- .map(({ type, value }) => {
- switch (type) {
- case "day":
- return "DD";
- case "month":
- return "MM";
- case "year":
- return "YYYY";
- case "hour":
- return "hh";
- case "minute":
- return "mm";
- case "second":
- return "ss";
- case "dayPeriod":
- return "A";
- case "literal":
- return value;
- default:
- return "";
- }
- })
- .join("");
-};
-
-/**
- * Return boolean for the locale passed to specify if locale uses 12 hour format
- *
- * @param {string} locale locale string
- * @returns {boolean} True or False for the locale
- * Example : getDateFormat("pl-PL") returns false
- */
-export const is12HClockFormat = (locale) => {
- const meridiem = new Intl.DateTimeFormat(locale, {
- hour: "numeric"
- })
- .formatToParts()
- .find(({ type }) => type === "dayPeriod");
- return !!(meridiem === null || meridiem === undefined
- ? undefined
- : meridiem.value);
-};
-
-/**
- * Return Option object for Time formatting
- *
- * @param {boolean} withSeconds true or false depending on seconds to be included
- * @param {boolean} is12h 12 hour format
- * @returns {object} options object time formatting
- * Example : getTimeOptions(false, true) returns {hour: 'numeric',minute: 'numeric',hour12: true}
- */
-export const getTimeOptions = (withSeconds, is12h = false) => {
- return {
- hour: "numeric",
- minute: "numeric",
- ...(withSeconds && { second: "numeric" }),
- hour12: is12h
- };
-};
-
-/**
- * Return Option object for Datetime formatting
- *
- * @param {boolean} withSeconds true or false depending on seconds to be included
- * @param {boolean} is12h 12 hour format
- * @returns {object} options object datetime formatting
- * Example : getDateTimeOptions(false, true) returns {year: 'numeric',month: 'numeric',day: 'numeric',hour: 'numeric',minute: 'numeric',hour12: true}
- */
-export const getDateTimeOptions = (withSeconds, is12h = false) => {
- return {
- year: "numeric",
- month: "numeric",
- day: "numeric",
- ...getTimeOptions(withSeconds, is12h)
- };
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/demo.stories.jsx
deleted file mode 100644
index 33477e19..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/demo.stories.jsx
+++ /dev/null
@@ -1,73 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-import { configProps, stateProps } from './mock.stories';
-import PegaDxilMyDateTime from './index.jsx';
-
-export default {
- title: 'PegaDxilMyDateTime',
- decorators: [withKnobs],
- component: PegaDxilMyDateTime
-};
-
-if (!window.PCore) {
- window.PCore = {};
-}
-
-window.PCore.getEnvironmentInfo = () => {
- return {
- getTimeZone: () => {
- return '';
- }
- };
-};
-
-export const basePegaDxilMyDateTime = () => {
- const props = {
- getPConnect: () => {
- return {
- getActionsApi: () => {
- return {
- updateFieldValue: () => {/* nothing */},
- triggerFieldChange: () => {/* nothing */}
- };
- },
- getValidationApi: () => {
- return {
- validate: () => {/* nothing */}
- };
- },
- getStateProps: () => {
- return stateProps;
- },
- getConfigProps: () => {
- return configProps;
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- clearErrorMessages: () => {/* nothing */}
- };
- },
- value: configProps.value,
- validatemessage: configProps.validatemessage,
- label: configProps.label,
- hideLabel: configProps.hideLabel,
- helperText: configProps.helperText,
- withSeconds: configProps.withSeconds,
- nextYearRange: configProps.nextYearRange,
- previousYearRange: configProps.previousYearRange,
- showWeekNumber: configProps.showWeekNumber,
- testId: configProps.testId,
- additionalProps: configProps.additionalProps,
- displayMode: configProps.displayMode,
- variant: configProps.variant,
- hasSuggestions: configProps.hasSuggestions,
- disabled: configProps.disabled,
- readOnly: configProps.readOnly,
- required: configProps.required
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/index.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/index.jsx
deleted file mode 100644
index 64510b9c..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/index.jsx
+++ /dev/null
@@ -1,254 +0,0 @@
-/* eslint-disable no-undef */
-import { useEffect, useState } from 'react';
-import { DateTimeInput, FieldValueList, DateTimeDisplay, Text } from "@pega/cosmos-react-core";
-import PropTypes from "prop-types";
-
-// includes in bundle
-import DateTimeFormatter from "./date-time";
-import {datetimedisplayformatter,formatExists} from "./date";
-import {
- getFullYear,
- getMaxDate,
- getMinDate,
- parseClockFormat,
- correctDateTimeToSeconds,
- datetimeFireChangeBlurEvents
-} from "./date-utils";
-import { suggestionsHandler } from './suggestions-handler';
-
-
-import StyledPegaDxilMyDateTimeWrapper from './styles';
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-const PegaDxilMyDateTime = props => {
- const {
- getPConnect,
- value,
- validatemessage,
- label,
- hideLabel,
- helperText,
- withSeconds,
- nextYearRange,
- previousYearRange,
- showWeekNumber,
- pickerInterval,
- testId,
- additionalProps,
- displayMode,
- variant,
- hasSuggestions
- } = props;
- let { formatter } = props;
- const pConn = getPConnect();
- const actions = pConn.getActionsApi();
- const propName = pConn.getStateProps().value;
-
- const environmentInfo = PCore.getEnvironmentInfo();
- const timezone = environmentInfo && environmentInfo.getTimeZone();
-
- let { readOnly, required, disabled } = props;
- [readOnly, required, disabled] = [readOnly, required, disabled].map(
- (prop) => prop === true || (typeof prop === 'string' && prop === 'true')
- );
-
- const [status, setStatus] = useState(hasSuggestions ? 'pending' : '');
-
- useEffect(() => {
- if (validatemessage !== '') {
- setStatus('error');
- }
- if (hasSuggestions) {
- setStatus('pending');
- } else if (!hasSuggestions && status !== 'success') {
- setStatus(validatemessage !== '' ? 'error' : undefined);
- }
- }, [validatemessage, hasSuggestions]);
-
- let { clockFormat } = props;
- clockFormat = parseClockFormat(clockFormat);
-
- // calculate min and max range of calendar
- const currentYear = getFullYear();
- const yearFromValue = getFullYear(value);
- const maxDate = getMaxDate(parseInt(nextYearRange, 10), currentYear, yearFromValue);
- const minDate = getMinDate(parseInt(previousYearRange, 10), currentYear, yearFromValue);
-
- const onResolveSuggestionHandler = (accepted) => {
- suggestionsHandler(accepted, pConn, setStatus);
- };
-
- function handleBlur(onBlurValue) {
- const { valueAsISOString: datetimeTZ, state: errorState } = onBlurValue;
- const datetimeGMT = DateTimeFormatter.convertFromTimezone(datetimeTZ, timezone);
-
- const datetimeGMTCorrectedToSeconds = datetimeGMT
- ? correctDateTimeToSeconds(datetimeGMT, withSeconds)
- : datetimeGMT;
-
- datetimeFireChangeBlurEvents(errorState, value, datetimeGMTCorrectedToSeconds, actions, propName, pConn);
- const isValueChanged =
- !(value === undefined && datetimeGMTCorrectedToSeconds === '') && value !== datetimeGMTCorrectedToSeconds;
- if (hasSuggestions && isValueChanged) {
- pConn.ignoreSuggestion();
- }
- }
-
- function handleChange(onChangeValue) {
- const { valueAsISOString: datetimeTZ } = onChangeValue;
- const datetimeGMT = DateTimeFormatter.convertFromTimezone(datetimeTZ, timezone);
- const datetimeGMTCorrectedToSeconds = datetimeGMT
- ? correctDateTimeToSeconds(datetimeGMT, withSeconds)
- : datetimeGMT;
- if (hasSuggestions && value !== datetimeGMTCorrectedToSeconds) {
- setStatus(undefined);
- }
- pConn.clearErrorMessages({
- property: propName
- });
- }
-
- if (displayMode === 'LABELS_LEFT' || displayMode === 'STACKED_LARGE_VAL' || displayMode === 'DISPLAY_ONLY') {
- let variantValue = 'datetime';
- let formatValue = withSeconds ? 'long' : 'short';
- const runtimeformatter = pConn.getConfigProps()?.formatter;
- if (formatter !== runtimeformatter) {
- formatter = runtimeformatter;
- }
- if (formatExists(formatter)) {
- const { variantVal, formatVal } = datetimedisplayformatter(formatter);
- variantValue = variantVal;
- formatValue = withSeconds && formatter === 'Time-Only' ? 'long' : formatVal;
- }
- const displayComp = (
-
- );
- switch (displayMode) {
- case 'DISPLAY_ONLY': {
- return ( displayComp );
- }
- case 'LABELS_LEFT': {
- return (
-
-
-
- );
- }
- case 'STACKED_LARGE_VAL': {
- return (
-
-
- {displayComp}
-
- )
- }
- ]}
- />
-
- );
- }
- // no default
- }
- }
-
-
- return (
-
-
-
- );
-}
-
-
-
-PegaDxilMyDateTime.defaultProps = {
- value: undefined,
- withSeconds: false,
- validatemessage: "",
- helperText: "",
- hideLabel: false,
- disabled: false,
- readOnly: false,
- required: false,
- pickerInterval: "30",
- clockFormat: 0,
- showWeekNumber: false,
- nextYearRange: "",
- previousYearRange: "",
- testId: null,
- additionalProps: {},
- displayMode: null,
- variant: "inline",
- Format: "defaultDateTime",
- hasSuggestions: false
-};
-
-PegaDxilMyDateTime.propTypes = {
- value: PropTypes.string,
- label: PropTypes.string.isRequired,
- hideLabel: PropTypes.bool,
- withSeconds: PropTypes.bool,
- getPConnect: PropTypes.func.isRequired,
- validatemessage: PropTypes.string,
- helperText: PropTypes.string,
- disabled: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- readOnly: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- required: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- pickerInterval: PropTypes.string,
- clockFormat: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
- showWeekNumber: PropTypes.bool,
- nextYearRange: PropTypes.string,
- previousYearRange: PropTypes.string,
- testId: PropTypes.string,
- additionalProps: PropTypes.objectOf(PropTypes.any),
- displayMode: PropTypes.string,
- variant: PropTypes.string,
- formatter: PropTypes.string,
- Format: PropTypes.string,
- hasSuggestions: PropTypes.bool
-};
-
-export default PegaDxilMyDateTime;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/mock.stories.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/mock.stories.js
deleted file mode 100644
index 45eb3e8c..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/mock.stories.js
+++ /dev/null
@@ -1,23 +0,0 @@
-export const configProps = {
- value: '2023-01-24T16:45:00.000Z',
- validatemessage: '',
- label: 'DateTime Label',
- hideLabel: false,
- helperText: 'DateTime helper text',
- withSeconds: false,
- nextYearRange: '10',
- previousYearRange: '5',
- showWeekNumber: false,
- testId: '12345678',
- additionalProps: {},
- displayMode: '',
- variant: '',
- hasSuggestions: false,
- readOnly: false,
- required: false,
- disabled: false
-};
-
-export const stateProps = {
- value: '.DateTimeLabel'
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/styles.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/suggestions-handler.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/suggestions-handler.js
deleted file mode 100644
index 901cd99e..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDateTime/suggestions-handler.js
+++ /dev/null
@@ -1,10 +0,0 @@
-/* eslint-disable import/prefer-default-export */
-export const suggestionsHandler = (accepted, pConn, setStatus) => {
- if (accepted) {
- pConn.acceptSuggestion();
- setStatus('success');
- } else {
- pConn.ignoreSuggestion();
- setStatus(undefined);
- }
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDecimal/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDecimal/demo.stories.jsx
deleted file mode 100644
index a9eb10fa..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDecimal/demo.stories.jsx
+++ /dev/null
@@ -1,49 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-
-import { configProps, fieldMetadata, stateProps } from './mock.stories.js';
-
-import PegaDxilMyDecimal from './index.jsx';
-
-export default {
- title: 'PegaDxilMyDecimal',
- decorators: [withKnobs],
- component: PegaDxilMyDecimal
-};
-
-export const basePegaDxilMyDecimal = () => {
-
- const props = {
- value: configProps.value,
- placeholder: configProps.placeholder,
- label: configProps.label,
- helperText: configProps.helperText,
- showGroupSeparators: configProps.showGroupSeparators,
- hasSuggestions: configProps.hasSuggestions,
- testId: configProps.testId,
- fieldMetadata,
-
- getPConnect: () => {
- return {
- getStateProps: () => {
- return stateProps;
- },
- getActionsApi: () => {
- return {
- updateFieldValue: () => {/* nothing */},
- triggerFieldChange: () => {/* nothing */}
- };
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- setInheritedProps: () => {/* nothing */},
- resolveConfigProps: () => {/* nothing */}
- };
- }
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDecimal/event-utils.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDecimal/event-utils.js
deleted file mode 100644
index 8b806f56..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDecimal/event-utils.js
+++ /dev/null
@@ -1,18 +0,0 @@
-const handleEvent = (actions, eventType, propName, value) => {
- switch (eventType) {
- case "change":
- actions.updateFieldValue(propName, value);
- break;
- case "blur":
- actions.triggerFieldChange(propName, value);
- break;
- case "changeNblur":
- actions.updateFieldValue(propName, value);
- actions.triggerFieldChange(propName, value);
- break;
- default:
- break;
- }
-};
-
-export default handleEvent;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDecimal/index.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDecimal/index.jsx
deleted file mode 100644
index 3e0fc7a8..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDecimal/index.jsx
+++ /dev/null
@@ -1,270 +0,0 @@
-import { useState, useEffect, useRef } from 'react';
-import { NumberInput, NumberDisplay, CurrencyDisplay, FieldValueList, Text } from '@pega/cosmos-react-core';
-import PropTypes from 'prop-types';
-
-// includes in bundle
-import StyledPegaDxilMyDecimalWrapper from './styles';
-import handleEvent from "./event-utils";
-import { suggestionsHandler } from './suggestions-handler';
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-const PegaDxilMyDecimal = props => {
- const {
- getPConnect,
- value,
- placeholder,
- validatemessage,
- label,
- hideLabel,
- helperText,
- testId,
- displayMode,
- additionalProps,
- variant,
- formatter,
- negative,
- notation,
- currencyISOCode,
- isTableFormatter,
- hasSuggestions
- } = props;
- let { showGroupSeparators } = props;
- let { currencyDisplay } = props;
- const pConn = getPConnect();
- const actions = pConn.getActionsApi();
- const propName = pConn.getStateProps().value;
- const [decimalValue, setDecimalValue] = useState(value?.toString());
- const hasValueChange = useRef(false);
-
- let { readOnly, required, disabled } = props;
- [readOnly, required, disabled] = [readOnly, required, disabled].map(
- (prop) => prop === true || (typeof prop === 'string' && prop === 'true')
- );
-
- const [status, setStatus] = useState(hasSuggestions ? 'pending' : undefined);
-
- useEffect(() => {
- if (validatemessage !== '') {
- setStatus('error');
- }
- if (hasSuggestions) {
- setStatus('pending');
- } else if (!hasSuggestions && status !== 'success') {
- setStatus(validatemessage !== '' ? 'error' : undefined);
- }
- }, [validatemessage, hasSuggestions]);
-
- const { decimalPrecision, currencyDecimalPrecision } = props;
- let numberOfDecimals = parseInt(decimalPrecision, 10);
- if (Number.isNaN(numberOfDecimals)) {
- numberOfDecimals = decimalPrecision === '' ? undefined : 2;
- }
- let noOfFractionDigits = currencyDecimalPrecision === 'auto' ? undefined : parseInt(currencyDecimalPrecision, 10);
-
- useEffect(() => {
- setDecimalValue(value?.toString());
- }, [value]);
-
- let unit;
-
- if (['DISPLAY_ONLY', 'LABELS_LEFT', 'STACKED_LARGE_VAL'].includes(displayMode)) {
- if (displayMode !== 'STACKED_LARGE_VAL' && isTableFormatter) {
- showGroupSeparators = true;
- noOfFractionDigits = undefined;
- if (formatter === 'Currency-Code') {
- currencyDisplay = 'code';
- }
- }
-
- switch (formatter) {
- case 'Integer': {
- numberOfDecimals = 0;
- break;
- }
- case 'Percentage': {
- showGroupSeparators = false;
- unit = 'percent';
- break;
- }
- case 'Decimal-Auto': {
- numberOfDecimals = Number.isInteger(decimalValue) ? 0 : 2;
- break;
- }
- default: {
- break;
- }
- }
-
-
-
- const displayComp =
- formatter === 'Currency' || formatter === 'Currency-Code' ? (
-
- ) : (
-
- );
-
-
- switch (displayMode) {
- case 'DISPLAY_ONLY': {
- return ( displayComp );
- }
- case 'LABELS_LEFT': {
- return (
-
-
-
- );
- }
- case 'STACKED_LARGE_VAL': {
- return (
-
-
- {displayComp}
-
- )
- }
- ]}
- />
-
- );
- }
- // no default
- }
- }
-
- const onResolveSuggestionHandler = (accepted) => {
- suggestionsHandler(accepted, pConn, setStatus);
- };
-
- return (
-
- {
- if (hasSuggestions) {
- setStatus(undefined);
- }
- setDecimalValue(enteredValue);
- if (value !== (enteredValue !== '' ? Number(enteredValue) : '')) {
- handleEvent(actions, 'change', propName, enteredValue !== '' ? Number(enteredValue) : '');
- hasValueChange.current = true;
- }
- }}
- onBlur={() => {
- if (!value || hasValueChange.current) {
- handleEvent(actions, 'blur', propName, decimalValue !== '' ? Number(decimalValue) : '');
- if (hasSuggestions) {
- pConn.ignoreSuggestion();
- }
- hasValueChange.current = false;
- }
- }}
- onResolveSuggestion={onResolveSuggestionHandler}
- />
-
- );
-}
-
-
-PegaDxilMyDecimal.defaultProps = {
- value: '',
- placeholder: '',
- validatemessage: '',
- helperText: '',
- hideLabel: false,
- disabled: false,
- readOnly: false,
- required: false,
- testId: null,
- decimalPrecision: '',
- showGroupSeparators: false,
- displayMode: null,
- additionalProps: {},
- variant: 'inline',
- currencyISOCode: 'USD',
- formatter: 'defaultDecimal',
- isoCodeSelection: 'constant',
- negative: 'minus-sign',
- notation: 'standard',
- currencyDisplay: 'symbol',
- currencyDecimalPrecision: 'auto',
- isTableFormatter: false,
- hasSuggestions: false
-};
-
-PegaDxilMyDecimal.propTypes = {
- value: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
- placeholder: PropTypes.string,
- label: PropTypes.string.isRequired,
- hideLabel: PropTypes.bool,
- getPConnect: PropTypes.func.isRequired,
- validatemessage: PropTypes.string,
- helperText: PropTypes.string,
- disabled: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- readOnly: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- required: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- testId: PropTypes.string,
- decimalPrecision: PropTypes.string,
- showGroupSeparators: PropTypes.bool,
- displayMode: PropTypes.string,
- additionalProps: PropTypes.objectOf(PropTypes.any),
- variant: PropTypes.string,
- currencyISOCode: PropTypes.string,
- formatter: PropTypes.string,
- isoCodeSelection: PropTypes.string,
- negative: PropTypes.string,
- notation: PropTypes.string,
- currencyDisplay: PropTypes.string,
- currencyDecimalPrecision: PropTypes.string,
- isTableFormatter: PropTypes.bool,
- hasSuggestions: PropTypes.bool
-};
-
-export default PegaDxilMyDecimal;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDecimal/mock.stories.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDecimal/mock.stories.js
deleted file mode 100644
index 39ac58c2..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDecimal/mock.stories.js
+++ /dev/null
@@ -1,21 +0,0 @@
-export const configProps = {
- value: '',
- label: 'Decimal Sample',
- showGroupSeparators: true,
- placeholder: 'Decimal Placeholder',
- helperText: 'Decimal Helper Text',
- testId: 'decimal-12345678',
- hasSuggestions: false
-};
-
-export const stateProps = {
- value: '.DecimalSample',
- hasSuggestions: false
-};
-
-export const fieldMetadata = {
- classID: 'DIXL-MediaCo-Work-NewService',
- type: 'Decimal',
- displayAs: 'pxNumber',
- label: 'Decimal sample'
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDecimal/styles.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDecimal/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDecimal/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDecimal/suggestions-handler.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDecimal/suggestions-handler.js
deleted file mode 100644
index 901cd99e..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyDecimal/suggestions-handler.js
+++ /dev/null
@@ -1,10 +0,0 @@
-/* eslint-disable import/prefer-default-export */
-export const suggestionsHandler = (accepted, pConn, setStatus) => {
- if (accepted) {
- pConn.acceptSuggestion();
- setStatus('success');
- } else {
- pConn.ignoreSuggestion();
- setStatus(undefined);
- }
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyEmail/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyEmail/demo.stories.jsx
deleted file mode 100644
index e7a9917d..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyEmail/demo.stories.jsx
+++ /dev/null
@@ -1,48 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-
-import PegaDxilMyEmail from './index.jsx';
-
-import { stateProps, configProps, fieldMetadata } from './mock.stories';
-
-export default {
- title: 'PegaDxilMyEmail',
- decorators: [withKnobs],
- component: PegaDxilMyEmail
-};
-
-export const basePegaDxilMyEmail = () => {
-
- const props = {
- value: configProps.value,
- label: configProps.label,
- placeholder: configProps.placeholder,
- helperText: configProps.helperText,
- testId: configProps.testId,
- hasSuggestions: configProps.hasSuggestions,
- fieldMetadata,
-
- getPConnect: () => {
- return {
- getStateProps: () => {
- return stateProps;
- },
- getActionsApi: () => {
- return {
- updateFieldValue: () => {/* nothing */},
- triggerFieldChange: () => {/* nothing */}
- };
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- setInheritedProps: () => {/* nothing */},
- resolveConfigProps: () => {/* nothing */}
- };
- }
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyEmail/event-utils.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyEmail/event-utils.js
deleted file mode 100644
index 8b806f56..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyEmail/event-utils.js
+++ /dev/null
@@ -1,18 +0,0 @@
-const handleEvent = (actions, eventType, propName, value) => {
- switch (eventType) {
- case "change":
- actions.updateFieldValue(propName, value);
- break;
- case "blur":
- actions.triggerFieldChange(propName, value);
- break;
- case "changeNblur":
- actions.updateFieldValue(propName, value);
- actions.triggerFieldChange(propName, value);
- break;
- default:
- break;
- }
-};
-
-export default handleEvent;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyEmail/index.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyEmail/index.jsx
deleted file mode 100644
index adc7dc4c..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyEmail/index.jsx
+++ /dev/null
@@ -1,231 +0,0 @@
-import { useState, useEffect, useRef } from 'react';
-import { Input, EmailDisplay, FieldValueList, Text, URLDisplay, PhoneDisplay } from '@pega/cosmos-react-core';
-import PropTypes from 'prop-types';
-
-// includes in bundle
-import { suggestionsHandler } from './suggestions-handler';
-import handleEvent from "./event-utils";
-
-import StyledPegaDxilMyEmailWrapper from './styles';
-
-export const formatExists = (formatterVal) => {
- const formatterValues = [
- "TextInput",
- "WorkStatus",
- "RichText",
- "Email",
- "Phone",
- "URL",
- "Operator"
- ];
- let isformatter = false;
- if (formatterValues.includes(formatterVal)) {
- isformatter = true;
- }
- return isformatter;
- };
-
-
-export const textFormatter = (formatter,value) => {
- let displayComponent = null;
- switch(formatter){
- case "TextInput" : {
- displayComponent = value;
- break;
- }
- case "Email" : {
- displayComponent = ( );
- break;
- }
- case "Phone" : {
- displayComponent = ( );
- break;
- }
- case "URL" : {
- displayComponent = ( );
- break;
- }
- // no default
- }
- return displayComponent;
-};
-
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-const PegaDxilMyEmail = props => {
- const {
- getPConnect,
- value,
- placeholder,
- validatemessage,
- label,
- hideLabel,
- helperText,
- testId,
- displayMode,
- additionalProps,
- variant,
- isTableFormatter,
- hasSuggestions
- } = props;
- const { formatter } = props;
- const pConn = getPConnect();
- const actions = pConn.getActionsApi();
- const propName = pConn.getStateProps().value;
- const hasValueChange = useRef(false);
-
-
- let { readOnly, required, disabled } = props;
- [readOnly, required, disabled] = [readOnly, required, disabled].map(
- (prop) => prop === true || (typeof prop === 'string' && prop === 'true')
- );
- const [inputValue, setInputValue] = useState(value);
- useEffect(() => setInputValue(value), [value]);
-
- const [status, setStatus] = useState(hasSuggestions ? 'pending' : undefined);
-
- useEffect(() => {
- if (validatemessage !== '') {
- setStatus('error');
- }
- if (hasSuggestions) {
- setStatus('pending');
- } else if (!hasSuggestions && status !== 'success') {
- setStatus(validatemessage !== '' ? 'error' : undefined);
- }
- }, [validatemessage, hasSuggestions]);
-
- let displayComp = null;
- if (displayMode) {
- displayComp = ;
- }
-
- if (displayMode === 'LABELS_LEFT' || displayMode === 'DISPLAY_ONLY') {
- if (isTableFormatter && formatExists(formatter)) {
- displayComp = textFormatter(formatter, value);
- }
- return displayMode === 'DISPLAY_ONLY' ? (
-
- displayComp
-
- ) : (
-
-
-
- );
- }
-
- if (displayMode === 'STACKED_LARGE_VAL') {
- return (
-
-
- {displayComp}
-
- )
- }
- ]}
- />
-
- );
- }
-
- const onResolveSuggestionHandler = (accepted) => {
- suggestionsHandler(accepted, pConn, setStatus);
- };
-
- return (
-
- {
- if (hasSuggestions) {
- setStatus(undefined);
- }
- setInputValue(event.target.value);
- if (value !== event.target.value) {
- handleEvent(actions, 'change', propName, event.target.value);
- hasValueChange.current = true;
- }
- }}
- onBlur={(event) => {
- if (!value || hasValueChange.current) {
- handleEvent(actions, 'blur', propName, event.target.value);
- if (hasSuggestions) {
- pConn.ignoreSuggestion();
- }
- hasValueChange.current = false;
- }
- }}
- onFocus={actions.onFocus}
- onResolveSuggestion={onResolveSuggestionHandler}
- />
-
- );
-}
-
-PegaDxilMyEmail.defaultProps = {
- value: '',
- placeholder: '',
- validatemessage: '',
- helperText: '',
- hideLabel: false,
- disabled: false,
- readOnly: false,
- required: false,
- testId: null,
- displayMode: null,
- additionalProps: {},
- variant: 'inline',
- formatter: '',
- isTableFormatter: false,
- hasSuggestions: false
-};
-
-PegaDxilMyEmail.propTypes = {
- value: PropTypes.string,
- placeholder: PropTypes.string,
- label: PropTypes.string.isRequired,
- hideLabel: PropTypes.bool,
- getPConnect: PropTypes.func.isRequired,
- validatemessage: PropTypes.string,
- helperText: PropTypes.string,
- disabled: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- readOnly: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- required: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- testId: PropTypes.string,
- displayMode: PropTypes.string,
- additionalProps: PropTypes.objectOf(PropTypes.any),
- variant: PropTypes.string,
- formatter: PropTypes.string,
- isTableFormatter: PropTypes.bool,
- hasSuggestions: PropTypes.bool
-};
-
-export default PegaDxilMyEmail;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyEmail/mock.stories.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyEmail/mock.stories.js
deleted file mode 100644
index d4dee12d..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyEmail/mock.stories.js
+++ /dev/null
@@ -1,22 +0,0 @@
-export const configProps = {
- value: '',
- label: 'Email Sample',
- placeholder: 'Email Placeholder',
- helperText: 'Email Helper Text',
- testId: 'email-12345678',
- hasSuggestions: false
-};
-
-export const stateProps = {
- value: '.EmailSample',
- hasSuggestions: false
-};
-
-export const fieldMetadata = {
- classID: 'DIXL-MediaCo-Work-NewService',
- type: 'Text',
- maxLength: 256,
- displayAs: 'pxEmail',
- label: 'Email sample',
- validateAs: 'ValidEmailAddress'
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyEmail/styles.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyEmail/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyEmail/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyEmail/suggestions-handler.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyEmail/suggestions-handler.js
deleted file mode 100644
index 901cd99e..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyEmail/suggestions-handler.js
+++ /dev/null
@@ -1,10 +0,0 @@
-/* eslint-disable import/prefer-default-export */
-export const suggestionsHandler = (accepted, pConn, setStatus) => {
- if (accepted) {
- pConn.acceptSuggestion();
- setStatus('success');
- } else {
- pConn.ignoreSuggestion();
- setStatus(undefined);
- }
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyInteger/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyInteger/demo.stories.jsx
deleted file mode 100644
index 1f4cca82..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyInteger/demo.stories.jsx
+++ /dev/null
@@ -1,49 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-
-import { stateProps, configProps, fieldMetadata } from './mock.stories';
-
-import PegaDxilMyInteger from './index.jsx';
-
-export default {
- title: 'PegaDxilMyInteger',
- decorators: [withKnobs],
- component: PegaDxilMyInteger
-};
-
-export const basePegaDxilMyInteger = () => {
-
- const props = {
- value: configProps.value,
- placeholder: configProps.placeholder,
- label: configProps.label,
- helperText: configProps.helperText,
- showGroupSeparators: configProps.showGroupSeparators,
- hasSuggestions: configProps.hasSuggestions,
- testId: configProps.testId,
- fieldMetadata,
-
- getPConnect: () => {
- return {
- getStateProps: () => {
- return stateProps;
- },
- getActionsApi: () => {
- return {
- updateFieldValue: () => {/* nothing */},
- triggerFieldChange: () => {/* nothing */}
- };
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- setInheritedProps: () => {/* nothing */},
- resolveConfigProps: () => {/* nothing */}
- };
- }
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyInteger/event-utils.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyInteger/event-utils.js
deleted file mode 100644
index 8b806f56..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyInteger/event-utils.js
+++ /dev/null
@@ -1,18 +0,0 @@
-const handleEvent = (actions, eventType, propName, value) => {
- switch (eventType) {
- case "change":
- actions.updateFieldValue(propName, value);
- break;
- case "blur":
- actions.triggerFieldChange(propName, value);
- break;
- case "changeNblur":
- actions.updateFieldValue(propName, value);
- actions.triggerFieldChange(propName, value);
- break;
- default:
- break;
- }
-};
-
-export default handleEvent;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyInteger/index.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyInteger/index.jsx
deleted file mode 100644
index 5ed8d49a..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyInteger/index.jsx
+++ /dev/null
@@ -1,333 +0,0 @@
-import { useState, useEffect, useRef } from 'react';
-import { NumberInput, NumberDisplay, Slider, FieldValueList, CurrencyDisplay, Text } from '@pega/cosmos-react-core';
-import PropTypes from 'prop-types';
-
-// includes in bundle
-import handleEvent from "./event-utils";
-import { suggestionsHandler } from './suggestions-handler';
-
-import StyledPegaDxilMyIntegerWrapper from './styles';
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-const PegaDxilMyInteger = props => {
- const {
- getPConnect,
- value,
- defaultValue,
- placeholder,
- validatemessage,
- label,
- hideLabel,
- helperText,
- testId,
- displayMode,
- displayAs,
- showInput,
- min,
- max,
- step,
- showTicks,
- additionalProps,
- variant,
- formatter,
- negative,
- notation,
- isTableFormatter,
- hasSuggestions
- } = props;
- let { showGroupSeparators } = props;
- let { currencyDisplay } = props;
- const pConn = getPConnect();
- const actions = pConn.getActionsApi();
- const propName = pConn.getStateProps().value;
- const [integerValue, setIntegerValue] = useState(value?.toString());
- const sliderDefaultValue = !defaultValue && defaultValue !== 0 ? max : defaultValue;
- const hasValueChange = useRef(false);
-
-
- let { readOnly, required, disabled } = props;
- [readOnly, required, disabled] = [readOnly, required, disabled].map(
- (prop) => prop === true || (typeof prop === 'string' && prop === 'true')
- );
-
- const [status, setStatus] = useState(hasSuggestions ? 'pending' : '');
- useEffect(() => {
- if (validatemessage !== '') {
- setStatus('error');
- }
- if (hasSuggestions) {
- setStatus('pending');
- } else if (!hasSuggestions && status !== 'success') {
- setStatus(validatemessage !== '' ? 'error' : undefined);
- }
- }, [validatemessage, hasSuggestions]);
-
- useEffect(() => {
- setIntegerValue(value?.toString());
- }, [value]);
-
- useEffect(() => {
- if (displayAs === 'slider' && value === '') {
- handleEvent(actions, 'change', propName, sliderDefaultValue);
- }
- }, []);
-
- const { decimalPrecision, currencyDecimalPrecision, currencyISOCode } = props;
- let noOfDecimals = parseInt(decimalPrecision, 10);
- if (Number.isNaN(noOfDecimals)) noOfDecimals = undefined;
- let noOfFractionDigits = currencyDecimalPrecision === 'auto' ? undefined : parseInt(currencyDecimalPrecision, 10);
- let unit;
- let unitPlacement;
-
- if (['LABELS_LEFT', 'STACKED_LARGE_VAL', 'DISPLAY_ONLY'].includes(displayMode)) {
- switch (formatter) {
- case 'Decimal': {
- break;
- }
- case 'Percentage': {
- showGroupSeparators = false;
- unit = '%';
- unitPlacement = 'after';
- break;
- }
- case 'Decimal-Auto': {
- noOfDecimals = Number.isInteger(integerValue) ? 0 : 2;
- break;
- }
- default: {
- noOfDecimals = 0;
- break;
- }
- }
-
- if (isTableFormatter && displayMode === 'LABELS_LEFT') {
- showGroupSeparators = true;
- noOfFractionDigits = undefined;
- if (formatter === 'Currency-Code') {
- currencyDisplay = 'code';
- }
- }
-
-
- const displayComp =
- formatter === 'Currency' || formatter === 'Currency-Code' ? (
-
- ) : (
-
- );
-
-
- switch (displayMode) {
- case 'DISPLAY_ONLY': {
- return ( displayComp );
- }
- case 'LABELS_LEFT': {
- return (
-
-
-
- );
- }
- case 'STACKED_LARGE_VAL': {
- return (
-
-
- {displayComp}
-
- )
- }
- ]}
- />
-
- );
- }
- // no default
- }
- }
-
- function onChangeHandler(enteredValue) {
- if (hasSuggestions) {
- setStatus(undefined);
- }
- setIntegerValue(enteredValue);
- // const parsedValue = integerValue !== '' ? Number(integerValue) : '';
- if (value !== (enteredValue !== '' ? Number(enteredValue) : '')) {
- handleEvent(actions, 'change', propName, enteredValue !== '' ? Number(enteredValue) : '');
- hasValueChange.current = true;
- }
- // In case of stepper variation there is no blur event as component is never focussed unless forced. Need to update redux on change.
- if (displayAs === 'stepper') {
- handleEvent(actions, 'changeNblur', propName, enteredValue !== '' ? Number(enteredValue) : '');
- }
- }
-
- const onResolveSuggestionHandler = (accepted) => {
- suggestionsHandler(accepted, pConn, setStatus);
- };
-
- return displayAs === 'slider' ? (
-
- {
- onChangeHandler(selectedValue.toString());
- handleEvent(actions, 'changeNblur', propName, selectedValue);
- }}
- />
-
- ) : (
-
- {
- onChangeHandler(enteredValue);
- }}
- onBlur={() => {
- if (!readOnly && (hasValueChange.current || !value)) {
- handleEvent(actions, 'blur', propName, integerValue !== '' ? Number(integerValue) : '');
- if (hasSuggestions) {
- pConn.ignoreSuggestion();
- }
- hasValueChange.current = false;
- }
- }}
- onResolveSuggestion={onResolveSuggestionHandler}
- />
-
- );
-}
-
-PegaDxilMyInteger.defaultProps = {
- value: '',
- defaultValue: null,
- placeholder: '',
- validatemessage: '',
- helperText: '',
- hideLabel: false,
- disabled: false,
- readOnly: false,
- required: false,
- testId: null,
- showGroupSeparators: false,
- displayMode: null,
- displayAs: 'input',
- showInput: true,
- min: 0,
- max: 100,
- step: 1,
- showTicks: true,
- additionalProps: {},
- variant: 'inline',
- decimalPrecision: null,
- currencyISOCode: 'USD',
- isoCodeSelection: 'constant',
- formatter: 'defaultInteger',
- negative: 'minus-sign',
- notation: 'standard',
- currencyDisplay: 'symbol',
- currencyDecimalPrecision: 'auto',
- isTableFormatter: false,
- hasSuggestions: false
-};
-
-PegaDxilMyInteger.propTypes = {
- value: PropTypes.string,
- defaultValue: PropTypes.number,
- placeholder: PropTypes.string,
- label: PropTypes.string.isRequired,
- hideLabel: PropTypes.bool,
- getPConnect: PropTypes.func.isRequired,
- validatemessage: PropTypes.string,
- helperText: PropTypes.string,
- disabled: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- readOnly: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- required: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- testId: PropTypes.string,
- showGroupSeparators: PropTypes.bool,
- displayMode: PropTypes.string,
- displayAs: PropTypes.string,
- showInput: PropTypes.bool,
- min: PropTypes.number,
- max: PropTypes.number,
- step: PropTypes.number,
- showTicks: PropTypes.bool,
- additionalProps: PropTypes.objectOf(PropTypes.any),
- variant: PropTypes.string,
- decimalPrecision: PropTypes.number,
- currencyISOCode: PropTypes.string,
- isoCodeSelection: PropTypes.string,
- formatter: PropTypes.string,
- negative: PropTypes.string,
- notation: PropTypes.string,
- currencyDisplay: PropTypes.string,
- currencyDecimalPrecision: PropTypes.string,
- isTableFormatter: PropTypes.bool,
- hasSuggestions: PropTypes.bool
-};
-
-export default PegaDxilMyInteger;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyInteger/mock.stories.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyInteger/mock.stories.js
deleted file mode 100644
index 8cce1630..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyInteger/mock.stories.js
+++ /dev/null
@@ -1,21 +0,0 @@
-export const configProps = {
- value: '',
- label: 'Integer Sample',
- showGroupSeparators: true,
- placeholder: 'Integer Placeholder',
- helperText: 'Integer Helper Text',
- testId: 'integer-12345678',
- hasSuggestions: false
-};
-
-export const stateProps = {
- value: '.IntegerSample',
- hasSuggestions: false
-};
-
-export const fieldMetadata = {
- classID: 'DIXL-MediaCo-Work-NewService',
- type: 'Integer',
- displayAs: 'pxInteger',
- label: 'Integer sample'
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyInteger/styles.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyInteger/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyInteger/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyInteger/suggestions-handler.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyInteger/suggestions-handler.js
deleted file mode 100644
index 901cd99e..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyInteger/suggestions-handler.js
+++ /dev/null
@@ -1,10 +0,0 @@
-/* eslint-disable import/prefer-default-export */
-export const suggestionsHandler = (accepted, pConn, setStatus) => {
- if (accepted) {
- pConn.acceptSuggestion();
- setStatus('success');
- } else {
- pConn.ignoreSuggestion();
- setStatus(undefined);
- }
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyParagraph/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyParagraph/demo.stories.jsx
deleted file mode 100644
index 5f3cbe3d..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyParagraph/demo.stories.jsx
+++ /dev/null
@@ -1,48 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-
-import PegaDxilMyParagraph from './index.jsx';
-
-import { stateProps, configProps, fieldMetadata } from './mock.stories';
-
-export default {
- title: 'PegaDxilMyParagraph',
- decorators: [withKnobs],
- component: PegaDxilMyParagraph
-};
-
-export const basePegaDxilMyParagraph = () => {
-
- const props = {
- value: configProps.value,
- placeholder: configProps.placeholder,
- label: configProps.label,
- helperText: configProps.helperText,
- testId: configProps.testId,
- hasSuggestions: configProps.hasSuggestions,
- fieldMetadata,
-
- getPConnect: () => {
- return {
- getStateProps: () => {
- return stateProps;
- },
- getActionsApi: () => {
- return {
- updateFieldValue: () => {/* nothing */},
- triggerFieldChange: () => {/* nothing */}
- };
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- setInheritedProps: () => {/* nothing */},
- resolveConfigProps: () => {/* nothing */}
- };
- }
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyParagraph/event-utils.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyParagraph/event-utils.js
deleted file mode 100644
index 8b806f56..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyParagraph/event-utils.js
+++ /dev/null
@@ -1,18 +0,0 @@
-const handleEvent = (actions, eventType, propName, value) => {
- switch (eventType) {
- case "change":
- actions.updateFieldValue(propName, value);
- break;
- case "blur":
- actions.triggerFieldChange(propName, value);
- break;
- case "changeNblur":
- actions.updateFieldValue(propName, value);
- actions.triggerFieldChange(propName, value);
- break;
- default:
- break;
- }
-};
-
-export default handleEvent;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyParagraph/index.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyParagraph/index.jsx
deleted file mode 100644
index 5e1e621e..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyParagraph/index.jsx
+++ /dev/null
@@ -1,231 +0,0 @@
-import { useState, useEffect, useRef } from 'react';
-import { TextArea as CosmosTextArea, FieldValueList, ParagraphDisplay, Text, EmailDisplay, PhoneDisplay, URLDisplay } from '@pega/cosmos-react-core';
-import PropTypes from 'prop-types';
-
-// includes in bundle
-import { suggestionsHandler } from './suggestions-handler';
-import handleEvent from "./event-utils";
-
-import StyledPegaDxilMyParagraphWrapper from './styles';
-
-export const formatExists = (formatterVal) => {
- const formatterValues = [
- "TextInput",
- "WorkStatus",
- "RichText",
- "Email",
- "Phone",
- "URL",
- "Operator"
- ];
- let isformatter = false;
- if (formatterValues.includes(formatterVal)) {
- isformatter = true;
- }
- return isformatter;
- };
-
-
-export const textFormatter = (formatter,value) => {
- let displayComponent = null;
- switch(formatter){
- case "TextInput" : {
- displayComponent = value;
- break;
- }
- case "Email" : {
- displayComponent = ( );
- break;
- }
- case "Phone" : {
- displayComponent = ( );
- break;
- }
- case "URL" : {
- displayComponent = ( );
- break;
- }
- // no default
- }
- return displayComponent;
-};
-
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-const PegaDxilMyParagraph = props => {
- const {
- getPConnect,
- value,
- hideLabel,
- placeholder,
- validatemessage,
- label,
- helperText,
- testId,
- fieldMetadata,
- displayMode,
- additionalProps,
- variant,
- isTableFormatter,
- hasSuggestions
- } = props;
- const { formatter } = props;
- const pConn = getPConnect();
- const actions = pConn.getActionsApi();
- const propName = pConn.getStateProps().value;
- const maxLength = fieldMetadata?.maxLength;
- const hasValueChange = useRef(false);
-
-
- // BUG-547602: Temporary type coercion for 8.5 until DXAPIs are enhanced to pass original pxViewMetadata JSON, respecting boolean primitives
- let { readOnly, required, disabled } = props;
- [readOnly, required, disabled] = [readOnly, required, disabled].map(
- (prop) => prop === true || (typeof prop === 'string' && prop === 'true')
- );
-
- const [inputValue, setInputValue] = useState(value);
- const [status, setStatus] = useState(hasSuggestions ? 'pending' : undefined);
- useEffect(() => setInputValue(value), [value]);
-
- useEffect(() => {
- if (validatemessage !== '') {
- setStatus('error');
- }
- if (hasSuggestions) {
- setStatus('pending');
- } else if (!hasSuggestions && status !== 'success') {
- setStatus(validatemessage !== '' ? 'error' : undefined);
- }
- }, [validatemessage, hasSuggestions]);
-
- if (displayMode === 'LABELS_LEFT' || displayMode === 'DISPLAY_ONLY') {
- let displayComp = ;
- if (isTableFormatter && formatExists(formatter) && formatter !== 'TextInput') {
- displayComp = textFormatter(formatter, value);
- }
- return displayMode === 'DISPLAY_ONLY' ? (
-
- displayComp
-
- ) : (
-
-
-
- );
- }
-
- if (displayMode === 'STACKED_LARGE_VAL') {
- const isValDefined = typeof value !== 'undefined' && value !== '';
- const val = isValDefined ? (
-
- {value}
-
- ) : (
- ''
- );
- return (
-
-
-
- );
- }
-
- const onResolveSuggestionHandler = (accepted) => {
- suggestionsHandler(accepted, pConn, setStatus);
- };
-
- return (
-
- {
- if (hasSuggestions) {
- setStatus(undefined);
- }
- setInputValue(event.target.value);
- if (value !== event.target.value) {
- handleEvent(actions, 'change', propName, event.target.value);
- hasValueChange.current = true;
- }
- }}
- onBlur={(event) => {
- if (!value || hasValueChange.current) {
- handleEvent(actions, 'blur', propName, event.target.value);
- if (hasSuggestions) {
- pConn.ignoreSuggestion();
- }
- hasValueChange.current = false;
- }
- }}
- onResolveSuggestion={onResolveSuggestionHandler}
- />
-
- );
-}
-
-PegaDxilMyParagraph.defaultProps = {
- value: '',
- placeholder: '',
- validatemessage: '',
- helperText: '',
- hideLabel: false,
- disabled: false,
- readOnly: false,
- required: false,
- testId: null,
- displayMode: null,
- fieldMetadata: {},
- additionalProps: {},
- variant: 'inline',
- formatter: '',
- isTableFormatter: false,
- hasSuggestions: false
-};
-
-PegaDxilMyParagraph.propTypes = {
- value: PropTypes.string,
- placeholder: PropTypes.string,
- label: PropTypes.string.isRequired,
- hideLabel: PropTypes.bool,
- getPConnect: PropTypes.func.isRequired,
- validatemessage: PropTypes.string,
- displayMode: PropTypes.string,
- helperText: PropTypes.string,
- disabled: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- readOnly: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- required: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- testId: PropTypes.string,
- fieldMetadata: PropTypes.objectOf(PropTypes.any),
- additionalProps: PropTypes.objectOf(PropTypes.any),
- variant: PropTypes.string,
- formatter: PropTypes.string,
- isTableFormatter: PropTypes.bool,
- hasSuggestions: PropTypes.bool
-};
-
-export default PegaDxilMyParagraph;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyParagraph/mock.stories.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyParagraph/mock.stories.js
deleted file mode 100644
index 69fb82bf..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyParagraph/mock.stories.js
+++ /dev/null
@@ -1,20 +0,0 @@
-export const configProps = {
- value: '',
- label: 'Paragraph Sample',
- placeholder: 'Paragraph Placeholder',
- helperText: 'Paragraph Helper Text',
- testId: 'paragraph-12345678',
- hasSuggestions: false
-};
-
-export const fieldMetadata = {
- classID: 'DIXL-MediaCo-Work-NewService',
- type: 'Text',
- displayAs: 'pxTextArea',
- label: 'Paragraph sample'
-};
-
-export const stateProps = {
- value: '.ParagraphSample',
- hasSuggestions: false
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyParagraph/styles.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyParagraph/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyParagraph/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyParagraph/suggestions-handler.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyParagraph/suggestions-handler.js
deleted file mode 100644
index 901cd99e..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyParagraph/suggestions-handler.js
+++ /dev/null
@@ -1,10 +0,0 @@
-/* eslint-disable import/prefer-default-export */
-export const suggestionsHandler = (accepted, pConn, setStatus) => {
- if (accepted) {
- pConn.acceptSuggestion();
- setStatus('success');
- } else {
- pConn.ignoreSuggestion();
- setStatus(undefined);
- }
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPercentage/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPercentage/demo.stories.jsx
deleted file mode 100644
index e13fe786..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPercentage/demo.stories.jsx
+++ /dev/null
@@ -1,49 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-
-import { configProps, stateProps, fieldMetadata } from './mock.stories.js';
-
-import PegaDxilMyPercentage from './index.jsx';
-
-export default {
- title: 'PegaDxilMyPercentage',
- decorators: [withKnobs],
- component: PegaDxilMyPercentage
-};
-
-export const basePegaDxilMyPercentage = () => {
-
- const props = {
- value: configProps.value,
- placeholder: configProps.placeholder,
- label: configProps.label,
- helperText: configProps.helperText,
- showGroupSeparators: configProps.showGroupSeparators,
- hasSuggestions: configProps.hasSuggestions,
- testId: configProps.testId,
- fieldMetadata,
-
- getPConnect: () => {
- return {
- getStateProps: () => {
- return stateProps;
- },
- getActionsApi: () => {
- return {
- updateFieldValue: () => {/* nothing */},
- triggerFieldChange: () => {/* nothing */}
- };
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- setInheritedProps: () => {/* nothing */},
- resolveConfigProps: () => {/* nothing */}
- };
- }
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPercentage/event-utils.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPercentage/event-utils.js
deleted file mode 100644
index 8b806f56..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPercentage/event-utils.js
+++ /dev/null
@@ -1,18 +0,0 @@
-const handleEvent = (actions, eventType, propName, value) => {
- switch (eventType) {
- case "change":
- actions.updateFieldValue(propName, value);
- break;
- case "blur":
- actions.triggerFieldChange(propName, value);
- break;
- case "changeNblur":
- actions.updateFieldValue(propName, value);
- actions.triggerFieldChange(propName, value);
- break;
- default:
- break;
- }
-};
-
-export default handleEvent;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPercentage/index.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPercentage/index.jsx
deleted file mode 100644
index 48431e8b..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPercentage/index.jsx
+++ /dev/null
@@ -1,275 +0,0 @@
-import { useState, useEffect, useRef } from 'react';
-import {
- NumberInput,
- NumberDisplay,
- CurrencyDisplay,
- FieldValueList,
- Text
-} from '@pega/cosmos-react-core';
-import PropTypes from 'prop-types';
-
-// includes in bundle
-import handleEvent from './event-utils';
-import { suggestionsHandler } from './suggestions-handler';
-
-import StyledPegaDxilMyPercentageWrapper from './styles';
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-const PegaDxilMyPercentage = props => {
- const {
- getPConnect,
- value,
- placeholder,
- validatemessage,
- label,
- hideLabel,
- helperText,
- testId,
- decimalPrecision,
- additionalProps,
- displayMode,
- variant,
- formatter,
- isTableFormatter,
- hasSuggestions
- } = props;
- let { showGroupSeparators } = props;
- const pConn = getPConnect();
- const actions = pConn.getActionsApi();
- const propName = pConn.getStateProps().value;
- const [percentageValue, setPercentageValue] = useState(value?.toString());
- const hasValueChange = useRef(false);
-
- let { readOnly, required, disabled } = props;
- [readOnly, required, disabled] = [readOnly, required, disabled].map(
- (prop) => prop === true || (typeof prop === 'string' && prop === 'true')
- );
-
- const [status, setStatus] = useState(hasSuggestions ? 'pending' : undefined);
-
- useEffect(() => {
- if (validatemessage !== '') {
- setStatus('error');
- }
- if (hasSuggestions) {
- setStatus('pending');
- } else if (!hasSuggestions && status !== 'success') {
- setStatus(validatemessage !== '' ? 'error' : undefined);
- }
- }, [validatemessage, hasSuggestions]);
-
- let numberOfDecimals = parseInt(decimalPrecision, 10);
- if (Number.isNaN(numberOfDecimals)) {
- numberOfDecimals = decimalPrecision === '' ? undefined : 2;
- }
-
- useEffect(() => {
- setPercentageValue(value?.toString());
- }, [value]);
-
- if (displayMode === 'LABELS_LEFT' || displayMode === 'DISPLAY_ONLY') {
- let unit = 'percent';
- let displayComp = null;
-
- if (isTableFormatter) {
- switch (formatter) {
- case 'Integer': {
- numberOfDecimals = 0;
- showGroupSeparators = true;
- unit = '';
- break;
- }
- case 'Decimal': {
- showGroupSeparators = true;
- unit = '';
- break;
- }
- case 'Decimal-Auto': {
- numberOfDecimals = Number.isInteger(percentageValue) ? 0 : 2;
- showGroupSeparators = true;
- unit = '';
- break;
- }
- default: {
- showGroupSeparators = false;
- break;
- }
- }
- }
-
-
- displayComp = (
-
- );
- if (isTableFormatter && (formatter === 'Currency' || formatter === 'Currency-Code')) {
- const { currencyISOCode } = props;
- let showIsoCode = true;
- if (formatter === 'Currency') {
- showIsoCode = false;
- }
- displayComp = (
-
- );
- }
-
-
- return displayMode === 'DISPLAY_ONLY' ? (
-
- displayComp
-
- ) : (
-
-
-
- );
- }
-
-
- if (displayMode === 'STACKED_LARGE_VAL') {
- const displayComp = (
-
- );
-
-
- return (
-
-
- {displayComp}
-
- )
- }
- ]}
- />
-
- );
- }
-
- const onResolveSuggestionHandler = (accepted) => {
- suggestionsHandler(accepted, pConn, setStatus);
- };
-
- return (
-
- {
- if (hasSuggestions) {
- setStatus(undefined);
- }
- setPercentageValue(enteredValue);
- if (value !== enteredValue) {
- handleEvent(actions, 'change', propName, enteredValue);
- hasValueChange.current = true;
- }
- }}
- onBlur={() => {
- const parsedValue = percentageValue !== '' ? Number(percentageValue) : '';
- if (!value || hasValueChange.current) {
- handleEvent(actions, 'blur', propName, parsedValue);
- if (hasSuggestions) {
- pConn.ignoreSuggestion();
- }
- hasValueChange.current = false;
- }
- }}
- onResolveSuggestion={onResolveSuggestionHandler}
- />
-
- );
-}
-
-PegaDxilMyPercentage.defaultProps = {
- value: '',
- placeholder: '',
- validatemessage: '',
- helperText: '',
- hideLabel: false,
- disabled: false,
- readOnly: false,
- required: false,
- testId: null,
- decimalPrecision: '',
- showGroupSeparators: false,
- additionalProps: {},
- displayMode: null,
- variant: 'inline',
- currencyISOCode: 'USD',
- formatter: '',
- isTableFormatter: false,
- hasSuggestions: false
-};
-
-PegaDxilMyPercentage.propTypes = {
- value: PropTypes.string,
- placeholder: PropTypes.string,
- label: PropTypes.string.isRequired,
- hideLabel: PropTypes.bool,
- getPConnect: PropTypes.func.isRequired,
- validatemessage: PropTypes.string,
- helperText: PropTypes.string,
- disabled: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- readOnly: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- required: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- testId: PropTypes.string,
- decimalPrecision: PropTypes.string,
- showGroupSeparators: PropTypes.bool,
- additionalProps: PropTypes.objectOf(PropTypes.any),
- displayMode: PropTypes.string,
- variant: PropTypes.string,
- formatter: PropTypes.string,
- currencyISOCode: PropTypes.string,
- isTableFormatter: PropTypes.bool,
- hasSuggestions: PropTypes.bool
-};
-
-export default PegaDxilMyPercentage;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPercentage/mock.stories.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPercentage/mock.stories.js
deleted file mode 100644
index fc6331a3..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPercentage/mock.stories.js
+++ /dev/null
@@ -1,21 +0,0 @@
-export const configProps = {
- value: '',
- label: 'Percentage Sample',
- showGroupSeparators: true,
- placeholder: 'Percentage Placeholder',
- helperText: 'Percentage Helper Text',
- testId: 'percentage-12345678',
- hasSuggestions: false
-};
-
-export const stateProps = {
- value: '.PercentageSample',
- hasSuggestions: false
-};
-
-export const fieldMetadata = {
- classID: 'DIXL-MediaCo-Work-NewService',
- type: 'Decimal',
- displayAs: 'pxPercentage',
- label: 'Percentage sample'
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPercentage/styles.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPercentage/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPercentage/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPercentage/suggestions-handler.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPercentage/suggestions-handler.js
deleted file mode 100644
index 901cd99e..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPercentage/suggestions-handler.js
+++ /dev/null
@@ -1,10 +0,0 @@
-/* eslint-disable import/prefer-default-export */
-export const suggestionsHandler = (accepted, pConn, setStatus) => {
- if (accepted) {
- pConn.acceptSuggestion();
- setStatus('success');
- } else {
- pConn.ignoreSuggestion();
- setStatus(undefined);
- }
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPhone/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPhone/demo.stories.jsx
deleted file mode 100644
index e0c51940..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPhone/demo.stories.jsx
+++ /dev/null
@@ -1,46 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-
-import PegaDxilMyPhone from './index.jsx';
-import { stateProps, configProps } from './mock.stories';
-
-export default {
- title: 'PegaDxilMyPhone',
- decorators: [withKnobs],
- component: PegaDxilMyPhone
-};
-
-export const basePegaDxilMyPhone = () => {
-
- const props = {
- value: configProps.value,
- placeholder: configProps.placeholder,
- label: configProps.label,
- testId: configProps.testId,
- hasSuggestions: configProps.hasSuggestions,
- datasource: configProps.datasource,
-
- getPConnect: () => {
- return {
- getStateProps: () => {
- return stateProps;
- },
- getActionsApi: () => {
- return {
- updateFieldValue: () => {/* nothing */},
- triggerFieldChange: () => {/* nothing */}
- };
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- setInheritedProps: () => {/* nothing */},
- resolveConfigProps: () => {/* nothing */}
- };
- }
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPhone/event-utils.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPhone/event-utils.js
deleted file mode 100644
index 8b806f56..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPhone/event-utils.js
+++ /dev/null
@@ -1,18 +0,0 @@
-const handleEvent = (actions, eventType, propName, value) => {
- switch (eventType) {
- case "change":
- actions.updateFieldValue(propName, value);
- break;
- case "blur":
- actions.triggerFieldChange(propName, value);
- break;
- case "changeNblur":
- actions.updateFieldValue(propName, value);
- actions.triggerFieldChange(propName, value);
- break;
- default:
- break;
- }
-};
-
-export default handleEvent;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPhone/index.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPhone/index.jsx
deleted file mode 100644
index 5ea815cd..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPhone/index.jsx
+++ /dev/null
@@ -1,266 +0,0 @@
-import { useState, useEffect, useRef } from 'react';
-import {
- PhoneInput as CosmosPhone,
- getPhoneNumberParts,
- PhoneDisplay,
- FieldValueList,
- Text,
- EmailDisplay, URLDisplay
-} from '@pega/cosmos-react-core';
-import PropTypes from 'prop-types';
-
-// includes in bundle
-import handleEvent from "./event-utils";
-import { suggestionsHandler } from './suggestions-handler';
-
-import StyledPegaDxilMyPhoneWrapper from './styles';
-
-export const formatExists = (formatterVal) => {
- const formatterValues = [
- "TextInput",
- "WorkStatus",
- "RichText",
- "Email",
- "Phone",
- "URL",
- "Operator"
- ];
- let isformatter = false;
- if (formatterValues.includes(formatterVal)) {
- isformatter = true;
- }
- return isformatter;
- };
-
-
-export const textFormatter = (formatter,value) => {
- let displayComponent = null;
- switch(formatter){
- case "TextInput" : {
- displayComponent = value;
- break;
- }
- case "Email" : {
- displayComponent = ( );
- break;
- }
- case "Phone" : {
- displayComponent = ( );
- break;
- }
- case "URL" : {
- displayComponent = ( );
- break;
- }
- // no default
- }
- return displayComponent;
-};
-
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-const PegaDxilMyPhone = props => {
- const {
- getPConnect,
- value,
- showCountryCode,
- placeholder,
- validatemessage,
- label,
- hideLabel,
- helperText,
- datasource,
- testId,
- displayMode,
- additionalProps,
- variant,
- isTableFormatter,
- hasSuggestions
- } = props;
- const { formatter } = props;
- const pConn = getPConnect();
- const actions = pConn.getActionsApi();
- const propName = pConn.getStateProps().value;
- const hasValueChange = useRef(false);
-
- let callingCodesList = [];
- if (datasource?.source?.length > 0) {
- datasource.source.forEach((element) => {
- callingCodesList.push(element.value);
- });
- } else {
- callingCodesList = ['+1']; // if no datasource is present we default to show only US country code
- }
-
- // BUG-547602: Temporary type coercion for 8.5 until DXAPIs are enhanced to pass original pxViewMetadata JSON, respecting boolean primitives
- let { readOnly, required, disabled } = props;
- [readOnly, required, disabled] = [readOnly, required, disabled].map(
- (prop) => prop === true || (typeof prop === 'string' && prop === 'true')
- );
-
- const [inputValue, setInputValue] = useState(value);
- useEffect(() => setInputValue(value), [value]);
-
- const [status, setStatus] = useState(hasSuggestions ? 'pending' : undefined);
- useEffect(() => {
- if (validatemessage !== '') {
- setStatus('error');
- }
- if (hasSuggestions) {
- setStatus('pending');
- } else if (!hasSuggestions && status !== 'success') {
- setStatus(validatemessage !== '' ? 'error' : undefined);
- }
- }, [validatemessage, hasSuggestions]);
-
- // funtion to exclude country code from phone number
- function getPhoneNumberAlone(phoneNumber) {
- const phoneNumberParts = getPhoneNumberParts(phoneNumber, callingCodesList);
- return phoneNumberParts && phoneNumberParts[1];
- }
-
- function handleChangeBlur(enteredValue, eventType) {
- if (!getPhoneNumberAlone(enteredValue)) {
- enteredValue = '';
- }
- handleEvent(actions, eventType, propName, enteredValue);
- }
-
- let displayComp = null;
- if (displayMode) {
- displayComp = ;
- }
-
- if (displayMode === 'LABELS_LEFT' || displayMode === 'DISPLAY_ONLY') {
- if (isTableFormatter && formatExists(formatter)) {
- displayComp = textFormatter(formatter, value);
- }
- return displayMode === 'DISPLAY_ONLY' ? (
-
- displayComp
-
- ) : (
-
-
-
- );
- }
-
- if (displayMode === 'STACKED_LARGE_VAL') {
- return (
-
-
- {displayComp}
-
- )
- }
- ]}
- />
-
- );
- }
-
- const onResolveSuggestionHandler = (accepted) => {
- suggestionsHandler(accepted, pConn, setStatus);
- };
-
- return (
-
- {
- if (hasSuggestions) {
- setStatus(undefined);
- }
- setInputValue(enteredValue);
- if (value !== enteredValue) {
- handleEvent(actions, 'change', propName, enteredValue);
- }
- hasValueChange.current = true;
- }}
- onBlur={(enteredValue) => {
- if (!value || hasValueChange.current) {
- handleChangeBlur(enteredValue, 'blur');
- if (hasSuggestions) {
- pConn.ignoreSuggestion();
- }
- hasValueChange.current = false;
- }
- }}
- onResolveSuggestion={onResolveSuggestionHandler}
- />
-
- );
-}
-
-PegaDxilMyPhone.defaultProps = {
- value: '',
- placeholder: '',
- validatemessage: '',
- helperText: '',
- datasource: undefined,
- hideLabel: false,
- disabled: false,
- readOnly: false,
- required: false,
- showCountryCode: true,
- testId: null,
- displayMode: null,
- additionalProps: {},
- variant: 'inline',
- formatter: '',
- isTableFormatter: false,
- hasSuggestions: false
-};
-
-PegaDxilMyPhone.propTypes = {
- value: PropTypes.string,
- placeholder: PropTypes.string,
- datasource: PropTypes.objectOf(PropTypes.any),
- label: PropTypes.string.isRequired,
- hideLabel: PropTypes.bool,
- getPConnect: PropTypes.func.isRequired,
- validatemessage: PropTypes.string,
- helperText: PropTypes.string,
- showCountryCode: PropTypes.bool,
- disabled: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- readOnly: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- required: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- testId: PropTypes.string,
- displayMode: PropTypes.string,
- additionalProps: PropTypes.objectOf(PropTypes.any),
- variant: PropTypes.string,
- formatter: PropTypes.string,
- isTableFormatter: PropTypes.bool,
- hasSuggestions: PropTypes.bool
-};
-
-export default PegaDxilMyPhone;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPhone/mock.stories.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPhone/mock.stories.js
deleted file mode 100644
index 75bfaf42..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPhone/mock.stories.js
+++ /dev/null
@@ -1,37 +0,0 @@
-export const configProps = {
- value: '',
- label: 'Phone Sample',
- datasource: {
- source: [
- {
- value: '+1'
- },
- {
- value: '+91'
- },
- {
- value: '+48'
- },
- {
- value: '+44'
- }
- ],
- fields: {}
- },
- showCountryCode: true,
- placeholder: 'Phone Placeholder',
- helperText: 'Phone Helper Text',
- testId: 'phone-12345678',
- hasSuggestions: false
-};
-
-export const stateProps = {
- value: '.PhoneSample',
- datasource: {
- source: 'D_pyCountryCallingCodeList.pxResults',
- fields: {
- value: '.pyCallingCode'
- }
- },
- hasSuggestions: false
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPhone/styles.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPhone/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPhone/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPhone/suggestions-handler.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPhone/suggestions-handler.js
deleted file mode 100644
index 901cd99e..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPhone/suggestions-handler.js
+++ /dev/null
@@ -1,10 +0,0 @@
-/* eslint-disable import/prefer-default-export */
-export const suggestionsHandler = (accepted, pConn, setStatus) => {
- if (accepted) {
- pConn.acceptSuggestion();
- setStatus('success');
- } else {
- pConn.ignoreSuggestion();
- setStatus(undefined);
- }
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPicklist/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPicklist/demo.stories.jsx
deleted file mode 100644
index ed2621a7..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPicklist/demo.stories.jsx
+++ /dev/null
@@ -1,78 +0,0 @@
-import { useState } from 'react';
-import { withKnobs } from '@storybook/addon-knobs';
-
-import { configProps, rawMetadata, fieldMetadata, stateProps } from './mock.stories.js';
-
-import PegaDxilMyPicklist from './index.jsx';
-
-export default {
- title: 'PegaDxilMyPicklist',
- decorators: [withKnobs],
- component: PegaDxilMyPicklist
-};
-
-export const basePegaDxilMyPicklist = () => {
- // eslint-disable-next-line react-hooks/rules-of-hooks
- const [value, setValue] = useState(configProps.value);
-
- const props = {
- value,
- placeholder: configProps.placeholder,
- label: configProps.label,
- helperText: configProps.helperText,
- datasource: configProps.datasource,
- testId: configProps.testId,
- hasSuggestions: configProps.hasSuggestions,
- fieldMetadata,
-
- getPConnect: () => {
- return {
- getConfigProps: () => {
- return configProps;
- },
- getStateProps: () => {
- return stateProps;
- },
- getLocalizedValue: val => {
- return val;
- },
- getLocaleRuleNameFromKeys: (localeClass, localeContext, localeName) => {
- return `${localeClass}!${localeContext}!${localeName}`;
- },
- getCaseInfo: () => {
- return {
- getClassName: () => {
- return 'DIXL-MediaCo-Work-NewService';
- }
- };
- },
- getRawMetadata: () => {
- return rawMetadata;
- },
- getActionsApi: () => {
- return {
- updateFieldValue: (propName, theValue) => {
- setValue(theValue);
- },
- triggerFieldChange: () => {/* nothing */}
- };
- },
- getValidationApi: () => {
- return {
- validate: () => {/* nothing */}
- };
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- setInheritedProps: () => {/* nothing */},
- resolveConfigProps: () => {/* nothing */}
- };
- }
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPicklist/event-utils.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPicklist/event-utils.js
deleted file mode 100644
index 8b806f56..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPicklist/event-utils.js
+++ /dev/null
@@ -1,18 +0,0 @@
-const handleEvent = (actions, eventType, propName, value) => {
- switch (eventType) {
- case "change":
- actions.updateFieldValue(propName, value);
- break;
- case "blur":
- actions.triggerFieldChange(propName, value);
- break;
- case "changeNblur":
- actions.updateFieldValue(propName, value);
- actions.triggerFieldChange(propName, value);
- break;
- default:
- break;
- }
-};
-
-export default handleEvent;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPicklist/index.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPicklist/index.jsx
deleted file mode 100644
index 1e2d0de0..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPicklist/index.jsx
+++ /dev/null
@@ -1,351 +0,0 @@
-import { useState, useEffect, useRef } from 'react';
-import { Select, Option, FieldValueList, Text } from '@pega/cosmos-react-core';
-import PropTypes from 'prop-types';
-
-// includes in bundle
-import handleEvent from "./event-utils";
-import { suggestionsHandler } from './suggestions-handler';
-
-import StyledPegaDxilMyPicklistWrapper from './styles';
-import {EmailDisplay, PhoneDisplay, URLDisplay } from "@pega/cosmos-react-core";
-
-export const formatExists = (formatterVal) => {
- const formatterValues = [
- "TextInput",
- "WorkStatus",
- "RichText",
- "Email",
- "Phone",
- "URL",
- "Operator"
- ];
- let isformatter = false;
- if (formatterValues.includes(formatterVal)) {
- isformatter = true;
- }
- return isformatter;
- };
-
-
-export const textFormatter = (formatter,value) => {
- let displayComponent = null;
- switch(formatter){
- case "TextInput" : {
- displayComponent = value;
- break;
- }
- case "Email" : {
- displayComponent = ( );
- break;
- }
- case "Phone" : {
- displayComponent = ( );
- break;
- }
- case "URL" : {
- displayComponent = ( );
- break;
- }
- // no default
- }
- return displayComponent;
-};
-
-
-export const setDefaultValue = (dropdownOptions, pConnect, propName) => {
- // calculate the default option and set it to dropdown
- const option = (dropdownOptions && dropdownOptions[0]) || {};
- const defaultValue = option.key ? option.props.value : '';
- pConnect.setValue(propName, defaultValue, defaultValue);
-};
-
-const pushPlaceholderOption = (placeholder, listSourceItems, items, pConnect) => {
- // If we have a placeholder, push that option in the list of items
- if (placeholder) {
- items.push(
-
- {pConnect.getLocalizedValue(placeholder)}
-
- );
- } else if (!listSourceItems) {
- // If we don't have a placeholder and our list source is empty, push a blank row option in the list of items
- items.push( );
- }
-};
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-const PegaDxilMyPicklist = props => {
- const {
- getPConnect,
- value,
- label,
- hideLabel,
- placeholder,
- datasource,
- listType,
- validatemessage,
- testId,
- helperText,
- additionalProps,
- displayMode,
- onRecordChange,
- variant,
- fieldMetadata,
- isTableFormatter,
- hasSuggestions
- } = props;
- const { formatter } = props;
- const pConnect = getPConnect();
- const actions = pConnect.getActionsApi();
- const propName = pConnect.getStateProps().value;
- const className = pConnect.getCaseInfo().getClassName();
- const refName = propName?.slice(propName.lastIndexOf('.') + 1);
-
- let { readOnly, required, disabled } = props;
- [readOnly, required, disabled] = [readOnly, required, disabled].map(
- (prop) => prop === true || (typeof prop === 'string' && prop === 'true')
- );
-
- const [status, setStatus] = useState(hasSuggestions ? 'pending' : undefined);
-
- const useIsMount = () => {
- const isMountRef = useRef(true);
- useEffect(() => {
- isMountRef.current = false;
- }, []);
- return isMountRef.current;
- };
-
- const isMount = useIsMount();
-
- const metaData = Array.isArray(fieldMetadata)
- ? fieldMetadata.filter((field) => field?.classID === className)[0]
- : fieldMetadata;
- let displayName = metaData?.datasource?.propertyForDisplayText;
- displayName = displayName?.slice(displayName.lastIndexOf('.') + 1);
- const localeContext = metaData?.datasource?.tableType === 'DataPage' ? 'datapage' : 'associated';
- const localeClass = localeContext === 'datapage' ? '@baseclass' : className;
- const localeName = localeContext === 'datapage' ? metaData?.datasource?.name : refName;
- const localePath = localeContext === 'datapage' ? displayName : '';
-
- const configProps = pConnect.getConfigProps();
- const items = [];
- const isDatapage = listType === 'datapage';
- let listSourceItems = isDatapage ? configProps.listOutput : datasource;
-
- if (isDatapage && typeof datasource === 'object' && !Array.isArray(listSourceItems)) {
- listSourceItems = datasource.source ? datasource.source : [];
- }
-
- useEffect(() => {
- if (validatemessage !== '') {
- setStatus('error');
- }
- if (hasSuggestions) {
- setStatus('pending');
- } else if (!hasSuggestions && status !== 'success') {
- setStatus(validatemessage !== '' ? 'error' : undefined);
- }
- }, [validatemessage, hasSuggestions]);
-
- pushPlaceholderOption(placeholder, listSourceItems, items, pConnect);
-
- // Loop through all of our list source items that make up the values of the dropdown
-
- let selectedLabel = '';
- (listSourceItems || []).forEach((item) => {
- selectedLabel =
- value !== undefined &&
- value !== null &&
- item.key !== undefined &&
- item.key !== null &&
- value.toString() === item.key.toString()
- ? item.text || item.value
- : selectedLabel;
- items.push(
-
- {isDatapage
- ? pConnect.getLocalizedValue(
- item.text,
- localePath,
- pConnect.getLocaleRuleNameFromKeys(localeClass, localeContext, localeName)
- )
- : pConnect.getLocalizedValue(
- item.value,
- localePath,
- pConnect.getLocaleRuleNameFromKeys(localeClass, localeContext, localeName)
- )}
-
- );
- });
-
- const isDisplayModeEnabled =
- displayMode === 'LABELS_LEFT' || displayMode === 'STACKED_LARGE_VAL' || displayMode === 'DISPLAY_ONLY';
- let firstOptionKey = '';
- let firstOptionValue = '';
- if (!placeholder && listSourceItems?.length > 0) {
- // First option isn't going to change as long as placeholder is present. Incase placeholder is not there
- // check for new option
- firstOptionKey = listSourceItems[0].key;
- firstOptionValue = listSourceItems[0].text || listSourceItems[0].value;
- }
- useEffect(() => {
- // placeholder - placeholder option configured to be shown with dropdown, empty string if not configured
- // value - value of the dropdown if set to something prior (either by pre-activity or default value etc.), empty string if nothing is set
- // selectedLabel - is value(the one above) if it is one of the option in the dropdown datasource, empty string if not
- // below code does this -
- // set dropdown value to first option if placeholder is NOT present and ((value is empty) or (value is not empty and selectedLabel is empty))
- // set dropdown value to empty if placeholder is present and value is not empty and selectedLabel is empty
- // Broken down first option(key, value) to be as dependency instead of entire items array which creates new reference on every render
- // First option is kept as dependency as setDefaultValue sets only first value from options
- if (!isDisplayModeEnabled && ((!placeholder && !value) || (!isMount && value && !selectedLabel))) {
- setDefaultValue(items, pConnect, propName);
- }
- }, [firstOptionKey, firstOptionValue, placeholder, selectedLabel, value, propName]);
-
- if (displayMode === 'LABELS_LEFT' || displayMode === 'DISPLAY_ONLY') {
- let displayComp = selectedLabel;
- if (isTableFormatter && formatExists(formatter)) {
- displayComp = textFormatter(formatter, selectedLabel);
- }
- if (selectedLabel === '') {
- displayComp = value || –– ;
- }
-
- return displayMode === 'DISPLAY_ONLY' ? (
-
- displayComp
-
- ) : (
-
-
-
- );
- }
-
- if (displayMode === 'STACKED_LARGE_VAL') {
- selectedLabel = selectedLabel === '' ? value : selectedLabel;
- const isValDefined = typeof selectedLabel !== 'undefined' && selectedLabel !== '';
- const val = isValDefined ? (
-
- {selectedLabel}
-
- ) : (
- ''
- );
- return (
-
-
-
- );
- }
-
- const onResolveSuggestionHandler = (accepted) => {
- suggestionsHandler(accepted, pConnect, setStatus);
- };
-
- return (
-
- {
- handleEvent(actions, 'changeNblur', propName, event.target.value);
- if (hasSuggestions) {
- pConnect.ignoreSuggestion();
- setStatus(undefined);
- }
- if (onRecordChange) {
- onRecordChange(event);
- }
- }}
- onBlur={(event) => {
- pConnect.getValidationApi().validate(event.target.value);
- }}
- onResolveSuggestion={onResolveSuggestionHandler}
- >
- {items}
-
-
- );
-}
-
-PegaDxilMyPicklist.defaultProps = {
- value: '',
- placeholder: '',
- validatemessage: '',
- hideLabel: false,
- disabled: false,
- readOnly: false,
- required: false,
- testId: null,
- helperText: '',
- datasource: [],
- listType: '',
- additionalProps: {},
- fieldMetadata: {},
- displayMode: null,
- onRecordChange: null,
- variant: 'inline',
- formatter: '',
- isTableFormatter: false,
- hasSuggestions: false
-};
-
-PegaDxilMyPicklist.propTypes = {
- getPConnect: PropTypes.func.isRequired,
- value: PropTypes.string,
- placeholder: PropTypes.string,
- label: PropTypes.string.isRequired,
- hideLabel: PropTypes.bool,
- datasource: PropTypes.oneOfType([
- PropTypes.arrayOf(PropTypes.any),
- PropTypes.shape({
- source: PropTypes.arrayOf(PropTypes.any)
- })
- ]),
- listType: PropTypes.string,
- validatemessage: PropTypes.string,
- disabled: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- readOnly: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- required: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- testId: PropTypes.string,
- helperText: PropTypes.string,
- additionalProps: PropTypes.objectOf(PropTypes.any),
- fieldMetadata: PropTypes.objectOf(PropTypes.any),
- displayMode: PropTypes.string,
- onRecordChange: PropTypes.func,
- variant: PropTypes.string,
- formatter: PropTypes.string,
- isTableFormatter: PropTypes.bool,
- hasSuggestions: PropTypes.bool
-};
-
-export default PegaDxilMyPicklist;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPicklist/mock.stories.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPicklist/mock.stories.js
deleted file mode 100644
index 1bea2054..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPicklist/mock.stories.js
+++ /dev/null
@@ -1,67 +0,0 @@
-export const configProps = {
- value: '',
- label: 'Picklist Sample',
- placeholder: 'Select...',
- listType: 'associated',
- datasource: [
- {
- key: 'Option 1',
- value: 'Option 1'
- },
- {
- key: 'Option 2',
- value: 'Option 2'
- },
- {
- key: 'Option 3',
- value: 'Option 3'
- }
- ],
- helperText: 'Picklist Helper Text',
- testId: 'picklist-12345678',
- hasSuggestions: false
-};
-
-export const stateProps = {
- value: '.PicklistSample',
- placeholder: 'Select...',
- datasource: '.PicklistSample',
- hasSuggestions: false
-};
-
-export const rawMetadata = {
- type: 'Dropdown',
- config: {
- value: '@P .PicklistSample',
- label: '@L Picklist Sample',
- placeholder: '@L Select...',
- listType: 'associated',
- datasource: '@ASSOCIATED .PicklistSample',
- helperText: '@L Picklist Helper Text',
- testId: 'picklist-12345678'
- }
-};
-
-export const fieldMetadata = {
- classID: 'DIXL-MediaCo-Work-NewService',
- type: 'Text',
- displayAs: 'pxDropdown',
- label: 'Picklist sample',
- datasource: {
- tableType: 'PromptList',
- records: [
- {
- key: 'Option 1',
- value: 'Option 1'
- },
- {
- key: 'Option 2',
- value: 'Option 2'
- },
- {
- key: 'Option 3',
- value: 'Option 3'
- }
- ]
- }
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPicklist/styles.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPicklist/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPicklist/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPicklist/suggestions-handler.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPicklist/suggestions-handler.js
deleted file mode 100644
index 901cd99e..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyPicklist/suggestions-handler.js
+++ /dev/null
@@ -1,10 +0,0 @@
-/* eslint-disable import/prefer-default-export */
-export const suggestionsHandler = (accepted, pConn, setStatus) => {
- if (accepted) {
- pConn.acceptSuggestion();
- setStatus('success');
- } else {
- pConn.ignoreSuggestion();
- setStatus(undefined);
- }
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyText/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyText/demo.stories.jsx
deleted file mode 100644
index 1294e24a..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyText/demo.stories.jsx
+++ /dev/null
@@ -1,51 +0,0 @@
-import { useState } from 'react';
-import { withKnobs } from '@storybook/addon-knobs';
-
-import { stateProps, configProps } from './mock.stories';
-
-import PegaDxilMyText from './index.jsx';
-
-export default {
- title: 'PegaDxilMyText',
- decorators: [withKnobs],
- component: PegaDxilMyText
-};
-
-export const basePegaDxilMyText = () => {
- // eslint-disable-next-line react-hooks/rules-of-hooks
- const [value, setValue] = useState(configProps.value);
-
- const props = {
- value,
- placeholder: configProps.placeholder,
- label: configProps.label,
- testId: configProps.testId,
- hasSuggestions: configProps.hasSuggestions,
-
- getPConnect: () => {
- return {
- getStateProps: () => {
- return stateProps;
- },
- getActionsApi: () => {
- return {
- updateFieldValue: (propName, theValue) => {
- setValue(theValue);
- },
- triggerFieldChange: () => {/* nothing */}
- };
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- setInheritedProps: () => {/* nothing */},
- resolveConfigProps: () => {/* nothing */}
- };
- }
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyText/index.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyText/index.jsx
deleted file mode 100644
index d0ac35df..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyText/index.jsx
+++ /dev/null
@@ -1,60 +0,0 @@
-import PropTypes from 'prop-types';
-import { Input, Label } from '@pega/cosmos-react-core';
-
-import StyledPegaDxilMyTextWrapper from './styles';
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-const PegaDxilMyText = props => {
- const { getPConnect, value, placeholder, disabled, readOnly, required, label, testId } = props;
-
- const pConn = getPConnect();
- const actions = pConn.getActionsApi();
- const propName = pConn?.getStateProps()?.value;
-
- const handleOnChange = event => {
- const { value: updatedValue } = event.target;
- actions.updateFieldValue(propName, updatedValue);
- };
-
- return (
-
- {label}
-
-
- );
-};
-
-PegaDxilMyText.defaultProps = {
- value: '',
- placeholder: '',
- disabled: false,
- readOnly: false,
- required: false,
- testId: null
-};
-
-PegaDxilMyText.propTypes = {
- label: PropTypes.string,
- value: PropTypes.string,
- placeholder: PropTypes.string,
- getPConnect: PropTypes.func.isRequired,
- disabled: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- readOnly: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- required: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- testId: PropTypes.string
-};
-
-export default PegaDxilMyText;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyText/mock.stories.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyText/mock.stories.js
deleted file mode 100644
index fd283d8b..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyText/mock.stories.js
+++ /dev/null
@@ -1,13 +0,0 @@
-export const configProps = {
- value: '',
- label: 'Text Sample',
- placeholder: 'Text Placeholder',
- helperText: 'Text Helper Text',
- testId: 'Text-12345678',
- hasSuggestions: false
-};
-
-export const stateProps = {
- value: '.TextSample',
- hasSuggestions: false
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyText/styles.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyText/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyText/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/StatusWork.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/StatusWork.jsx
deleted file mode 100644
index 4c6c2b48..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/StatusWork.jsx
+++ /dev/null
@@ -1,26 +0,0 @@
-import { Status } from "@pega/cosmos-react-core";
-
-export default function StatusWorkRenderer({ value }) {
- let variant = "info";
-
- const warnStrings = ["fail", "cancel", "reject", "revoke", "stopped", "warn"];
- const infoStrings = ["open", "hold", "info", "new"];
- const successStrings = ["resolved", "completed", "success"];
- const pendingStrings = ["pending"];
-
- if (new RegExp(warnStrings.join("|"), "i").test(value)) {
- variant = "warn";
- } else if (new RegExp(infoStrings.join("|"), "i").test(value)) {
- variant = "info";
- } else if (new RegExp(successStrings.join("|"), "i").test(value)) {
- variant = "success";
- } else if (new RegExp(pendingStrings.join("|"), "i").test(value)) {
- variant = "pending";
- }
-
- return (
-
- {value}
-
- );
-}
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/demo.stories.jsx
deleted file mode 100644
index cf098746..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/demo.stories.jsx
+++ /dev/null
@@ -1,48 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-
-import PegaDxilMyTextInput from './index.jsx';
-
-import { stateProps, fieldMetadata, configProps } from './mock.stories';
-
-export default {
- title: 'PegaDxilMyTextInput',
- decorators: [withKnobs],
- component: PegaDxilMyTextInput
-};
-
-export const basePegaDxilMyTextInput = () => {
-
- const props = {
- value: configProps.value,
- placeholder: configProps.placeholder,
- label: configProps.label,
- helperText: configProps.helperText,
- testId: configProps.testId,
- hasSuggestions: configProps.hasSuggestions,
- fieldMetadata,
-
- getPConnect: () => {
- return {
- getStateProps: () => {
- return stateProps;
- },
- getActionsApi: () => {
- return {
- updateFieldValue: () => {/* nothing */},
- triggerFieldChange: () => {/* nothing */}
- };
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- setInheritedProps: () => {/* nothing */},
- resolveConfigProps: () => {/* nothing */}
- };
- }
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/event-utils.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/event-utils.js
deleted file mode 100644
index 8b806f56..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/event-utils.js
+++ /dev/null
@@ -1,18 +0,0 @@
-const handleEvent = (actions, eventType, propName, value) => {
- switch (eventType) {
- case "change":
- actions.updateFieldValue(propName, value);
- break;
- case "blur":
- actions.triggerFieldChange(propName, value);
- break;
- case "changeNblur":
- actions.updateFieldValue(propName, value);
- actions.triggerFieldChange(propName, value);
- break;
- default:
- break;
- }
-};
-
-export default handleEvent;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/index.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/index.jsx
deleted file mode 100644
index 3bfc666c..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/index.jsx
+++ /dev/null
@@ -1,239 +0,0 @@
-import { useEffect, useState, useRef } from 'react';
-import { Input, FieldValueList, Text, EmailDisplay, PhoneDisplay, URLDisplay } from '@pega/cosmos-react-core';
-import PropTypes from 'prop-types';
-
-// include in bundle
-import handleEvent from "./event-utils";
-import StatusWorkRenderer from "./StatusWork.jsx";
-import { suggestionsHandler } from './suggestions-handler';
-
-import StyledPegaDxilMyTextInputWrapper from './styles';
-
-
-export const formatExists = (formatterVal) => {
- const formatterValues = [
- "TextInput",
- "WorkStatus",
- "RichText",
- "Email",
- "Phone",
- "URL",
- "Operator"
- ];
- let isformatter = false;
- if (formatterValues.includes(formatterVal)) {
- isformatter = true;
- }
- return isformatter;
- };
-
-
-export const textFormatter = (formatter,value) => {
- let displayComponent = null;
- switch(formatter){
- case "TextInput" : {
- displayComponent = value;
- break;
- }
- case "Email" : {
- displayComponent = ( );
- break;
- }
- case "Phone" : {
- displayComponent = ( );
- break;
- }
- case "URL" : {
- displayComponent = ( );
- break;
- }
- // no default
- }
- return displayComponent;
-};
-
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-const PegaDxilMyTextInput = props => {
- const {
- getPConnect,
- placeholder,
- validatemessage,
- label,
- hideLabel,
- helperText,
- testId,
- fieldMetadata,
- additionalProps,
- displayMode,
- displayAsStatus,
- variant,
- hasSuggestions,
- isTableFormatter
- } = props;
- const { formatter } = props;
- const pConn = getPConnect();
- const actions = pConn.getActionsApi();
- const propName = pConn.getStateProps().value;
- const maxLength = fieldMetadata?.maxLength;
- const hasValueChange = useRef(false);
-
- let { value, readOnly, required, disabled } = props;
- [readOnly, required, disabled] = [readOnly, required, disabled].map(
- (prop) => prop === true || (typeof prop === 'string' && prop === 'true')
- );
-
- const [inputValue, setInputValue] = useState(value);
- const [status, setStatus] = useState(hasSuggestions ? 'pending' : undefined);
- useEffect(() => setInputValue(value), [value]);
-
- useEffect(() => {
- if (validatemessage !== '') {
- setStatus('error');
- }
- if (hasSuggestions) {
- setStatus('pending');
- } else if (!hasSuggestions && status !== 'success') {
- setStatus(validatemessage !== '' ? 'error' : undefined);
- }
- }, [validatemessage, hasSuggestions]);
-
- const onResolveSuggestionHandler = (accepted) => {
- suggestionsHandler(accepted, pConn, setStatus);
- };
- // Override the value to render as status work when prop passed to display as status
- if (displayAsStatus) {
- value = StatusWorkRenderer({ value });
-
- // Fall into this scenario for case summary, default to stacked status
- if (!displayMode) {
- return ;
- }
- }
-
- if (displayMode === 'LABELS_LEFT' || displayMode === 'DISPLAY_ONLY') {
- let displayComp = value || –– ;
- if (isTableFormatter && formatExists(formatter)) {
- displayComp = textFormatter(formatter, value);
- }
- return displayMode === 'DISPLAY_ONLY' ? (
- displayComp
- ) : (
-
-
-
- );
- }
-
- if (displayMode === 'STACKED_LARGE_VAL') {
- const isValDefined = typeof value !== 'undefined' && value !== '';
- const val = isValDefined ? (
-
- {value}
-
- ) : (
- ''
- );
- return (
-
-
-
- );
- }
-
- return (
-
- {
- if (hasSuggestions) {
- setStatus(undefined);
- }
- setInputValue(event.target.value);
- if (value !== event.target.value) {
- handleEvent(actions, 'change', propName, event.target.value);
- hasValueChange.current = true;
- }
- }}
- onBlur={(event) => {
- if ((!value || hasValueChange.current) && !readOnly) {
- handleEvent(actions, 'blur', propName, event.target.value);
- if (hasSuggestions) {
- pConn.ignoreSuggestion();
- }
- hasValueChange.current = false;
- }
- }}
- onResolveSuggestion={onResolveSuggestionHandler}
- />
-
- );
-}
-
-PegaDxilMyTextInput.defaultProps = {
- value: '',
- placeholder: '',
- validatemessage: '',
- helperText: '',
- displayAsStatus: false,
- hideLabel: false,
- disabled: false,
- readOnly: false,
- required: false,
- testId: null,
- fieldMetadata: {},
- additionalProps: {},
- displayMode: null,
- variant: 'inline',
- formatter: '',
- isTableFormatter: false,
- hasSuggestions: false
-};
-
-PegaDxilMyTextInput.propTypes = {
- value: PropTypes.string,
- placeholder: PropTypes.string,
- displayMode: PropTypes.string,
- displayAsStatus: PropTypes.bool,
- label: PropTypes.string.isRequired,
- hideLabel: PropTypes.bool,
- getPConnect: PropTypes.func.isRequired,
- validatemessage: PropTypes.string,
- helperText: PropTypes.string,
- disabled: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- readOnly: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- required: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- testId: PropTypes.string,
- fieldMetadata: PropTypes.objectOf(PropTypes.any),
- additionalProps: PropTypes.objectOf(PropTypes.any),
- variant: PropTypes.string,
- formatter: PropTypes.string,
- isTableFormatter: PropTypes.bool,
- hasSuggestions: PropTypes.bool
-};
-
-export default PegaDxilMyTextInput;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/mock.stories.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/mock.stories.js
deleted file mode 100644
index b2753b25..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/mock.stories.js
+++ /dev/null
@@ -1,21 +0,0 @@
-export const configProps = {
- value: '',
- label: 'TextInput Sample',
- placeholder: 'TextInput Placeholder',
- helperText: 'TextInput Helper Text',
- testId: 'TextInput-12345678',
- hasSuggestions: false
-};
-
-export const stateProps = {
- value: '.TextInputSample',
- hasSuggestions: false
-};
-
-export const fieldMetadata = {
- classID: 'DIXL-MediaCo-Work-NewService',
- type: 'Text',
- maxLength: 256,
- displayAs: 'pxTextInput',
- label: 'TextInput Sample'
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/styles.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/suggestions-handler.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/suggestions-handler.js
deleted file mode 100644
index 901cd99e..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTextInput/suggestions-handler.js
+++ /dev/null
@@ -1,10 +0,0 @@
-/* eslint-disable import/prefer-default-export */
-export const suggestionsHandler = (accepted, pConn, setStatus) => {
- if (accepted) {
- pConn.acceptSuggestion();
- setStatus('success');
- } else {
- pConn.ignoreSuggestion();
- setStatus(undefined);
- }
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTimeOfDay/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTimeOfDay/demo.stories.jsx
deleted file mode 100644
index 6d689d76..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTimeOfDay/demo.stories.jsx
+++ /dev/null
@@ -1,57 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-import { configProps, stateProps } from './mock.stories';
-import PegaDxilMyTimeOfDay from './index.jsx';
-
-export default {
- title: 'PegaDxilMyTimeOfDay',
- decorators: [withKnobs],
- component: PegaDxilMyTimeOfDay
-};
-
-export const basePegaDxilMyTimeOfDay = () => {
- const props = {
- getPConnect: () => {
- return {
- getActionsApi: () => {
- return {
- updateFieldValue: () => {/* nothing */},
- triggerFieldChange: () => {/* nothing */}
- };
- },
- getValidationApi: () => {
- return {
- validate: () => {/* nothing */}
- };
- },
- getStateProps: () => {
- return stateProps;
- },
- getConfigProps: () => {
- return configProps;
- },
- ignoreSuggestion: () => {/* nothing */},
- clearErrorMessages: () => {/* nothing */}
- };
- },
- value: configProps.value,
- validatemessage: configProps.validatemessage,
- label: configProps.label,
- hideLabel: configProps.hideLabel,
- helperText: configProps.helperText,
- withSeconds: configProps.withSeconds,
- testId: configProps.testId,
- additionalProps: configProps.additionalProps,
- displayMode: configProps.displayMode,
- variant: configProps.variant,
- hasSuggestions: configProps.hasSuggestions,
- disabled: configProps.disabled,
- readOnly: configProps.readOnly,
- required: configProps.required
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTimeOfDay/index.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTimeOfDay/index.jsx
deleted file mode 100644
index 3330d5d5..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTimeOfDay/index.jsx
+++ /dev/null
@@ -1,213 +0,0 @@
-import { useEffect, useState } from 'react';
-import { TimeInput, FieldValueList, DateTimeDisplay, Text } from '@pega/cosmos-react-core';
-import PropTypes from 'prop-types';
-
-// includes in bundle
-import {
- parseClockFormat,
- timeCorrectedToSeconds,
- datetimeFireChangeBlurEvents
-} from "./time-of-day";
-import { suggestionsHandler } from './suggestions-handler';
-
-import StyledPegaDxilMyTimeOfDayWrapper from './styles';
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-const PegaDxilMyTimeOfDay = props => {
- const {
- getPConnect,
- value,
- validatemessage,
- label,
- hideLabel,
- helperText,
- withSeconds,
- pickerInterval,
- testId,
- additionalProps,
- displayMode,
- variant,
- hasSuggestions
- } = props;
- let { formatter } = props;
- const pConn = getPConnect();
- const actions = pConn.getActionsApi();
- const propName = pConn.getStateProps().value;
-
-
- // BUG-547602: Temporary type coercion for 8.5 until DXAPIs are enhanced to pass original pxViewMetadata JSON, respecting boolean primitives
- let { readOnly, required, disabled } = props;
- [readOnly, required, disabled] = [readOnly, required, disabled].map(
- (prop) => prop === true || (typeof prop === 'string' && prop === 'true')
- );
-
- let { clockFormat } = props;
- clockFormat = parseClockFormat(clockFormat);
-
- const [status, setStatus] = useState(hasSuggestions ? 'pending' : undefined);
-
- useEffect(() => {
- if (validatemessage !== '') {
- setStatus('error');
- }
- if (hasSuggestions) {
- setStatus('pending');
- } else if (!hasSuggestions && status !== 'success') {
- setStatus(validatemessage !== '' ? 'error' : undefined);
- }
- }, [validatemessage, hasSuggestions]);
-
- const onResolveSuggestionHandler = (accepted) => {
- suggestionsHandler(accepted, pConn, setStatus);
- };
-
- function handleBlur(onBlurValue) {
- const { valueAsISOString: time, state: errorState } = onBlurValue;
- const trimmedTime = time ? timeCorrectedToSeconds(time, withSeconds) : time;
- datetimeFireChangeBlurEvents(errorState, value, trimmedTime, actions, propName, pConn);
- const isValueChanged = !(value === undefined && trimmedTime === '') && value !== trimmedTime;
- if (hasSuggestions && isValueChanged) {
- pConn.ignoreSuggestion();
- }
- }
-
- function handleChange(onChangeValue) {
- const { valueAsISOString: time } = onChangeValue;
- const trimmedTime = time ? timeCorrectedToSeconds(time, withSeconds) : time;
- if (hasSuggestions && value !== trimmedTime) {
- setStatus(undefined);
- }
- pConn.clearErrorMessages({
- property: propName
- });
- }
-
- if (displayMode === 'LABELS_LEFT' || displayMode === 'STACKED_LARGE_VAL' || displayMode === 'DISPLAY_ONLY') {
- let variantValue = 'time';
- let formatValue = withSeconds ? 'long' : 'short';
- if (pConn && pConn.getConfigProps()) {
- const runtimeformatter = pConn.getConfigProps()?.formatter;
- if (formatter !== runtimeformatter) {
- formatter = runtimeformatter;
- }
- }
- if (formatter === 'Time-Only') {
- variantValue = 'time';
- formatValue = 'long';
- }
- const displayComp = (
-
- );
- switch (displayMode) {
- case 'DISPLAY_ONLY': {
- return ( displayComp );
- }
- case 'LABELS_LEFT': {
- return (
-
-
-
- );
- }
- case 'STACKED_LARGE_VAL': {
- return (
-
-
- {displayComp}
-
- )
- }
- ]}
- />
-
- );
- }
- // no default
- }
- }
-
- return (
-
-
-
- );
-}
-
-PegaDxilMyTimeOfDay.defaultProps = {
- value: undefined,
- withSeconds: false,
- validatemessage: "",
- helperText: "",
- hideLabel: false,
- disabled: false,
- readOnly: false,
- required: false,
- pickerInterval: "30",
- clockFormat: 0,
- testId: null,
- additionalProps: {},
- displayMode: null,
- variant: "inline",
- formatter:"defaultTime"
-};
-
-PegaDxilMyTimeOfDay.propTypes = {
- value: PropTypes.string,
- label: PropTypes.string.isRequired,
- hideLabel: PropTypes.bool,
- withSeconds: PropTypes.bool,
- getPConnect: PropTypes.func.isRequired,
- validatemessage: PropTypes.string,
- helperText: PropTypes.string,
- disabled: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- readOnly: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- required: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- pickerInterval: PropTypes.string,
- clockFormat: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
- testId: PropTypes.string,
- additionalProps: PropTypes.objectOf(PropTypes.any),
- displayMode: PropTypes.string,
- variant: PropTypes.string,
- formatter : PropTypes.string
-};
-
-export default PegaDxilMyTimeOfDay;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTimeOfDay/mock.stories.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTimeOfDay/mock.stories.js
deleted file mode 100644
index 8a432748..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTimeOfDay/mock.stories.js
+++ /dev/null
@@ -1,20 +0,0 @@
-export const configProps = {
- value: '13:30',
- validatemessage: '',
- label: 'TimeOfDay Label',
- hideLabel: false,
- helperText: 'TimeOfDay helper text',
- withSeconds: false,
- testId: '12345678',
- additionalProps: {},
- displayMode: '',
- variant: '',
- hasSuggestions: false,
- readOnly: false,
- required: false,
- disabled: false
-};
-
-export const stateProps = {
- value: '.TimeOfDayLabel'
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTimeOfDay/styles.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTimeOfDay/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTimeOfDay/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTimeOfDay/suggestions-handler.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTimeOfDay/suggestions-handler.js
deleted file mode 100644
index 901cd99e..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTimeOfDay/suggestions-handler.js
+++ /dev/null
@@ -1,10 +0,0 @@
-/* eslint-disable import/prefer-default-export */
-export const suggestionsHandler = (accepted, pConn, setStatus) => {
- if (accepted) {
- pConn.acceptSuggestion();
- setStatus('success');
- } else {
- pConn.ignoreSuggestion();
- setStatus(undefined);
- }
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTimeOfDay/time-of-day.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTimeOfDay/time-of-day.js
deleted file mode 100644
index fad402d1..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyTimeOfDay/time-of-day.js
+++ /dev/null
@@ -1,288 +0,0 @@
-/* eslint-disable no-undef */
-import dayjs from "dayjs";
-import relativeTime from 'dayjs/plugin/relativeTime.js';
-import localizedFormat from 'dayjs/plugin/localizedFormat.js';
-import utc from 'dayjs/plugin/utc.js';
-import timezone from 'dayjs/plugin/timezone.js';
-
-dayjs.extend(relativeTime);
-dayjs.extend(localizedFormat);
-dayjs.extend(utc);
-dayjs.extend(timezone);
-
-/**
- * Return relative time in fromNow for the given datetime
- * @description Convert and return the given datetime in dayJSObject
- *
- * @param {string} text datetime
- * @returns {object} datetime as a dayjs object
- */
-export const getDayJSObject = (text) => {
- const momObj = dayjs(text);
- if (momObj.isValid()) return momObj;
- const timeStamp = text;
- const isDateTime = timeStamp.indexOf("GMT") !== -1;
- const year = parseInt(timeStamp.substr(0, 4), 10);
- const month = parseInt(timeStamp.substr(4, 2), 10) - 1;
- const day = parseInt(timeStamp.substr(6, 2), 10);
-
- const CurrentTz = PCore.getLocaleUtils().getTimeZoneInUse();
-
- let mom = new Date();
-
- mom.setUTCDate(day);
- mom.setUTCMonth(month);
- mom.setUTCFullYear(year);
-
- /* istanbul ignore else */
- if (isDateTime) {
- const hours = parseInt(timeStamp.substr(9, 2), 10);
- const minutes = parseInt(timeStamp.substr(11, 2), 10);
- const seconds = parseInt(timeStamp.substr(13, 2), 10);
- const ms = parseInt(timeStamp.substr(16, 3), 10);
- mom.setUTCHours(hours);
- mom.setUTCMinutes(minutes);
- mom.setUTCSeconds(seconds);
- mom.setUTCMilliseconds(ms);
- }
-
- mom = dayjs(
- mom.toLocaleString("en-US", {
- timeZone: CurrentTz
- })
- );
-
- return mom;
-};
-
-/**
- * Return relative time in fromNow for the given datetime
- *
- * @param {string} time datetime
- * @returns {object} relative time from now
- */
-export const getRelativeTime = (time) => {
- let relativetime = "";
- if (dayjs(time).isUTC()) {
- relativetime = dayjs(time).fromNow();
- } else {
- const dayjstime = getDayJSObject(time);
- relativetime = dayjs(dayjstime).fromNow();
- }
- return relativetime;
-};
-
-/**
- * Return year for the date passed
- *
- * @param {string} value from which Year needs to be taken out
- * @returns {number} year for the date passed
- */
-export const getFullYear = (value) =>
- value ? new Date(value).getFullYear() : new Date().getFullYear();
-
-/**
- * Return maxDate for the date passed
- *
- * @param {number} nextYears next number of years
- * @param {number} currentYear current year
- * @param {number} yearFromValue year set on value in redux
- *
- * @returns {string} maxDate calculated based on inputs
- */
-export const getMaxDate = (nextYears, currentYear, yearFromValue) => {
- if (Number.isNaN(nextYears)) {
- nextYears = 20;
- }
- let maxYear = currentYear + nextYears;
- if (yearFromValue > maxYear) {
- maxYear = yearFromValue;
- }
- return `${maxYear}-01-01`;
-};
-
-/**
- * Return minDate for the date passed
- *
- * @param {number} previousYears previous number of years
- * @param {number} currentYear current year
- * @param {number} yearFromValue year set on value in redux
- *
- * @returns {string} minDate calculated based on inputs
- */
-export const getMinDate = (previousYears, currentYear, yearFromValue) => {
- if (Number.isNaN(previousYears)) {
- previousYears = 100;
- }
- let minYear = currentYear - previousYears;
- if (yearFromValue < minYear) {
- minYear = yearFromValue;
- }
- return `${minYear}-12-31`;
-};
-
-/**
- * Return clockFormat after parsing
- *
- * @param {number | string} clockFormat chosen by user
- *
- * @returns {number} clockFormat
- */
-export const parseClockFormat = (clockFormat) =>
- typeof clockFormat === "string" ? parseInt(clockFormat, 10) : clockFormat;
-
-/**
- * Return datetime value string off to seconds
- *
- * @param {string} datetime in ISO format
- * @param {boolean} withSeconds to specify if seconds is needed or not
- *
- * @returns {string} datetime after stripping of ms and seconds if selected to
- */
-export const correctDateTimeToSeconds = (datetime, withSeconds) => {
- if (withSeconds) {
- return `${datetime.substring(0, datetime.indexOf("Z"))}.000Z`;
- }
- return `${datetime.substring(0, datetime.lastIndexOf(":"))}:00.000Z`;
-};
-
-/**
- * Return time value string off to seconds
- *
- * @param {string} datetime in ISO format
- * @param {boolean} withSeconds to specify if seconds is needed or not
- *
- * @returns {string} just time after stripping of ms and seconds if selected to
- */
-export const timeCorrectedToSeconds = (datetime, withSeconds) => {
- if (withSeconds) {
- return datetime.substring(datetime.indexOf("T") + 1, datetime.indexOf("."));
- }
- return `${datetime.substring(
- datetime.indexOf("T") + 1,
- datetime.lastIndexOf(":")
- )}:00`;
-};
-
-/**
- * This function handles the cosmos blur handler of DateTime components
- *
- * @param {string | undefined} errorState for the selected datetime value
- * @param {string} actualValue present in redux
- * @param {string} formattedValue retrieved by trimming ISO to just Date/Time, also applying timezone if DateTime
- * @param {object} actions object which has fire and blur callbacks
- * @param {string} propName name of the property bound
- * @param {object} pConn component's PConnect object which is useful to invoke validationApi
- *
- * @returns {void}
- */
-export const datetimeFireChangeBlurEvents = (
- errorState,
- actualValue,
- formattedValue,
- actions,
- propName,
- pConn
-) => {
-
- // TODO - clean up, we should not rely on timestamp from cosmos to check InComplete validation
- // above triggerFieldChange should have validated this
- if (errorState) {
- pConn.getValidationApi().validate(errorState);
- }
- // BUG-640834 In errorState presist old values avoiding store update & re-render.
- else{
- if (formattedValue !== actualValue) {
- actions.updateFieldValue(propName, formattedValue);
- }
- actions.triggerFieldChange(propName, formattedValue);
- }
-};
-
-/**
- * Return Date format for the locale passed
- *
- * @param {string} locale locale string
- * @param {object} options options for format string
- * @returns {string} dateformat for the locale
- * Example : getDateFormat("pl-PL") returns "DD.MM.YYYY"
- */
-export const getDateFormat = (locale, options) => {
- return new Intl.DateTimeFormat(locale, options)
- .formatToParts()
- .map(({ type, value }) => {
- switch (type) {
- case "day":
- return "DD";
- case "month":
- return "MM";
- case "year":
- return "YYYY";
- case "hour":
- return "hh";
- case "minute":
- return "mm";
- case "second":
- return "ss";
- case "dayPeriod":
- return "A";
- case "literal":
- return value;
- default:
- return "";
- }
- })
- .join("");
-};
-
-/**
- * Return boolean for the locale passed to specify if locale uses 12 hour format
- *
- * @param {string} locale locale string
- * @returns {boolean} True or False for the locale
- * Example : getDateFormat("pl-PL") returns false
- */
-export const is12HClockFormat = (locale) => {
- const meridiem = new Intl.DateTimeFormat(locale, {
- hour: "numeric"
- })
- .formatToParts()
- .find(({ type }) => type === "dayPeriod");
- return !!(meridiem === null || meridiem === undefined
- ? undefined
- : meridiem.value);
-};
-
-/**
- * Return Option object for Time formatting
- *
- * @param {boolean} withSeconds true or false depending on seconds to be included
- * @param {boolean} is12h 12 hour format
- * @returns {object} options object time formatting
- * Example : getTimeOptions(false, true) returns {hour: 'numeric',minute: 'numeric',hour12: true}
- */
-export const getTimeOptions = (withSeconds, is12h = false) => {
- return {
- hour: "numeric",
- minute: "numeric",
- ...(withSeconds && { second: "numeric" }),
- hour12: is12h
- };
-};
-
-/**
- * Return Option object for Datetime formatting
- *
- * @param {boolean} withSeconds true or false depending on seconds to be included
- * @param {boolean} is12h 12 hour format
- * @returns {object} options object datetime formatting
- * Example : getDateTimeOptions(false, true) returns {year: 'numeric',month: 'numeric',day: 'numeric',hour: 'numeric',minute: 'numeric',hour12: true}
- */
-export const getDateTimeOptions = (withSeconds, is12h = false) => {
- return {
- year: "numeric",
- month: "numeric",
- day: "numeric",
- ...getTimeOptions(withSeconds, is12h)
- };
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/demo.stories.jsx
deleted file mode 100644
index c85be627..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/demo.stories.jsx
+++ /dev/null
@@ -1,46 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-
-import PegaDxilMyUrl from './index.jsx';
-import { stateProps, configProps } from './mock.stories';
-
-export default {
- title: 'PegaDxilMyUrl',
- decorators: [withKnobs],
- component: PegaDxilMyUrl
-};
-
-export const basePegaDxilMyUrl = () => {
-
- const props = {
- value: configProps.value,
- placeholder: configProps.placeholder,
- label: configProps.label,
- helperText: configProps.helperText,
- testId: configProps.testId,
- hasSuggestions: configProps.hasSuggestions,
-
- getPConnect: () => {
- return {
- getStateProps: () => {
- return stateProps;
- },
- getActionsApi: () => {
- return {
- updateFieldValue: () => {/* nothing */},
- triggerFieldChange: () => {/* nothing */}
- };
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- setInheritedProps: () => {/* nothing */},
- resolveConfigProps: () => {/* nothing */}
- };
- }
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/event-utils.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/event-utils.js
deleted file mode 100644
index 8b806f56..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/event-utils.js
+++ /dev/null
@@ -1,18 +0,0 @@
-const handleEvent = (actions, eventType, propName, value) => {
- switch (eventType) {
- case "change":
- actions.updateFieldValue(propName, value);
- break;
- case "blur":
- actions.triggerFieldChange(propName, value);
- break;
- case "changeNblur":
- actions.updateFieldValue(propName, value);
- actions.triggerFieldChange(propName, value);
- break;
- default:
- break;
- }
-};
-
-export default handleEvent;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/index.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/index.jsx
deleted file mode 100644
index 70f8f17c..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/index.jsx
+++ /dev/null
@@ -1,232 +0,0 @@
-import { useState, useEffect, useRef} from "react";
-import { Input, FieldValueList, Text } from "@pega/cosmos-react-core";
-import PropTypes from "prop-types";
-
-// includes in bundle
-import {formatExists,textFormatter, urlFormatter} from "./text-url.jsx";
-import handleEvent from "./event-utils";
-import { suggestionsHandler } from './suggestions-handler';
-
-import StyledPegaDxilMyUrlWrapper from './styles';
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-const PegaDxilMyUrl = props => {
- const {
- getPConnect,
- value,
- hideLabel,
- placeholder,
- validatemessage,
- label,
- helperText,
- testId,
- displayMode,
- additionalProps,
- variant,
- isTableFormatter,
- displayAs,
- widthSel,
- customWidth,
- altText,
- altTextOfImage,
- propaltTextOfImage,
- urlLabel,
- propUrlLabel,
- urlLabelSelection,
- tableDisplayAs,
- hasSuggestions
- } = props;
- const { formatter } = props;
- const pConn = getPConnect();
- const actions = pConn.getActionsApi();
- const propName = pConn.getStateProps().value;
- const hasValueChange = useRef(false);
-
-
- // BUG-547602: Temporary type coercion for 8.5 until DXAPIs are enhanced to pass original pxViewMetadata JSON, respecting boolean primitives
- let { readOnly, required, disabled } = props;
- [readOnly, required, disabled] = [readOnly, required, disabled].map(
- (prop) => prop === true || (typeof prop === 'string' && prop === 'true')
- );
-
- const [inputValue, setInputValue] = useState(value);
- const [status, setStatus] = useState(hasSuggestions ? 'pending' : undefined);
- useEffect(() => setInputValue(value), [value]);
-
- useEffect(() => {
- if (validatemessage !== '') {
- setStatus('error');
- }
- if (hasSuggestions) {
- setStatus('pending');
- } else if (!hasSuggestions && status !== 'success') {
- setStatus(validatemessage !== '' ? 'error' : undefined);
- }
- }, [validatemessage, hasSuggestions]);
-
- let displayComp = null;
- if (displayMode) {
- displayComp = urlFormatter(value, {
- displayAs,
- tableDisplayAs,
- isTableFormatter,
- altText,
- altTextOfImage,
- propaltTextOfImage,
- urlLabelSelection,
- urlLabel,
- propUrlLabel,
- widthSel,
- customWidth
- });
- }
-
-
-
- if (displayMode === 'LABELS_LEFT' || displayMode === 'DISPLAY_ONLY') {
- if (isTableFormatter && formatter !== 'URL' && formatExists(formatter)) {
- displayComp = textFormatter(formatter, value);
- }
- return displayMode === 'DISPLAY_ONLY' ? (
- displayComp
- ) : (
-
-
-
- );
- }
-
- if (displayMode === 'STACKED_LARGE_VAL') {
- return (
-
-
- {displayComp}
-
- )
- }
- ]}
- />
-
- );
- }
-
- const onResolveSuggestionHandler = (accepted) => {
- suggestionsHandler(accepted, pConn, setStatus);
- };
-
- return (
-
- {
- if (hasSuggestions) {
- setStatus(undefined);
- }
- setInputValue(event.target.value);
- if (value !== event.target.value) {
- handleEvent(actions, 'change', propName, event.target.value);
- hasValueChange.current = true;
- }
- }}
- onBlur={(event) => {
- if (!value || hasValueChange.current) {
- handleEvent(actions, 'blur', propName, event.target.value);
- if (hasSuggestions) {
- pConn.ignoreSuggestion();
- }
- hasValueChange.current = false;
- }
- }}
- onFocus={actions.onFocus}
- onResolveSuggestion={onResolveSuggestionHandler}
- />
-
- );
-}
-
-PegaDxilMyUrl.defaultProps = {
- value: '',
- placeholder: '',
- validatemessage: '',
- helperText: '',
- hideLabel: false,
- disabled: false,
- readOnly: false,
- required: false,
- testId: null,
- displayMode: null,
- additionalProps: {},
- variant: 'inline',
- formatter: '',
- isTableFormatter: false,
- displayAs: 'defaultURL',
- widthSel: 'defaultWidth',
- customWidth: null,
- altText: 'constant',
- altTextOfImage: '',
- propaltTextOfImage: '',
- urlLabel: '',
- propUrlLabel: '',
- urlLabelSelection: 'constant',
- tableDisplayAs: 'link',
- hasSuggestions: false
-};
-
-PegaDxilMyUrl.propTypes = {
- value: PropTypes.string,
- placeholder: PropTypes.string,
- label: PropTypes.string.isRequired,
- hideLabel: PropTypes.bool,
- getPConnect: PropTypes.func.isRequired,
- validatemessage: PropTypes.string,
- helperText: PropTypes.string,
- disabled: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- readOnly: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- required: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
- testId: PropTypes.string,
- displayMode: PropTypes.string,
- additionalProps: PropTypes.objectOf(PropTypes.any),
- variant: PropTypes.string,
- formatter: PropTypes.string,
- isTableFormatter: PropTypes.bool,
- displayAs: PropTypes.string,
- widthSel: PropTypes.string,
- customWidth: PropTypes.number,
- altText: PropTypes.string,
- altTextOfImage: PropTypes.string,
- propaltTextOfImage: PropTypes.string,
- urlLabel: PropTypes.string,
- propUrlLabel: PropTypes.string,
- urlLabelSelection: PropTypes.string,
- tableDisplayAs: PropTypes.string,
- hasSuggestions: PropTypes.bool
-};
-
-export default PegaDxilMyUrl;
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/mock.stories.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/mock.stories.js
deleted file mode 100644
index 05e390a7..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/mock.stories.js
+++ /dev/null
@@ -1,22 +0,0 @@
-export const configProps = {
- value: '',
- label: 'URL Sample',
- placeholder: 'URL Placeholder',
- helperText: 'URL Helper Text',
- testId: 'url-12345678',
- hasSuggestions: false
-};
-
-export const fieldMetadata = {
- classID: 'DIXL-MediaCo-Work-NewService',
- type: 'Text',
- maxLength: 256,
- displayAs: 'pxURL',
- label: 'URL sample',
- validateAs: 'pxIsValidURL'
-};
-
-export const stateProps = {
- value: '.URLSample',
- hasSuggestions: false
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/styles.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/suggestions-handler.js b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/suggestions-handler.js
deleted file mode 100644
index 901cd99e..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/suggestions-handler.js
+++ /dev/null
@@ -1,10 +0,0 @@
-/* eslint-disable import/prefer-default-export */
-export const suggestionsHandler = (accepted, pConn, setStatus) => {
- if (accepted) {
- pConn.acceptSuggestion();
- setStatus('success');
- } else {
- pConn.ignoreSuggestion();
- setStatus(undefined);
- }
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/text-url.jsx b/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/text-url.jsx
deleted file mode 100644
index 81b8a6e8..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/Pega_DXIL_MyURL/text-url.jsx
+++ /dev/null
@@ -1,173 +0,0 @@
-import { useState, useRef, React} from "react";
-import { EmailDisplay, PhoneDisplay, URLDisplay, Image, Button, Lightbox } from '@pega/cosmos-react-core';
-
-export const formatExists = (formatterVal) => {
- const formatterValues = [
- "TextInput",
- "WorkStatus",
- "RichText",
- "Email",
- "Phone",
- "URL",
- "Operator"
- ];
- let isformatter = false;
- if (formatterValues.includes(formatterVal)) {
- isformatter = true;
- }
- return isformatter;
- };
-
-const urlLabelVal = (urlLabelSelection, btnVal, urlLabel, propUrlLabel) => {
- if ((urlLabel !== '' || propUrlLabel !== '') && btnVal !== null) {
- switch (urlLabelSelection) {
- case 'constant': {
- btnVal = urlLabel;
- break;
- }
- case 'propertyRef': {
- btnVal = propUrlLabel;
- break;
- }
- // no default
- }
- }
- return btnVal;
-};
-
-const isImage = (url) => /\.(jpg|jpeg|png|webp|avif|gif|svg)$/.test(url);
-
-const TableImage = (imageProps) => {
- const { value, altText, altTextOfImage, propaltTextOfImage, urlLabelSelection, urlLabel, propUrlLabel } = imageProps;
- const demoButtonRef = useRef(null);
- let imageDisplayComp = null;
- const [images, setImages] = useState(null);
- const imgDescription = {
- id: 'url',
- name: urlLabelSelection === 'constant' ? urlLabel : propUrlLabel,
- description: altText === 'constant' ? altTextOfImage : propaltTextOfImage,
- src: value
- };
- const onClick = () => {
- setImages([imgDescription]);
- };
- const onItemDownload = async (id) => {
- const a = document.createElement('a');
- a.href = await fetch(images[0].src)
- .then((response) => {
- return response.blob();
- })
- .then((blob) => {
- return URL.createObjectURL(blob);
- });
- a.download = images?.find((image) => image.id === id)?.name ?? id;
- document.body.appendChild(a);
- a.click();
- document.body.removeChild(a);
- };
- let btnVal = value;
- btnVal = urlLabelVal(urlLabelSelection, btnVal, urlLabel, propUrlLabel);
- imageDisplayComp = (
-
- {btnVal !== null && (
-
- {btnVal}
-
- )}
- {images && (
- {
- setImages(null);
- demoButtonRef.current?.focus();
- }}
- onItemDownload={isImage(images[0].src) ? onItemDownload : undefined}
- />
- )}
-
- );
- return imageDisplayComp;
-};
-
-export const textFormatter = (formatter,value) => {
- let displayComponent = null;
- switch(formatter){
- case "TextInput" : {
- displayComponent = value;
- break;
- }
- case "Email" : {
- displayComponent = ( );
- break;
- }
- case "Phone" : {
- displayComponent = ( );
- break;
- }
- case "URL" : {
- displayComponent = ( );
- break;
- }
- // no default
- }
- return displayComponent;
-};
-
-/**
- * Returns a URL display component based on the options
- * @function urlFormatter
- * @param {string} value value
- * @param {object} options options for formatting
- * { displayAs,tableDisplayAs,isTableFormatter,altText,altTextOfImage,propaltTextOfImage,urlLabelSelection, urlLabel,propUrlLabel, widthSel, customWidth}
- */
-export const urlFormatter = (value, options) => {
- const {
- displayAs,
- tableDisplayAs,
- isTableFormatter,
- altText,
- altTextOfImage,
- propaltTextOfImage,
- urlLabelSelection,
- urlLabel,
- propUrlLabel,
- widthSel,
- customWidth
- } = options;
-
- let urlFormatComp = null;
- if (
- (displayAs === 'labelText' || (isTableFormatter && tableDisplayAs === 'link')) &&
- (urlLabel !== '' || propUrlLabel !== '')
- ) {
- urlFormatComp = (
-
- );
- } else if ((displayAs === 'Image' || tableDisplayAs === 'Image') && !!value) {
- if (isTableFormatter) {
- urlFormatComp = TableImage({
- value,
- altText,
- altTextOfImage,
- propaltTextOfImage,
- urlLabelSelection,
- urlLabel,
- propUrlLabel
- });
- } else {
- const width = widthSel === 'widthpx' ? customWidth : null;
- urlFormatComp = (
-
- );
- }
- } else {
- urlFormatComp = ;
- }
- return urlFormatComp;
-};
diff --git a/tests/assets/components/createAll/custom-constellation/field/_field.md b/tests/assets/components/createAll/custom-constellation/field/_field.md
deleted file mode 100644
index da26dc3e..00000000
--- a/tests/assets/components/createAll/custom-constellation/field/_field.md
+++ /dev/null
@@ -1,5 +0,0 @@
-# The **custom-constellation/field** directory
-
-The **src/components/custom-constellation/field** directory contains the code for the Constellation-based associated component for any custom **field** component you have created for use with the **Angular SDK**.
-
-For each component in the **src/components/custom-constellation/field** directory, there will be a matching component in the **src/components/custom-sdk/field** directory.
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/OneColumnDetails.svg b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/OneColumnDetails.svg
deleted file mode 100644
index f5659c9f..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/OneColumnDetails.svg
+++ /dev/null
@@ -1,22 +0,0 @@
-
-
- 1 col
-
-
-
-
-
-
-
-
-
-
-
-
- A
-
-
-
-
-
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/StatusWork.jsx b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/StatusWork.jsx
deleted file mode 100644
index 4c6c2b48..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/StatusWork.jsx
+++ /dev/null
@@ -1,26 +0,0 @@
-import { Status } from "@pega/cosmos-react-core";
-
-export default function StatusWorkRenderer({ value }) {
- let variant = "info";
-
- const warnStrings = ["fail", "cancel", "reject", "revoke", "stopped", "warn"];
- const infoStrings = ["open", "hold", "info", "new"];
- const successStrings = ["resolved", "completed", "success"];
- const pendingStrings = ["pending"];
-
- if (new RegExp(warnStrings.join("|"), "i").test(value)) {
- variant = "warn";
- } else if (new RegExp(infoStrings.join("|"), "i").test(value)) {
- variant = "info";
- } else if (new RegExp(successStrings.join("|"), "i").test(value)) {
- variant = "success";
- } else if (new RegExp(pendingStrings.join("|"), "i").test(value)) {
- variant = "pending";
- }
-
- return (
-
- {value}
-
- );
-}
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/demo.stories.jsx
deleted file mode 100644
index aa582cff..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/demo.stories.jsx
+++ /dev/null
@@ -1,132 +0,0 @@
-import { Text, FieldValueList, Button, DateTimeDisplay, useTheme } from '@pega/cosmos-react-core';
-import PegaDxilMyDetails from './index';
-import { pyReviewRaw, pyReviewResolved, regionChildrenResolved } from './mock.stories';
-import StatusWorkRenderer from './StatusWork.jsx';
-
-export default {
- title: 'PegaDxilMyDetails',
- component: PegaDxilMyDetails
-};
-
-const renderField = resolvedProps => {
- const {
- displayAsStatus = false,
- displayMode,
- value = '',
- label = '',
- key,
- // eslint-disable-next-line react-hooks/rules-of-hooks
- theme = useTheme()
- } = resolvedProps;
-
- const variant = displayMode === 'LABELS_LEFT' ? 'inline' : 'stacked';
-
- let val =
- value !== '' ? (
-
- {value}
-
- ) : (
- ''
- );
-
- if (label === 'Create date/time')
- val = (
-
- );
-
- if (displayAsStatus === true) val = ;
-
- if (label === 'Create Operator')
- val = (
-
- {value.userName}
-
- );
-
- if (variant === 'inline') {
- val = value || (
-
- ––
-
- );
- } else {
- val = (
-
- {val}
-
- );
- }
- return ;
-};
-
-export const basePegaDxilMyDetails = () => {
- const props = {
- template: 'MyCo_MyComponents_NewDetailsTemplate',
- showHighlightedData: true,
- label: 'Test Details',
- showLabel: true,
- getPConnect: () => {
- return {
- getChildren: () => {
- return pyReviewRaw.children;
- },
- getRawMetadata: () => {
- return pyReviewRaw;
- },
- getInheritedProps: () => {
- return pyReviewRaw.config.inheritedProps;
- },
- createComponent: config => {
- // eslint-disable-next-line default-case
- switch (config.config.value) {
- case '@P .pyStatusWork':
- return renderField(pyReviewResolved.highlightedData[0].config);
- case '@P .pyID':
- return renderField(pyReviewResolved.highlightedData[1].config);
- case '@P .pxCreateDateTime':
- return renderField(pyReviewResolved.highlightedData[2].config);
- case '@USER .pxCreateOperator':
- return renderField(pyReviewResolved.highlightedData[3].config);
- case '@P .pySLADeadline':
- return renderField(regionChildrenResolved[0]);
- case '@P .pySLAGoal':
- return renderField(regionChildrenResolved[1]);
- case '@P .pySLAStartTime':
- return renderField(regionChildrenResolved[2]);
- }
- },
- setInheritedProp: () => {
- /* nothing */
- },
- resolveConfigProps: () => {
- /* nothing */
- }
- };
- }
- };
-
- const regionAChildren = pyReviewRaw.children[0].children.map(child => {
- return props.getPConnect().createComponent(child);
- });
-
- return (
- <>
- {regionAChildren}
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/index.jsx b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/index.jsx
deleted file mode 100644
index a9dec67e..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/index.jsx
+++ /dev/null
@@ -1,83 +0,0 @@
-import { Fragment } from 'react';
-import { Grid, Flex, FieldGroup } from '@pega/cosmos-react-core';
-import PropTypes from 'prop-types';
-
-import StyledPegaDxilMyDetailsWrapper from './styles';
-
-// includes in bundle
-import { getAllFields } from './utils';
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-export default function PegaDxilMyDetails(props) {
-
- const { getPConnect, children, label, showLabel, showHighlightedData } = props;
- const propsToUse = { label, showLabel, ...getPConnect().getInheritedProps() };
-
- const numRegions = getAllFields(getPConnect)?.length;
- const gridRepeat = "repeat(".concat(numRegions).concat(", 1fr)");
- const gridContainer = { "colGap": 1};
- gridContainer.cols = gridRepeat;
- gridContainer.alignItems = 'start';
-
- const gridHighlightContainer = { "gap": 2};
- gridHighlightContainer.cols = gridRepeat;
- gridHighlightContainer.alignItems = 'start';
- gridHighlightContainer.pad = [0, 0, 2, 0];
-
- // Set up highlighted data to pass in return if is set to show, need raw metadata to pass to createComponent
- let highlightedDataArr = [];
- if (showHighlightedData) {
- const { highlightedData = [] } = getPConnect().getRawMetadata().config;
- highlightedDataArr = highlightedData.map((field) => {
- field.config.displayMode = 'STACKED_LARGE_VAL';
-
- // Mark as status display when using pyStatusWork
- if (field.config.value === '@P .pyStatusWork') {
- field.type = 'TextInput';
- field.config.displayAsStatus = true;
- }
-
- return getPConnect().createComponent(field);
- });
- }
-
- return (
-
-
- {showHighlightedData && highlightedDataArr.length > 0 && (
-
- {highlightedDataArr.map((child, i) => (
- {child}
- ))}
-
- )}
-
- {children.map((child, i) => (
-
- {child}
-
- ))}
-
-
-
- );
-
-}
-
-PegaDxilMyDetails.defaultProps = {
- label: undefined,
- showLabel: true,
- showHighlightedData: false
-};
-
-
-PegaDxilMyDetails.propTypes = {
- showLabel: PropTypes.bool,
- label: PropTypes.string,
- getPConnect: PropTypes.func.isRequired,
- showHighlightedData: PropTypes.bool
-};
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/mock.stories.js b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/mock.stories.js
deleted file mode 100644
index 17ed81cb..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/mock.stories.js
+++ /dev/null
@@ -1,189 +0,0 @@
-export const pyReviewRaw = {
- name: 'pyReview',
- type: 'View',
- config: {
- template: 'Details',
- ruleClass: 'MyCo-MyCompon-Work-MyComponents',
- showLabel: true,
- label: '@L Details',
- localeReference: '@LR MYCO-MYCOMPON-WORK-MYCOMPONENTS!VIEW!PYREVIEW',
- showHighlightedData: true,
- highlightedData: [
- {
- type: 'TextInput',
- config: {
- value: '@P .pyStatusWork',
- label: '@L Work Status',
- displayMode: 'STACKED_LARGE_VAL',
- displayAsStatus: true,
- key: 'pyStatusWork'
- }
- },
- {
- type: 'TextInput',
- config: {
- value: '@P .pyID',
- label: '@L Case ID',
- displayMode: 'STACKED_LARGE_VAL',
- key: 'pyID'
- }
- },
- {
- type: 'DateTime',
- config: {
- value: '@P .pxCreateDateTime',
- label: '@L Create date/time',
- displayMode: 'STACKED_LARGE_VAL',
- key: 'pxCreateDateTime'
- }
- },
- {
- type: 'UserReference',
- config: {
- label: '@L Create Operator',
- value: '@USER .pxCreateOperator',
- placeholder: 'Select...',
- displayMode: 'STACKED_LARGE_VAL',
- key: 'pxCreateOperator'
- }
- }
- ],
- inheritedProps: [
- {
- prop: 'label',
- value: '@L Details'
- },
- {
- prop: 'showLabel',
- value: true
- }
- ]
- },
- children: [
- {
- name: 'A',
- type: 'Region',
- getPConnect: () => {
- return {
- getRawMetadata: () => {
- return pyReviewRaw.children[0];
- }
- };
- },
- children: [
- {
- type: 'DateTime',
- config: {
- value: '@P .pySLADeadline',
- label: '@L SLA Deadline'
- },
- key: '1'
- },
- {
- type: 'DateTime',
- config: {
- value: '@P .pySLAGoal',
- label: '@L SLA Goal'
- },
- key: '2'
- },
- {
- type: 'RadioButtons',
- config: {
- value: '@P .pySLAStartTime',
- label: '@L SLA Start Time',
- listType: 'associated',
- datasource: '@ASSOCIATED .pySLAStartTime'
- },
- key: '3'
- }
- ]
- }
- ],
- classID: 'MyCo-MyCompon-Work-MyComponents'
-};
-
-export const pyReviewResolved = {
- readOnly: true,
- template: 'Details',
- ruleClass: 'MyCo-MyCompon-Work-MyComponents',
- showLabel: true,
- label: 'Details',
- localeReference: 'MYCO-MYCOMPON-WORK-MYCOMPONENTS!VIEW!PYREVIEW',
- showHighlightedData: true,
- highlightedData: [
- {
- type: 'TextInput',
- config: {
- value: 'New',
- label: 'Work Status',
- displayMode: 'STACKED_LARGE_VAL',
- displayAsStatus: true
- }
- },
- {
- type: 'TextInput',
- config: {
- value: 'M-1002',
- label: 'Case ID',
- displayMode: 'STACKED_LARGE_VAL'
- }
- },
- {
- type: 'DateTime',
- config: {
- value: '2022-12-11T20:06:27.232Z',
- label: 'Create date/time',
- displayMode: 'STACKED_LARGE_VAL'
- }
- },
- {
- type: 'UserReference',
- config: {
- label: 'Create Operator',
- value: {
- userId: 'conns',
- userName: 'Sara Connor'
- },
- placeholder: 'Select...',
- displayMode: 'STACKED_LARGE_VAL'
- }
- }
- ],
- displayMode: 'LABELS_LEFT'
-};
-
-export const regionChildrenResolved = [
- {
- readOnly: true,
- value: '',
- label: 'SLA Deadline',
- displayMode: 'LABELS_LEFT',
- key: 'SLA Deadline'
- },
- {
- readOnly: true,
- value: '',
- label: 'SLA Goal',
- displayMode: 'LABELS_LEFT',
- key: 'SLA Goal'
- },
- {
- readOnly: true,
- value: '',
- label: 'SLA Start Time',
- listType: 'associated',
- datasource: [
- {
- key: 'AssignmentCreation',
- value: 'The creation time of the Assignment'
- },
- {
- key: 'CurrentTime',
- value: 'Current Date Time'
- }
- ],
- displayMode: 'LABELS_LEFT',
- key: 'SLA Start Time'
- }
-];
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/styles.js b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/utils.js b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/utils.js
deleted file mode 100644
index 2a91cc0f..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyDetails/utils.js
+++ /dev/null
@@ -1,152 +0,0 @@
-/* eslint-disable no-undef */
-
-/**
- * Given the PConnect object of a Template component, retrieve the children
- * metadata of all regions.
- * @param {Function} pConnect PConnect of a Template component.
- */
-export function getAllFields(pConnect) {
- const metadata = pConnect().getRawMetadata();
- if (!metadata.children) {
- return [];
- }
-
- let allFields = [];
-
- const makeField = (f) => ({
- ...pConnect().resolveConfigProps(f.config),
- type: f.type
- });
-
- const hasRegions = !!metadata.children[0]?.children;
- if (hasRegions) {
- allFields = metadata.children.map((region) =>
- region.children.map((field) => {
- // Do not resolve the config props if is status work, instead create component here as status badge and mark as status display
- if (field.config?.value === '@P .pyStatusWork') {
- field.type = 'TextInput';
- field.config.displayAsStatus = true;
- return pConnect().createComponent(field);
- }
-
- return makeField(field);
- })
- );
- } else {
- allFields = metadata.children.map(makeField);
- }
-
- return allFields;
-}
-
-
-
-export function getFilteredFields(getPConnect) {
- let primaryFieldsRaw;
- let secondaryFieldsRaw;
- const metadata = getPConnect().getRawMetadata();
- const hasRegions = !!metadata.children[0]?.children;
- if (hasRegions) {
- primaryFieldsRaw = metadata.children[0].children;
- secondaryFieldsRaw = metadata.children[1].children;
- } else {
- [primaryFieldsRaw, secondaryFieldsRaw] = metadata.children;
- }
-
- // Filter out fields that are not visible and unsupported types for primary fields (for CaseSummary)
- primaryFieldsRaw = primaryFieldsRaw.filter((item) => {
- const resolvedItem = getPConnect().resolveConfigProps(item.config);
- return resolvedItem.visibility !== false && item.type !== 'TextContent';
- });
-
- secondaryFieldsRaw = secondaryFieldsRaw.filter((item) => {
- const resolvedItem = getPConnect().resolveConfigProps(item.config);
- return resolvedItem.visibility !== false && item.type !== 'TextContent';
- });
-
- return [primaryFieldsRaw, secondaryFieldsRaw];
-}
-
-/**
- * Returns ConfigurableLayout mapped content. With pre-populated default layout configs.
- * @param {object[]} regionData template children item.
- * @returns {object[]} ConfigurableLayout content.
- */
-export function getLayoutDataFromRegion(regionData) {
- const defaultLayoutConfig = {
- width: 'full',
- fillAvailable: true,
- minWidth: [300, 'px']
- };
-
- return regionData.props
- ?.getPConnect()
- ?.getChildren()
- ?.map((item, index) => {
- const itemPConnect = item?.getPConnect();
-
- return {
- id: itemPConnect?.getComponentName() ? `${itemPConnect.getComponentName()}--${index}` : `item--${index}`,
- content: itemPConnect?.getComponent(),
- layoutConfig: {
- ...defaultLayoutConfig,
- ...itemPConnect?.getConfigProps().layoutConfig
- }
- };
- });
-}
-
-/**
- * Determine if the current view is the view of the case step/assignment.
- * @param {Function} pConnect PConnect object for the component
- */
-export function getIsAssignmentView(pConnect) {
- // Get caseInfo content from the store which contains the view info about the current assignment/step
- // TODO To be replaced with pConnect.getCaseInfo().getCurrentAssignmentView when it's available
- const assignmentViewClass = pConnect.getValue(PCore.getConstants().CASE_INFO.CASE_INFO_CLASSID);
- const assignmentViewName = pConnect.getValue(PCore.getConstants().CASE_INFO.ASSIGNMENTACTION_ID);
-
- const assignmentViewId = `${assignmentViewName}!${assignmentViewClass}`;
-
- // Get the info about the current view from pConnect
- const currentViewId = `${pConnect.getCurrentView()}!${pConnect.getCurrentClassID()}`;
-
- return assignmentViewId === currentViewId;
-}
-
-/**
- * A hook that gets the instructions content for a view.
- * @param {Function} pConnect PConnect object for the component
- * @param {string} [instructions="casestep"] 'casestep', 'none', or the html content of a Rule-UI-Paragraph rule (processed via core's paragraph annotation handler)
- */
-export function getInstructions(pConnect, instructions = 'casestep') {
- const caseStepInstructions = pConnect.getValue(PCore.getConstants().CASE_INFO.INSTRUCTIONS);
-
- // Determine if this view is the current assignment/step view
- const isCurrentAssignmentView = getIsAssignmentView(pConnect);
-
- // Case step instructions
- if (instructions === 'casestep' && isCurrentAssignmentView && caseStepInstructions?.length) {
- return caseStepInstructions;
- }
-
- // No instructions
- if (instructions === 'none') {
- return undefined;
- }
-
- // If the annotation wasn't processed correctly, don't return any instruction text
- if (instructions?.startsWith('@PARAGRAPH')) {
- /* eslint-disable no-console */
- console.error('@PARAGRAPH annotation was not processed. Hiding custom instructions.');
- /* eslint-enable no-console */ return undefined;
- }
-
- // Custom instructions from the view
- // The raw metadata for `instructions` will be something like '@PARAGRAPH .SomeParagraphRule' but
- // it is evaluated by core logic to the content
- if (instructions !== 'casestep' && instructions !== 'none') {
- return instructions;
- }
- return undefined;
-}
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyForm/DefaultForm.svg b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyForm/DefaultForm.svg
deleted file mode 100644
index 9fe86e70..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyForm/DefaultForm.svg
+++ /dev/null
@@ -1,29 +0,0 @@
-
-
- 2 col copy
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyForm/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyForm/demo.stories.jsx
deleted file mode 100644
index 1556bcbf..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyForm/demo.stories.jsx
+++ /dev/null
@@ -1,166 +0,0 @@
-/* eslint-disable react-hooks/rules-of-hooks */
-import { useState } from 'react';
-import { withKnobs } from '@storybook/addon-knobs';
-
-import PegaDxilMyForm from './index.jsx';
-import { DateInput, Input, FieldValueList, Text } from '@pega/cosmos-react-core';
-import { PhoneInput as CosmosPhone } from '@pega/cosmos-react-core';
-import { pyReviewRaw, regionChildrenResolved } from './mock.stories';
-
-export default {
- title: 'PegaDxilMyForm',
- decorators: [withKnobs],
- component: PegaDxilMyForm
-};
-
-const renderField = resolvedProps => {
- const { displayMode, value = '', label = '', key } = resolvedProps;
-
- const [inputValue, setInputValue] = useState(value);
- const [phoneValue, setPhoneValue] = useState('+16397975093');
-
- const variant = displayMode === 'LABELS_LEFT' ? 'inline' : 'stacked';
-
- let val =
- value !== '' ? (
- {
- setInputValue(e.target.value);
- }}
- >
- {inputValue}
-
- ) : (
- ''
- );
-
-
- if (label === 'Service Date')
- val = (
- {
- const { valueAsISOString: date } = dateValue;
- const trimmedDate = date ? date.substring(0, date.indexOf('T')) : date;
- setInputValue(trimmedDate);
- }}
- >
- );
-
- if (label === 'Email')
- val = (
- {
- setInputValue(e.target.value);
- }}
- >
- );
-
- if (label === 'First Name' || label === 'Last Name' || label === 'Middle Name')
- val = (
- {
- setInputValue(e.target.value);
- }}
- >
- );
-
- if (label === 'Phone Number')
- val = (
- {
- setPhoneValue(phoneVal);
- }}
- >
- );
-
-
- if (variant === 'inline') {
- val = value || (
- {
- setInputValue(e.target.value);
- }}
- >
- ––
-
- );
- } else {
- val = (
- {
- setInputValue(e.target.value);
- }}
- >
- {val}
-
- );
- }
- return (
-
- );
-};
-
-export const basePegaDxilMyForm = () => {
- const props = {
- NumCols: 1,
- template: 'DefaultForm',
- getPConnect: () => {
- return {
- getChildren: () => {
- return pyReviewRaw.children;
- },
- createComponent: config => {
- // eslint-disable-next-line default-case
- switch (config.config.value) {
- case '@P .FirstName':
- return renderField(regionChildrenResolved[0]);
- case '@P .MiddleName':
- return renderField(regionChildrenResolved[1]);
- case '@P .LastName':
- return renderField(regionChildrenResolved[2]);
- case '@P .Email':
- return renderField(regionChildrenResolved[3]);
- case '@P .PhoneNumber':
- return renderField(regionChildrenResolved[4]);
- case '@P .ServiceDate':
- return renderField(regionChildrenResolved[5]);
- }
- }
- };
- }
- };
-
- const regionAChildren = pyReviewRaw.children[0].children.map(child => {
- return props.getPConnect().createComponent(child);
- });
-
- return (
- <>
- {regionAChildren}
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyForm/index.jsx b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyForm/index.jsx
deleted file mode 100644
index 021863d5..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyForm/index.jsx
+++ /dev/null
@@ -1,42 +0,0 @@
-import { Grid } from '@pega/cosmos-react-core';
-import PropTypes from 'prop-types';
-
-import StyledPegaDxilMyFormWrapper from './styles';
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-export default function PegaDxilMyForm(props) {
-
-
- const { children, NumCols } = props;
-
- const nCols = parseInt(NumCols, 10);
-
- // console.log(`Rendering ${getPConnect()?.getComponentName()} with ${template} with ${children?.length} Region(s)`);
-
- return (
-
-
- {children}
-
-
- );
-
-}
-
-PegaDxilMyForm.defaultProps = {
- NumCols: 1,
- children: []
-};
-
-PegaDxilMyForm.propTypes = {
- NumCols: PropTypes.number,
- children: PropTypes.arrayOf(PropTypes.node),
-};
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyForm/mock.stories.js b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyForm/mock.stories.js
deleted file mode 100644
index 75a0941e..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyForm/mock.stories.js
+++ /dev/null
@@ -1,137 +0,0 @@
-export const pyReviewRaw = {
- name: 'CollectInformation',
- type: 'View',
- config: {
- template: 'DefaultForm',
- ruleClass: 'OM5W9U-SampleApp-Work-Test',
- localeReference: '@LR OM5W9U-SAMPLEAPP-WORK-TEST!VIEW!COLLECTINFORMATION',
- context: '@P .pyViewContext'
- },
- children: [
- {
- name: 'Fields',
- type: 'Region',
- children: [
- {
- type: 'TextInput',
- config: {
- value: '@P .FirstName',
- label: '@L First Name',
- key: 'FirstName'
- }
- },
- {
- type: 'TextInput',
- config: {
- value: '@P .MiddleName',
- label: '@L Middle Name',
- key: 'MiddleName'
- }
- },
- {
- type: 'TextInput',
- config: {
- value: '@P .LastName',
- label: '@L Last Name',
- key: 'LastName'
- }
- },
- {
- type: 'Email',
- config: {
- value: '@P .Email',
- label: '@L Email',
- key: 'Email'
- }
- },
- {
- type: 'Phone',
- config: {
- value: '@P .PhoneNumber',
- label: '@L Phone Number',
- datasource: {
- source: '@DATASOURCE D_pyCountryCallingCodeList.pxResults',
- fields: {
- value: '@P .pyCallingCode'
- }
- },
- key: 'PhoneNumber'
- }
- },
- {
- type: 'Date',
- config: {
- value: '@P .ServiceDate',
- label: '@L Service Date',
- key: 'ServiceDate'
- }
- }
- ]
- }
- ],
- classID: 'OM5W9U-SampleApp-Work-Test'
-};
-
-export const regionChildrenResolved = [
- {
- readOnly: undefined,
- value: 'John',
- label: 'First Name',
- hasSuggestions: false,
- key: 'firstName'
- },
- {
- readOnly: undefined,
- value: '',
- label: 'Middle Name',
- hasSuggestions: false,
- key: 'middleName'
- },
- {
- readOnly: undefined,
- value: 'Doe',
- label: 'Last Name',
- hasSuggestions: false,
- key: 'lastName'
- },
- {
- readOnly: undefined,
- value: 'John@doe.com',
- label: 'Email',
- hasSuggestions: false,
- key: 'email'
- },
- {
- readOnly: undefined,
- value: '+16397975093',
- label: 'Phone Number',
- datasource: {
- fields: {
- value: undefined
- },
- source: [
- {
- value: '+1'
- },
- {
- value: '+91'
- },
- {
- value: '+48'
- },
- {
- value: '+44'
- }
- ]
- },
- hasSuggestions: false,
- key: 'phoneNumber'
- },
- {
- readOnly: undefined,
- value: '2023-01-25',
- label: 'Service Date',
- hasSuggestions: false,
- key: 'serviceDate'
- }
-];
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyForm/styles.js b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyForm/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyForm/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/GetNextWork.jsx b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/GetNextWork.jsx
deleted file mode 100644
index 5c04e519..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/GetNextWork.jsx
+++ /dev/null
@@ -1,35 +0,0 @@
-/* eslint-disable no-undef */
-import { Button, useToaster } from '@pega/cosmos-react-core';
-
-export default function GetNextWork(props) {
- const { getPConnect, variant } = props;
-
- const toasterCtx = useToaster();
-
- const localizedVal = PCore.getLocaleUtils().getLocaleValue;
-
- const getNextWork = () => {
-
- // alert('Get next work clicked');
-
- getPConnect()
- .getActionsApi()
- .getNextWork()
- .catch((err) => {
- /* eslint-disable no-console */
- console.log(err);
- /* eslint-enable no-console */
- if (err[0].status === 404) {
- toasterCtx.push({
- content: localizedVal('No task currently available')
- });
- }
- });
- };
-
- return (
-
- {getPConnect().getLocalizedValue('Get next work')}
-
- );
-}
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/OneColumnPage.svg b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/OneColumnPage.svg
deleted file mode 100644
index 5f2dec97..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/OneColumnPage.svg
+++ /dev/null
@@ -1,36 +0,0 @@
-
-
- 1 col
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- A
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/demo.stories.jsx
deleted file mode 100644
index 5d408efd..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/demo.stories.jsx
+++ /dev/null
@@ -1,102 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-
-import { AppAnnouncement as PegaAppAnnouncement } from '@pega/cosmos-react-work';
-
-import PegaDxilMyPage from './index.jsx';
-import { pyHome1Resolved, pyHome1Raw } from './mock.stories.js';
-
-export default {
- title: 'PegaDxilMyPage',
- decorators: [withKnobs],
- component: PegaDxilMyPage
-};
-
-export const basePegaDxilMyPage = () => {
- if (!window.PCore) {
- window.PCore = {};
- }
-
- window.PCore.getLocaleUtils = () => {
- return {
- getLocaleValue: val => {
- return val;
- }
- };
- };
-
- const configProps = pyHome1Resolved.children[0].children[0].config;
-
- const props = {
- useConfigurableLayout: false,
- enableGetNextWork: pyHome1Raw.config.enableGetNextWork,
- icon: pyHome1Raw.config.icon,
- title: 'Page Template',
-
- getPConnect: () => {
- return {
- getStateProps: () => {
- return {};
- },
- getActionsApi: () => {
- return {
- getNextWork: () => {
- return new Promise(resolve => {
- resolve({});
- });
- },
- updateFieldValue: () => {/* nothing */},
- triggerFieldChange: () => {/* nothing */}
- };
- },
- getChildren: () => {
- return pyHome1Raw.children;
- },
- getComponentName: () => {
- return '';
- },
- getLocalizedValue: value => {
- return value;
- },
- getRawMetadata: () => {
- return pyHome1Raw;
- },
- createComponent: config => {
- if (config.type === 'AppAnnouncement') {
- return (
- {
- return {
- getChildren: () => {
- return pyHome1Resolved.children;
- }
- };
- }}
- />
- );
- }
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- setInheritedProps: () => {/* nothing */},
- resolveConfigProps: () => {/* nothing */}
- };
- }
- };
-
- const regionAChildren = pyHome1Raw.children[0].children.map(child => {
- return props.getPConnect().createComponent(child);
- });
-
- return (
- <>
- {regionAChildren}
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/index.jsx b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/index.jsx
deleted file mode 100644
index 89699dfc..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/index.jsx
+++ /dev/null
@@ -1,70 +0,0 @@
-import { useMemo, Children } from 'react';
-import PropTypes from 'prop-types';
-import { OneColumnPage as OneColumn } from '@pega/cosmos-react-core';
-import { ConfigurableLayout } from '@pega/cosmos-react-work'
-// import { registerIcon } from '@pega/cosmos-react-core';
-
-// temp
-// import * as headlineIcon from '@pega/cosmos-react-core/lib/components/Icon/icons/headline.icon';
-
-import StyledPegaDxilMyPageWrapper from './styles';
-
-import GetNextWork from './GetNextWork.jsx';
-import { getLayoutDataFromRegion } from './utils';
-
-// temp
-// registerIcon(headlineIcon);
-
-// currently getting 'icon' from props is not supported with iconRegistry
-// have to manually get icon, so can't determine a runtime for now
-// so "headline" icon is hardcoded.
-
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-export default function PegaDxilMyPage(props) {
-
- // add back in icon when working
- // const { children, title, icon, useConfigurableLayout, getPConnect, enableGetNextWork } = props;
- const { children, title, useConfigurableLayout, getPConnect, enableGetNextWork } = props;
- const childArray = useMemo(() => {
- return Children.toArray(children);
- }, [children]);
- const layoutItemsA = useMemo(() => {
- return getLayoutDataFromRegion(childArray[0]);
- }, [childArray[0]]);
-
- // temp
- const tempIcon = "pi pi-headline";
-
- return (
-
-
- : childArray[0]}
- title={title}
- icon={tempIcon?.replace('pi pi-', '')}
- actions={enableGetNextWork ? : null}
- />
-
-
- );
-
-
-
-}
-
-PegaDxilMyPage.defaultProps = {
- /* icon: '', */
- useConfigurableLayout: false
-};
-
-PegaDxilMyPage.propTypes = {
- children: PropTypes.arrayOf(PropTypes.node).isRequired,
- title: PropTypes.string.isRequired,
- /* icon: PropTypes.string, */
- useConfigurableLayout: PropTypes.bool
-};
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/localizations.json b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/localizations.json
deleted file mode 100644
index 8e13d22a..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/localizations.json
+++ /dev/null
@@ -1,4 +0,0 @@
-{
- "Get next work" : "Get next work",
- "No task currently available" : "No task currently available"
-}
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/mock.stories.js b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/mock.stories.js
deleted file mode 100644
index 7659742d..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/mock.stories.js
+++ /dev/null
@@ -1,94 +0,0 @@
-export const pyHome1Raw = {
- name: 'pyHome1',
- type: 'View',
- config: {
- type: 'landingpage',
- template: 'OneColumnPage',
- icon: 'home-solid',
- title: '@ENV APPLICATION_DESC',
- ruleClass: 'DIXL-MediaCo-UIPages',
- localeReference: '@LR DIXL-MEDIACO-UIPAGES!PAGE!PYHOME1',
- enableGetNextWork: true,
- context: 'pyPortal'
- },
- children: [
- {
- name: 'A',
- type: 'Region',
- children: [
- {
- type: 'AppAnnouncement',
- config: {
- label: '@L App announcement',
- description:
- "We've launched a brand new experience to accelerate your workflow. Check out the guides to help you get the most of Cosmos.",
- whatsnewlink: 'https://design.pega.com',
- image:
- '',
- datasource: {
- source: '@DATASOURCE D_pyAnnouncements.pxResults',
- fields: {
- name: '@P .pyLabel'
- }
- }
- }
- }
- ]
- }
- ],
- classID: 'DIXL-MediaCo-UIPages'
-};
-
-export const pyHome1Resolved = {
- name: 'pyHome1',
- type: 'View',
- config: {
- type: 'landingpage',
- template: 'OneColumnPage',
- icon: 'home-solid',
- title: '@ENV APPLICATION_DESC',
- ruleClass: 'DIXL-MediaCo-UIPages',
- localeReference: '@LR DIXL-MEDIACO-UIPAGES!PAGE!PYHOME1',
- enableGetNextWork: true,
- context: 'pyPortal'
- },
- children: [
- {
- name: 'A',
- type: 'Region',
- getPConnect: () => {
- return {
- getComponentName: () => {
- return '';
- },
- getComponent: () => {
- return pyHome1Resolved.children[0];
- },
- getConfigProps: () => {
- return {};
- }
- };
- },
- children: [
- {
- type: 'AppAnnouncement',
- config: {
- label: '@L App announcement',
- description:
- "We've launched a brand new experience to accelerate your workflow. Check out the guides to help you get the most of Cosmos.",
- whatsnewlink: 'https://design.pega.com',
- image:
- '',
- datasource: {
- source: '@DATASOURCE D_pyAnnouncements.pxResults',
- fields: {
- name: '@P .pyLabel'
- }
- }
- }
- }
- ]
- }
- ],
- classID: 'DIXL-MediaCo-UIPages'
-};
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/styles.js b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/utils.js b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/utils.js
deleted file mode 100644
index e088c3aa..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyPage/utils.js
+++ /dev/null
@@ -1,229 +0,0 @@
-/* eslint-disable no-undef */
-import { createUID } from '@pega/cosmos-react-core';
-
-// import { LazyMap as LazyComponentMap } from '../../components_map';
-
-const LazyComponentMap = {};
-
-/**
- * Given the PConnect object of a Template component, retrieve the children
- * metadata of all regions.
- * @param {Function} pConnect PConnect of a Template component.
- */
-export function getAllFields(pConnect) {
- const metadata = pConnect().getRawMetadata();
- if (!metadata.children) {
- return [];
- }
-
- let allFields = [];
-
- const makeField = (f) => ({
- ...pConnect().resolveConfigProps(f.config),
- type: f.type
- });
-
- const hasRegions = !!metadata.children[0]?.children;
- if (hasRegions) {
- allFields = metadata.children.map((region) =>
- region.children.map((field) => {
- // Do not resolve the config props if is status work, instead create component here as status badge and mark as status display
- if (field.config?.value === '@P .pyStatusWork') {
- field.type = 'TextInput';
- field.config.displayAsStatus = true;
- return pConnect().createComponent(field);
- }
-
- return makeField(field);
- })
- );
- } else {
- allFields = metadata.children.map(makeField);
- }
-
- return allFields;
-}
-
-/**
- * A helper function to create an object consisting react component as per the type.
- * This is used by CaseSummary template.
- * @param {object} configObject Object containing meta information for the particular field authored
- * @param {Function} getPConnect PConnect function passed along to other components.
- * @param {string} displayMode displayMode string contains information about the layout of component in review mode.
- */
-export function prepareComponentInCaseSummary(configObject, getPConnect, displayMode) {
- const { config, children } = configObject;
- let { type } = configObject;
- const caseSummaryComponentObject = {};
- let showAddressLabel = true;
- if (config && config.value === '@P .pyStatusWork') {
- config.displayAsStatus = true;
- type = 'TextInput'; // force the type to be TextInput for status field.
- // As TextInput is loaded forcefully sometimes, TextInput component might not be available in lazy map.
- // Load TextInput if it is not available.
- if (!LazyComponentMap[type]) {
- PCore.getAssetLoader().getLoader('component-loader')([type]);
- }
- }
-
- caseSummaryComponentObject.name = getPConnect().resolveConfigProps({
- label: config.label
- }).label;
- if (type === 'CaseOperator') {
- switch (caseSummaryComponentObject.name) {
- case 'Create operator':
- caseSummaryComponentObject.name = getPConnect().resolveConfigProps({
- createLabel: config.createLabel
- }).createLabel;
- break;
- case 'Update operator':
- caseSummaryComponentObject.name = getPConnect().resolveConfigProps({
- updateLabel: config.updateLabel
- }).updateLabel;
- break;
- default:
- caseSummaryComponentObject.name = getPConnect().resolveConfigProps({
- resolveLabel: config.resolveLabel
- }).resolveLabel;
- break;
- }
- } else if (type === 'Checkbox') {
- caseSummaryComponentObject.name = getPConnect().resolveConfigProps({
- label: config.caption
- }).label;
- } else if (type === 'Address') {
- showAddressLabel = false;
- }
- const createdComponent = getPConnect().createComponent({
- type,
- children: children ? [...children] : [],
- showAddressLabel,
- config: {
- ...config,
- hideLabel: true,
- key: createUID() // Need a unique key on render of the summary so that the component is recreated each time
- }
- });
- createdComponent.props.getPConnect().setInheritedProp('displayMode', displayMode);
- if (type === 'Address') {
- createdComponent.props.getPConnect().setInheritedProp('showAddressLabel', showAddressLabel);
- }
- // createdComponent.props.getPConnect().setInheritedProp("hideLabel", true);
- caseSummaryComponentObject.value = createdComponent;
- if (type === 'reference') {
- caseSummaryComponentObject.name = createdComponent.props.getPConnect().getInheritedProps().label;
- }
-
- return caseSummaryComponentObject;
-}
-
-export function getFilteredFields(getPConnect) {
- let primaryFieldsRaw;
- let secondaryFieldsRaw;
- const metadata = getPConnect().getRawMetadata();
- const hasRegions = !!metadata.children[0]?.children;
- if (hasRegions) {
- primaryFieldsRaw = metadata.children[0].children;
- secondaryFieldsRaw = metadata.children[1].children;
- } else {
- [primaryFieldsRaw, secondaryFieldsRaw] = metadata.children;
- }
-
- // Filter out fields that are not visible and unsupported types for primary fields (for CaseSummary)
- primaryFieldsRaw = primaryFieldsRaw.filter((item) => {
- const resolvedItem = getPConnect().resolveConfigProps(item.config);
- return resolvedItem.visibility !== false && item.type !== 'TextContent';
- });
-
- secondaryFieldsRaw = secondaryFieldsRaw.filter((item) => {
- const resolvedItem = getPConnect().resolveConfigProps(item.config);
- return resolvedItem.visibility !== false && item.type !== 'TextContent';
- });
-
- return [primaryFieldsRaw, secondaryFieldsRaw];
-}
-
-/**
- * Returns ConfigurableLayout mapped content. With pre-populated default layout configs.
- * @param {object[]} regionData template children item.
- * @returns {object[]} ConfigurableLayout content.
- */
-export function getLayoutDataFromRegion(regionData) {
- const defaultLayoutConfig = {
- width: 'full',
- fillAvailable: true,
- minWidth: [300, 'px']
- };
-
- return regionData.props
- ?.getPConnect()
- ?.getChildren()
- ?.map((item, index) => {
- const itemPConnect = item?.getPConnect();
-
- return {
- id: itemPConnect?.getComponentName() ? `${itemPConnect.getComponentName()}--${index}` : `item--${index}`,
- content: itemPConnect?.getComponent(),
- layoutConfig: {
- ...defaultLayoutConfig,
- ...itemPConnect?.getConfigProps().layoutConfig
- }
- };
- });
-}
-
-/**
- * Determine if the current view is the view of the case step/assignment.
- * @param {Function} pConnect PConnect object for the component
- */
-export function getIsAssignmentView(pConnect) {
- // Get caseInfo content from the store which contains the view info about the current assignment/step
- // TODO To be replaced with pConnect.getCaseInfo().getCurrentAssignmentView when it's available
- const assignmentViewClass = pConnect.getValue(PCore.getConstants().CASE_INFO.CASE_INFO_CLASSID);
- const assignmentViewName = pConnect.getValue(PCore.getConstants().CASE_INFO.ASSIGNMENTACTION_ID);
-
- const assignmentViewId = `${assignmentViewName}!${assignmentViewClass}`;
-
- // Get the info about the current view from pConnect
- const currentViewId = `${pConnect.getCurrentView()}!${pConnect.getCurrentClassID()}`;
-
- return assignmentViewId === currentViewId;
-}
-
-/**
- * A hook that gets the instructions content for a view.
- * @param {Function} pConnect PConnect object for the component
- * @param {string} [instructions="casestep"] 'casestep', 'none', or the html content of a Rule-UI-Paragraph rule (processed via core's paragraph annotation handler)
- */
-export function getInstructions(pConnect, instructions = 'casestep') {
- const caseStepInstructions = pConnect.getValue(PCore.getConstants().CASE_INFO.INSTRUCTIONS);
-
- // Determine if this view is the current assignment/step view
- const isCurrentAssignmentView = getIsAssignmentView(pConnect);
-
- // Case step instructions
- if (instructions === 'casestep' && isCurrentAssignmentView && caseStepInstructions?.length) {
- return caseStepInstructions;
- }
-
- // No instructions
- if (instructions === 'none') {
- return undefined;
- }
-
- // If the annotation wasn't processed correctly, don't return any instruction text
- if (instructions?.startsWith('@PARAGRAPH')) {
- /* eslint-disable no-console */
- console.error('@PARAGRAPH annotation was not processed. Hiding custom instructions.');
- /* eslint-enable no-console */
- return undefined;
- }
-
- // Custom instructions from the view
- // The raw metadata for `instructions` will be something like '@PARAGRAPH .SomeParagraphRule' but
- // it is evaluated by core logic to the content
- if (instructions !== 'casestep' && instructions !== 'none') {
- return instructions;
- }
- return undefined;
-}
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/StatusWork.jsx b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/StatusWork.jsx
deleted file mode 100644
index 4c6c2b48..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/StatusWork.jsx
+++ /dev/null
@@ -1,26 +0,0 @@
-import { Status } from "@pega/cosmos-react-core";
-
-export default function StatusWorkRenderer({ value }) {
- let variant = "info";
-
- const warnStrings = ["fail", "cancel", "reject", "revoke", "stopped", "warn"];
- const infoStrings = ["open", "hold", "info", "new"];
- const successStrings = ["resolved", "completed", "success"];
- const pendingStrings = ["pending"];
-
- if (new RegExp(warnStrings.join("|"), "i").test(value)) {
- variant = "warn";
- } else if (new RegExp(infoStrings.join("|"), "i").test(value)) {
- variant = "info";
- } else if (new RegExp(successStrings.join("|"), "i").test(value)) {
- variant = "success";
- } else if (new RegExp(pendingStrings.join("|"), "i").test(value)) {
- variant = "pending";
- }
-
- return (
-
- {value}
-
- );
-}
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/TwoColumnDetails.svg b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/TwoColumnDetails.svg
deleted file mode 100644
index 4d15fcd0..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/TwoColumnDetails.svg
+++ /dev/null
@@ -1,28 +0,0 @@
-
-
- 2 col
-
-
-
-
-
-
-
-
-
-
-
-
-
- B
-
-
-
- A
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/demo.stories.jsx
deleted file mode 100644
index bf8ae373..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/demo.stories.jsx
+++ /dev/null
@@ -1,136 +0,0 @@
-import { Text, FieldValueList, Button, DateTimeDisplay, useTheme } from '@pega/cosmos-react-core';
-import PegaDxilMyTwoColumnDetails from './index';
-import { pyReviewRaw, pyReviewResolved, regionChildrenResolved } from './mock.stories';
-import StatusWorkRenderer from './StatusWork.jsx';
-
-export default {
- title: 'PegaDxilMyTwoColumnDetails',
- component: PegaDxilMyTwoColumnDetails
-};
-
-const renderField = resolvedProps => {
- const {
- displayAsStatus = false,
- displayMode,
- value = '',
- label = '',
- key,
- // eslint-disable-next-line react-hooks/rules-of-hooks
- theme = useTheme()
- } = resolvedProps;
-
- const variant = displayMode === 'LABELS_LEFT' ? 'inline' : 'stacked';
-
- let val =
- value !== '' ? (
-
- {value}
-
- ) : (
- ''
- );
-
- if (label === 'Create date/time')
- val = (
-
- );
-
- if (displayAsStatus === true) val = ;
-
- if (label === 'Create Operator')
- val = (
-
- {value.userName}
-
- );
-
- if (variant === 'inline') {
- val = value || (
-
- ––
-
- );
- } else {
- val = (
-
- {val}
-
- );
- }
- return ;
-};
-
-export const basePegaDxilMyTwoColumnDetails = () => {
- const props = {
- template: 'MyCo_MyComponents_NewDetailsTemplate',
- showHighlightedData: true,
- label: 'Test Details',
- showLabel: true,
- getPConnect: () => {
- return {
- getChildren: () => {
- return pyReviewRaw.children;
- },
- getRawMetadata: () => {
- return pyReviewRaw;
- },
- getInheritedProps: () => {
- return pyReviewRaw.config.inheritedProps;
- },
- createComponent: config => {
- // eslint-disable-next-line default-case
- switch (config.config.value) {
- case '@P .pyStatusWork':
- return renderField(pyReviewResolved.highlightedData[0].config);
- case '@P .pyID':
- return renderField(pyReviewResolved.highlightedData[1].config);
- case '@P .pxCreateDateTime':
- return renderField(pyReviewResolved.highlightedData[2].config);
- case '@USER .pxCreateOperator':
- return renderField(pyReviewResolved.highlightedData[3].config);
- case '@P .pySLADeadline':
- return renderField(regionChildrenResolved[0]);
- case '@P .pySLAGoal':
- return renderField(regionChildrenResolved[1]);
- case '@P .pySLAStartTime':
- return renderField(regionChildrenResolved[2]);
- }
- },
- setInheritedProp: () => {
- /* nothing */
- },
- resolveConfigProps: () => {
- /* nothing */
- }
- };
- }
- };
-
- const regionAChildren = pyReviewRaw.children[0].children.map(child => {
- return props.getPConnect().createComponent(child);
- });
- const regionBChildren = pyReviewRaw.children[1].children.map(child => {
- return props.getPConnect().createComponent(child);
- });
-
- return (
-
- {regionAChildren}
- {regionBChildren}
-
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/index.jsx b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/index.jsx
deleted file mode 100644
index cf606a9b..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/index.jsx
+++ /dev/null
@@ -1,83 +0,0 @@
-import { Fragment } from 'react';
-import { Grid, Flex, FieldGroup } from '@pega/cosmos-react-core';
-import PropTypes from 'prop-types';
-
-import StyledPegaDxilMyTwoColumnDetailsWrapper from './styles';
-
-// includes in bundle
-import { getAllFields } from './utils';
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-export default function PegaDxilMyTwoColumnDetails(props) {
-
- const { getPConnect, children, label, showLabel, showHighlightedData } = props;
- const propsToUse = { label, showLabel, ...getPConnect().getInheritedProps() };
-
- const numRegions = getAllFields(getPConnect)?.length;
- const gridRepeat = "repeat(".concat(numRegions).concat(", 1fr)");
- const gridContainer = { "colGap": 1};
- gridContainer.cols = gridRepeat;
- gridContainer.alignItems = 'start';
-
- const gridHighlightContainer = { "gap": 2};
- gridHighlightContainer.cols = gridRepeat;
- gridHighlightContainer.alignItems = 'start';
- gridHighlightContainer.pad = [0, 0, 2, 0];
-
- // Set up highlighted data to pass in return if is set to show, need raw metadata to pass to createComponent
- let highlightedDataArr = [];
- if (showHighlightedData) {
- const { highlightedData = [] } = getPConnect().getRawMetadata().config;
- highlightedDataArr = highlightedData.map((field) => {
- field.config.displayMode = 'STACKED_LARGE_VAL';
-
- // Mark as status display when using pyStatusWork
- if (field.config.value === '@P .pyStatusWork') {
- field.type = 'TextInput';
- field.config.displayAsStatus = true;
- }
-
- return getPConnect().createComponent(field);
- });
- }
-
- return (
-
-
- {showHighlightedData && highlightedDataArr.length > 0 && (
-
- {highlightedDataArr.map((child, i) => (
- {child}
- ))}
-
- )}
-
- {children.map((child, i) => (
-
- {child}
-
- ))}
-
-
-
- );
-
-}
-
-PegaDxilMyTwoColumnDetails.defaultProps = {
- label: undefined,
- showLabel: true,
- showHighlightedData: false
-};
-
-
-PegaDxilMyTwoColumnDetails.propTypes = {
- showLabel: PropTypes.bool,
- label: PropTypes.string,
- getPConnect: PropTypes.func.isRequired,
- showHighlightedData: PropTypes.bool
-};
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/mock.stories.js b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/mock.stories.js
deleted file mode 100644
index 10f90839..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/mock.stories.js
+++ /dev/null
@@ -1,230 +0,0 @@
-export const pyReviewRaw = {
- name: 'pyReview',
- type: 'View',
- config: {
- template: 'Details',
- ruleClass: 'MyCo-MyCompon-Work-MyComponents',
- showLabel: true,
- label: '@L Details',
- localeReference: '@LR MYCO-MYCOMPON-WORK-MYCOMPONENTS!VIEW!PYREVIEW',
- showHighlightedData: true,
- highlightedData: [
- {
- type: 'TextInput',
- config: {
- value: '@P .pyStatusWork',
- label: '@L Work Status',
- displayMode: 'STACKED_LARGE_VAL',
- displayAsStatus: true,
- key: 'pyStatusWork'
- }
- },
- {
- type: 'TextInput',
- config: {
- value: '@P .pyID',
- label: '@L Case ID',
- displayMode: 'STACKED_LARGE_VAL',
- key: 'pyID'
- }
- },
- {
- type: 'DateTime',
- config: {
- value: '@P .pxCreateDateTime',
- label: '@L Create date/time',
- displayMode: 'STACKED_LARGE_VAL',
- key: 'pxCreateDateTime'
- }
- },
- {
- type: 'UserReference',
- config: {
- label: '@L Create Operator',
- value: '@USER .pxCreateOperator',
- placeholder: 'Select...',
- displayMode: 'STACKED_LARGE_VAL',
- key: 'pxCreateOperator'
- }
- }
- ],
- inheritedProps: [
- {
- prop: 'label',
- value: '@L Details'
- },
- {
- prop: 'showLabel',
- value: true
- }
- ]
- },
- children: [
- {
- name: 'A',
- type: 'Region',
- key: 'A',
- getPConnect: () => {
- return {
- getRawMetadata: () => {
- return pyReviewRaw.children[0];
- }
- };
- },
- children: [
- {
- type: 'DateTime',
- config: {
- value: '@P .pySLADeadline',
- label: '@L SLA Deadline',
- key: 'pySLADeadline'
- }
- },
- {
- type: 'DateTime',
- config: {
- value: '@P .pySLAGoal',
- label: '@L SLA Goal',
- key: 'pySLAGoal'
- }
- },
- {
- type: 'RadioButtons',
- config: {
- value: '@P .pySLAStartTime',
- label: '@L SLA Start Time',
- listType: 'associated',
- datasource: '@ASSOCIATED .pySLAStartTime',
- key: 'pySLAStartTime'
- }
- }
- ]
- },
- {
- name: 'B',
- type: 'Region',
- key: 'B',
- getPConnect: () => {
- return {
- getRawMetadata: () => {
- return pyReviewRaw.children[0];
- }
- };
- },
- children: [
- {
- type: 'DateTime',
- config: {
- value: '@P .pySLADeadline',
- label: '@L SLA Deadline',
- key: 'pySLADeadline'
- }
- },
- {
- type: 'DateTime',
- config: {
- value: '@P .pySLAGoal',
- label: '@L SLA Goal',
- key: 'pySLAGoal'
- }
- },
- {
- type: 'RadioButtons',
- config: {
- value: '@P .pySLAStartTime',
- label: '@L SLA Start Time',
- listType: 'associated',
- datasource: '@ASSOCIATED .pySLAStartTime',
- key: 'pySLAStartTime'
- }
- }
- ]
- }
- ],
- classID: 'MyCo-MyCompon-Work-MyComponents'
-};
-
-export const pyReviewResolved = {
- readOnly: true,
- template: 'Details',
- ruleClass: 'MyCo-MyCompon-Work-MyComponents',
- showLabel: true,
- label: 'Details',
- localeReference: 'MYCO-MYCOMPON-WORK-MYCOMPONENTS!VIEW!PYREVIEW',
- showHighlightedData: true,
- highlightedData: [
- {
- type: 'TextInput',
- config: {
- value: 'New',
- label: 'Work Status',
- displayMode: 'STACKED_LARGE_VAL',
- displayAsStatus: true
- }
- },
- {
- type: 'TextInput',
- config: {
- value: 'M-1002',
- label: 'Case ID',
- displayMode: 'STACKED_LARGE_VAL'
- }
- },
- {
- type: 'DateTime',
- config: {
- value: '2022-12-11T20:06:27.232Z',
- label: 'Create date/time',
- displayMode: 'STACKED_LARGE_VAL'
- }
- },
- {
- type: 'UserReference',
- config: {
- label: 'Create Operator',
- value: {
- userId: 'conns',
- userName: 'Sara Connor'
- },
- placeholder: 'Select...',
- displayMode: 'STACKED_LARGE_VAL'
- }
- }
- ],
- displayMode: 'LABELS_LEFT'
-};
-
-export const regionChildrenResolved = [
- {
- readOnly: true,
- value: '',
- label: 'SLA Deadline',
- displayMode: 'LABELS_LEFT',
- key: 'SLA Deadline'
- },
- {
- readOnly: true,
- value: '',
- label: 'SLA Goal',
- displayMode: 'LABELS_LEFT',
- key: 'SLA Goal'
- },
- {
- readOnly: true,
- value: '',
- label: 'SLA Start Time',
- listType: 'associated',
- datasource: [
- {
- key: 'AssignmentCreation',
- value: 'The creation time of the Assignment'
- },
- {
- key: 'CurrentTime',
- value: 'Current Date Time'
- }
- ],
- displayMode: 'LABELS_LEFT',
- key: 'SLA Start Time'
- }
-];
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/styles.js b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/utils.js b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/utils.js
deleted file mode 100644
index cc4ead88..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnDetails/utils.js
+++ /dev/null
@@ -1,155 +0,0 @@
-/* eslint-disable no-undef */
-
-
-
-/**
- * Given the PConnect object of a Template component, retrieve the children
- * metadata of all regions.
- * @param {Function} pConnect PConnect of a Template component.
- */
-export function getAllFields(pConnect) {
- const metadata = pConnect().getRawMetadata();
- if (!metadata.children) {
- return [];
- }
-
- let allFields = [];
-
- const makeField = (f) => ({
- ...pConnect().resolveConfigProps(f.config),
- type: f.type
- });
-
- const hasRegions = !!metadata.children[0]?.children;
- if (hasRegions) {
- allFields = metadata.children.map((region) =>
- region.children.map((field) => {
- // Do not resolve the config props if is status work, instead create component here as status badge and mark as status display
- if (field.config?.value === '@P .pyStatusWork') {
- field.type = 'TextInput';
- field.config.displayAsStatus = true;
- return pConnect().createComponent(field);
- }
-
- return makeField(field);
- })
- );
- } else {
- allFields = metadata.children.map(makeField);
- }
-
- return allFields;
-}
-
-
-
-export function getFilteredFields(getPConnect) {
- let primaryFieldsRaw;
- let secondaryFieldsRaw;
- const metadata = getPConnect().getRawMetadata();
- const hasRegions = !!metadata.children[0]?.children;
- if (hasRegions) {
- primaryFieldsRaw = metadata.children[0].children;
- secondaryFieldsRaw = metadata.children[1].children;
- } else {
- [primaryFieldsRaw, secondaryFieldsRaw] = metadata.children;
- }
-
- // Filter out fields that are not visible and unsupported types for primary fields (for CaseSummary)
- primaryFieldsRaw = primaryFieldsRaw.filter((item) => {
- const resolvedItem = getPConnect().resolveConfigProps(item.config);
- return resolvedItem.visibility !== false && item.type !== 'TextContent';
- });
-
- secondaryFieldsRaw = secondaryFieldsRaw.filter((item) => {
- const resolvedItem = getPConnect().resolveConfigProps(item.config);
- return resolvedItem.visibility !== false && item.type !== 'TextContent';
- });
-
- return [primaryFieldsRaw, secondaryFieldsRaw];
-}
-
-/**
- * Returns ConfigurableLayout mapped content. With pre-populated default layout configs.
- * @param {object[]} regionData template children item.
- * @returns {object[]} ConfigurableLayout content.
- */
-export function getLayoutDataFromRegion(regionData) {
- const defaultLayoutConfig = {
- width: 'full',
- fillAvailable: true,
- minWidth: [300, 'px']
- };
-
- return regionData.props
- ?.getPConnect()
- ?.getChildren()
- ?.map((item, index) => {
- const itemPConnect = item?.getPConnect();
-
- return {
- id: itemPConnect?.getComponentName() ? `${itemPConnect.getComponentName()}--${index}` : `item--${index}`,
- content: itemPConnect?.getComponent(),
- layoutConfig: {
- ...defaultLayoutConfig,
- ...itemPConnect?.getConfigProps().layoutConfig
- }
- };
- });
-}
-
-/**
- * Determine if the current view is the view of the case step/assignment.
- * @param {Function} pConnect PConnect object for the component
- */
-export function getIsAssignmentView(pConnect) {
- // Get caseInfo content from the store which contains the view info about the current assignment/step
- // TODO To be replaced with pConnect.getCaseInfo().getCurrentAssignmentView when it's available
- const assignmentViewClass = pConnect.getValue(PCore.getConstants().CASE_INFO.CASE_INFO_CLASSID);
- const assignmentViewName = pConnect.getValue(PCore.getConstants().CASE_INFO.ASSIGNMENTACTION_ID);
-
- const assignmentViewId = `${assignmentViewName}!${assignmentViewClass}`;
-
- // Get the info about the current view from pConnect
- const currentViewId = `${pConnect.getCurrentView()}!${pConnect.getCurrentClassID()}`;
-
- return assignmentViewId === currentViewId;
-}
-
-/**
- * A hook that gets the instructions content for a view.
- * @param {Function} pConnect PConnect object for the component
- * @param {string} [instructions="casestep"] 'casestep', 'none', or the html content of a Rule-UI-Paragraph rule (processed via core's paragraph annotation handler)
- */
-export function getInstructions(pConnect, instructions = 'casestep') {
- const caseStepInstructions = pConnect.getValue(PCore.getConstants().CASE_INFO.INSTRUCTIONS);
-
- // Determine if this view is the current assignment/step view
- const isCurrentAssignmentView = getIsAssignmentView(pConnect);
-
- // Case step instructions
- if (instructions === 'casestep' && isCurrentAssignmentView && caseStepInstructions?.length) {
- return caseStepInstructions;
- }
-
- // No instructions
- if (instructions === 'none') {
- return undefined;
- }
-
- // If the annotation wasn't processed correctly, don't return any instruction text
- if (instructions?.startsWith('@PARAGRAPH')) {
- /* eslint-disable no-console */
- console.error('@PARAGRAPH annotation was not processed. Hiding custom instructions.');
- /* eslint-enable no-console */
- return undefined;
- }
-
- // Custom instructions from the view
- // The raw metadata for `instructions` will be something like '@PARAGRAPH .SomeParagraphRule' but
- // it is evaluated by core logic to the content
- if (instructions !== 'casestep' && instructions !== 'none') {
- return instructions;
- }
- return undefined;
-}
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnForm/TwoColumn.svg b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnForm/TwoColumn.svg
deleted file mode 100644
index 3533e017..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnForm/TwoColumn.svg
+++ /dev/null
@@ -1,38 +0,0 @@
-
-
- 2-col icon
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- A
-
-
-
- B
-
-
-
-
-
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnForm/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnForm/demo.stories.jsx
deleted file mode 100644
index 5da27462..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnForm/demo.stories.jsx
+++ /dev/null
@@ -1,175 +0,0 @@
-/* eslint-disable react-hooks/rules-of-hooks */
-import { useState } from 'react';
-import { withKnobs } from '@storybook/addon-knobs';
-
-import PegaDxilMyTwoColumnForm from './index.jsx';
-import { DateInput, Input, FieldValueList, Text } from '@pega/cosmos-react-core';
-import { PhoneInput as CosmosPhone } from '@pega/cosmos-react-core';
-import { pyReviewRaw, regionChildrenResolved } from './mock.stories';
-
-export default {
- title: 'PegaDxilMyTwoColumnForm',
- decorators: [withKnobs],
- component: PegaDxilMyTwoColumnForm
-};
-
-const renderField = resolvedProps => {
- const { displayMode, value = '', label = '', key } = resolvedProps;
-
- const [inputValue, setInputValue] = useState(value);
- const [phoneValue, setPhoneValue] = useState('+16397975093');
-
-
- const variant = displayMode === 'LABELS_LEFT' ? 'inline' : 'stacked';
-
- let val =
- value !== '' ? (
- {
- setInputValue(e.target.value);
- }}
- >
- {inputValue}
-
- ) : (
- ''
- );
-
-
- if (label === 'Service Date')
- val = (
- {
- const { valueAsISOString: date } = dateVal;
- const trimmedDate = date ? date.substring(0, date.indexOf('T')) : date;
- setInputValue(trimmedDate);
- }}
- >
- );
-
- if (label === 'Email')
- val = (
- {
- setInputValue(e.target.value);
- }}
- >
- );
-
- if (label === 'First Name' || label === 'Last Name' || label === 'Middle Name')
- val = (
- {
- setInputValue(e.target.value);
- }}
- >
- );
-
- if (label === 'Phone Number')
- val = (
- {
- setPhoneValue(phoneVal);
- }}
- >
- );
-
-
- if (variant === 'inline') {
- val = value || (
- {
- setInputValue(e.target.value);
- }}
- >
- ––
-
- );
- } else {
- val = (
- {
- setInputValue(e.target.value);
- }}
- >
- {val}
-
- );
- }
- return (
- {
- /* nothing */
- }}
- />
- );
-};
-
-export const basePegaDxilMyTwoColumnForm = () => {
- const props = {
- template: 'DefaultForm',
- getPConnect: () => {
- return {
- getChildren: () => {
- return pyReviewRaw.children;
- },
- createComponent: config => {
- // eslint-disable-next-line default-case
- switch (config.config.value) {
- case '@P .FirstName':
- return renderField(regionChildrenResolved[0]);
- case '@P .MiddleName':
- return renderField(regionChildrenResolved[1]);
- case '@P .LastName':
- return renderField(regionChildrenResolved[2]);
- case '@P .Email':
- return renderField(regionChildrenResolved[3]);
- case '@P .PhoneNumber':
- return renderField(regionChildrenResolved[4]);
- case '@P .ServiceDate':
- return renderField(regionChildrenResolved[5]);
- }
- }
- };
- }
- };
-
- const regionAChildren = pyReviewRaw.children[0].children.map(child => {
- return props.getPConnect().createComponent(child);
- });
- const regionBChildren = pyReviewRaw.children[1].children.map(child => {
- return props.getPConnect().createComponent(child);
- });
-
- return (
-
- {regionAChildren}
- {regionBChildren}
-
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnForm/index.jsx b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnForm/index.jsx
deleted file mode 100644
index 99533727..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnForm/index.jsx
+++ /dev/null
@@ -1,45 +0,0 @@
-import { Grid, Flex } from '@pega/cosmos-react-core';
-import PropTypes from 'prop-types';
-
-import StyledPegaDxilMyTwoColumnFormWrapper from './styles';
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-export default function PegaDxilMyTwoColumnForm(props) {
-
-
- const { children } = props;
-
- const numRegions = children?.length;
- const gridRepeat = "repeat(".concat(numRegions).concat(", 1fr)");
- const gridContainer = {"colGap" : 1};
- gridContainer.cols = gridRepeat;
- gridContainer.alignItems = 'start';
-
- const flexContainer = {direction: 'column'};
- flexContainer.gap = 2;
-
- return (
-
-
- {children.map((child, i) => (
-
- {child}
-
- ))}
-
-
- );
-
-}
-
-PegaDxilMyTwoColumnForm.defaultProps = {
- children: []
-};
-
-PegaDxilMyTwoColumnForm.propTypes = {
- children: PropTypes.arrayOf(PropTypes.node),
-};
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnForm/mock.stories.js b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnForm/mock.stories.js
deleted file mode 100644
index 8e16b199..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnForm/mock.stories.js
+++ /dev/null
@@ -1,143 +0,0 @@
-export const pyReviewRaw = {
- name: 'CollectInformation',
- type: 'View',
- config: {
- template: 'DefaultForm',
- ruleClass: 'OM5W9U-SampleApp-Work-Test',
- localeReference: '@LR OM5W9U-SAMPLEAPP-WORK-TEST!VIEW!COLLECTINFORMATION',
- context: '@P .pyViewContext'
- },
- children: [
- {
- name: 'A',
- type: 'Region',
- children: [
- {
- type: 'TextInput',
- config: {
- value: '@P .FirstName',
- label: '@L First Name',
- key: 'FirstName'
- }
- },
- {
- type: 'TextInput',
- config: {
- value: '@P .MiddleName',
- label: '@L Middle Name',
- key: 'MiddleName'
- }
- },
- {
- type: 'TextInput',
- config: {
- value: '@P .LastName',
- label: '@L Last Name',
- key: 'LastName'
- }
- }
- ]
- },
- {
- name: 'B',
- type: 'Region',
- children: [
- {
- type: 'Email',
- config: {
- value: '@P .Email',
- label: '@L Email',
- key: 'Email'
- }
- },
- {
- type: 'Phone',
- config: {
- value: '@P .PhoneNumber',
- label: '@L Phone Number',
- datasource: {
- source: '@DATASOURCE D_pyCountryCallingCodeList.pxResults',
- fields: {
- value: '@P .pyCallingCode'
- }
- },
- key: 'PhoneNumber'
- }
- },
- {
- type: 'Date',
- config: {
- value: '@P .ServiceDate',
- label: '@L Service Date',
- key: 'ServiceDate'
- }
- }
- ]
- }
- ],
- classID: 'OM5W9U-SampleApp-Work-Test'
-};
-
-export const regionChildrenResolved = [
- {
- readOnly: undefined,
- value: 'John',
- label: 'First Name',
- hasSuggestions: false,
- key: 'First Name'
- },
- {
- readOnly: undefined,
- value: '',
- label: 'Middle Name',
- hasSuggestions: false,
- key: 'Middle Name'
- },
- {
- readOnly: undefined,
- value: 'Doe',
- label: 'Last Name',
- hasSuggestions: false,
- key: 'Last Name'
- },
- {
- readOnly: undefined,
- value: 'John@doe.com',
- label: 'Email',
- hasSuggestions: false,
- key: 'Email'
- },
- {
- readOnly: undefined,
- value: '+16397975093',
- label: 'Phone Number',
- datasource: {
- fields: {
- value: undefined
- },
- source: [
- {
- value: '+1'
- },
- {
- value: '+91'
- },
- {
- value: '+48'
- },
- {
- value: '+44'
- }
- ]
- },
- hasSuggestions: false,
- key: 'Phone Number'
- },
- {
- readOnly: undefined,
- value: '2023-01-25',
- label: 'Service Date',
- hasSuggestions: false,
- key: 'Service Date'
- }
-];
diff --git a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnForm/styles.js b/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnForm/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/Pega_DXIL_MyTwoColumnForm/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/template/_template.md b/tests/assets/components/createAll/custom-constellation/template/_template.md
deleted file mode 100644
index 75835038..00000000
--- a/tests/assets/components/createAll/custom-constellation/template/_template.md
+++ /dev/null
@@ -1,5 +0,0 @@
-# The **custom-constellation/template** directory
-
-The **src/components/custom-constellation/template** directory contains the code for the Constellation-based associated component for any custom **template** component you have created for use with the **Angular SDK**.
-
-For each component in the **src/components/custom-constellation/template** directory, there will be a matching component in the **src/components/custom-sdk/template** directory.
diff --git a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyCaseWidget/OneColumnPage.svg b/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyCaseWidget/OneColumnPage.svg
deleted file mode 100644
index 5f2dec97..00000000
--- a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyCaseWidget/OneColumnPage.svg
+++ /dev/null
@@ -1,36 +0,0 @@
-
-
- 1 col
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- A
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyCaseWidget/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyCaseWidget/demo.stories.jsx
deleted file mode 100644
index 60c9a853..00000000
--- a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyCaseWidget/demo.stories.jsx
+++ /dev/null
@@ -1,78 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-
-import PegaDxilMyCaseWidget from './index.jsx';
-
-import historyData from './mock.stories';
-
-export default {
- title: 'PegaDxilMyCaseWidget',
- decorators: [withKnobs],
- component: PegaDxilMyCaseWidget
-};
-
-if (!window.PCore) {
- window.PCore = {};
-}
-
-window.PCore.getConstants = () => {
- return {
- CASE_INFO: {
- CASE_INFO_ID: 'caseInfo.ID'
- }
- };
-};
-
-window.PCore.getLocaleUtils = () => {
- return {
- getLocaleValue: value => {
- return value;
- }
- };
-};
-
-window.PCore.getDataApiUtils = () => {
- return {
- getData: () => {
- return new Promise(resolve => {
- resolve(historyData);
- });
- }
- };
-};
-
-export const basePegaDxilMyCaseWidget = () => {
-
- const props = {
- label: 'Case history',
-
- getPConnect: () => {
- return {
- getValue: value => {
- return value;
- },
- getContextName: () => {
- return 'app/primary_1';
- },
- getLocalizedValue: value => {
- return value;
- },
- getActionsApi: () => {
- return {
- updateFieldValue: () => {/* nothing */},
- triggerFieldChange: () => {/* nothing */}
- };
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- setInheritedProps: () => {/* nothing */},
- resolveConfigProps: () => {/* nothing */}
- };
- }
-};
-
-return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyCaseWidget/index.jsx b/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyCaseWidget/index.jsx
deleted file mode 100644
index eab48284..00000000
--- a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyCaseWidget/index.jsx
+++ /dev/null
@@ -1,73 +0,0 @@
-/* eslint-disable no-undef */
-import { useState, useEffect } from 'react';
-import PropTypes from 'prop-types';
-import { Table, Text } from '@pega/cosmos-react-core';
-
-import StyledPegaDxilMyCaseWidgetWrapper from './styles';
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-export default function PegaDxilMyCaseWidget(props) {
- const { getPConnect, label } = props;
- const pConn = getPConnect();
- const [history, setHistory] = useState([]);
- const [isLoading, setIsLoading] = useState(true);
- const caseID = pConn.getValue(PCore.getConstants().CASE_INFO.CASE_INFO_ID);
- const context = pConn.getContextName();
-
- const columns = [
- { renderer: 'date', label: pConn.getLocalizedValue('Date') },
- { renderer: 'description', label: pConn.getLocalizedValue('Description') },
- { renderer: 'user', label: pConn.getLocalizedValue('Performed by') }
- ];
-
- useEffect(() => {
- const payload = { dataViewParameters: [{ CaseInstanceKey: caseID }] };
- PCore.getDataApiUtils()
- .getData('D_pyWorkHistory', payload, context)
- .then((response) => {
- setIsLoading(false);
- if (response.data.data !== null) {
- setHistory(
- response.data.data.map((entry, index) => {
- return {
- date: new Date(entry.pxTimeCreated).toLocaleString(),
- description: {entry.pyMessageKey} ,
- user: entry.pyPerformer,
- id: index
- };
- })
- );
- } else {
- setHistory([]);
- }
- })
- .catch(() => {
- setHistory([]);
- setIsLoading(false);
- });
- }, [caseID, context]);
- return (
-
-
-
- );
-
-}
-
-PegaDxilMyCaseWidget.defaultProps = {
-
-};
-
-PegaDxilMyCaseWidget.propTypes = {
- getPConnect: PropTypes.func.isRequired
-};
diff --git a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyCaseWidget/mock.stories.js b/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyCaseWidget/mock.stories.js
deleted file mode 100644
index 1b5d98db..00000000
--- a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyCaseWidget/mock.stories.js
+++ /dev/null
@@ -1,390 +0,0 @@
-const historyData = {
- data: {
- fetchDateTime: '2023-01-18T12:04:56.517Z',
- pxObjClass: 'Pega-API-DataExploration-Data',
- resultCount: 31,
- data: [
- {
- pxTimeCreated: '2023-01-13T21:46:33.339Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214633.339 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214633.339 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxTimeCreated: '2023-01-13T21:46:33.332Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214633.332 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214633.332 GMT',
- pxLongitude: null,
- pyMessageKey: "Assignment to 'complete task' completed by performing a 'EmbeddedData'.",
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxTimeCreated: '2023-01-13T21:46:32.005Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214632.005 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214632.005 GMT',
- pxLongitude: null,
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxTimeCreated: '2023-01-13T21:46:31.998Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214631.998 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214631.998 GMT',
- pxLongitude: null,
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assignment to 'complete task' removed via ticket.",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:46:31.175Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214631.175 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214631.175 GMT',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:46:31.168Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214631.168 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214631.168 GMT',
- pxLongitude: null,
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assignment to 'complete task' completed by performing a 'EmbeddedData'.",
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:46:29.893Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214629.893 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214629.893 GMT',
- pxLongitude: null,
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:46:29.887Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214629.887 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214629.887 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assignment to 'complete task' removed via ticket.",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:46:28.248Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214628.248 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214628.248 GMT',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:46:28.242Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214628.242 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214628.242 GMT',
- pyMessageKey: "Assignment to 'complete task' completed by performing a 'EmbeddedData'.",
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:46:08.399Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214608.399 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214608.399 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:46:08.393Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214608.393 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214608.393 GMT',
- pyMessageKey: "Assignment to 'complete task' removed via ticket.",
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:46:07.584Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214607.584 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214607.584 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:46:07.579Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214607.579 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214607.579 GMT',
- pxLongitude: null,
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assignment to 'complete task' completed by performing a 'EmbeddedData'.",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:46:06.262Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214606.262 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214606.262 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:46:06.256Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214606.256 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214606.256 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assignment to 'complete task' removed via ticket.",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:45:57.503Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214557.503 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214557.503 GMT',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:45:57.496Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214557.496 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214557.496 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assignment to 'complete task' completed by performing a 'EmbeddedData'.",
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:45:36.250Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214536.250 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214536.250 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:45:36.244Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214536.244 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214536.244 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assignment to 'complete task' removed via ticket.",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:45:35.364Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214535.364 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214535.364 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:45:35.356Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214535.356 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214535.356 GMT',
- pxLongitude: null,
- pyMessageKey: "Assignment to 'complete task' completed by performing a 'EmbeddedData'.",
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:45:33.224Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214533.224 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214533.224 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:45:33.218Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214533.218 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214533.218 GMT',
- pxLongitude: null,
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assignment to 'complete task' removed via ticket.",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:45:32.436Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214532.436 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214532.436 GMT',
- pxLongitude: null,
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:45:32.430Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214532.430 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214532.430 GMT',
- pyMessageKey: "Assignment to 'complete task' completed by performing a 'EmbeddedData'.",
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:45:25.003Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214525.003 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214525.003 GMT',
- pxLongitude: null,
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:45:24.994Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214524.994 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214524.994 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assignment to 'complete task' completed by performing a 'Select Test'.",
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:45:23.570Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214523.570 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214523.570 GMT',
- pxLongitude: null,
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:45:23.563Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214523.563 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214523.563 GMT',
- pxLongitude: null,
- pyMessageKey: 'ChangeStageAutomatic\tCreate\tPick Test',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pxLatitude: null,
- pyMemo: 'ChangeStageAutomatic\tCreate\tPick Test'
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:45:23.550Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214523.550 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214523.550 GMT',
- pxLongitude: null,
- pyMessageKey: 'Item created.',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMemo: null,
- pxLatitude: null
- }
- ],
- hasMoreResults: false
- },
- status: 200,
- statusText: '',
- headers: {
- 'content-length': '1328',
- 'content-type': 'application/json;charset=UTF-8'
- },
- request: {}
-};
-export default historyData;
diff --git a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyCaseWidget/styles.js b/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyCaseWidget/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyCaseWidget/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/Avatar.jsx b/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/Avatar.jsx
deleted file mode 100644
index ad9f9dd1..00000000
--- a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/Avatar.jsx
+++ /dev/null
@@ -1,75 +0,0 @@
-/* eslint-disable no-undef */
-/* eslint-disable react-hooks/rules-of-hooks */
-import { useEffect, useState } from 'react';
-import PropTypes from 'prop-types';
-import { Avatar as CosmosAvatar } from '@pega/cosmos-react-core';
-
-function Avatar(props) {
- const { metaObj, showStatus } = props;
- const [imageBlobUrl, setImageBlobUrl] = useState(null);
- let userName;
- let userIdentifier;
-
- // TODO Below if conditions can be removed once we have apis to get worklist/mywork info
- // This is non CaseView case (Dashboard, MyWork etc)
- if (!metaObj) {
- userName = PCore.getEnvironmentInfo().getOperatorName();
- userIdentifier = PCore.getEnvironmentInfo().getOperatorIdentifier();
- } else {
- userName = metaObj.name;
- userIdentifier = metaObj.ID;
- }
- if (!userName && userIdentifier) {
- userName = userIdentifier;
- }
-
- useEffect(() => {
- const imageKey = !metaObj ? PCore.getEnvironmentInfo().getOperatorImageInsKey() : metaObj.image;
- if (imageKey) {
- PCore.getAssetLoader()
- .getSvcImage(imageKey)
- .then((blob) => window.URL.createObjectURL(blob))
- .then((imagePath) => setImageBlobUrl(imagePath));
- }
- }, []);
-
- if (showStatus) {
- const currentState = PCore.getMessagingServiceManager().getUserPresence().getUserState(userIdentifier);
- const [userState, setUserState] = useState(currentState === 'online' ? 'active' : 'inactive');
-
- const handleUserStateChange = ({ state }) => {
- setUserState(state === 'online' ? 'active' : 'inactive');
- };
-
- useEffect(() => {
- const subId = PCore.getMessagingServiceManager()
- .getUserPresence()
- .subscribe(userIdentifier, handleUserStateChange);
-
- return function cleanup() {
- PCore.getMessagingServiceManager().getUserPresence().unsubscribe(userIdentifier, subId);
- };
- }, []);
- return ;
- }
-
- // Do not render when userName does not exists
- // TODO : In CNR case, pxRequestor is not available, please remove this condition once it populates
- if (!userName) {
- return null;
- }
-
- return ;
-}
-
-Avatar.propTypes = {
- metaObj: PropTypes.objectOf(PropTypes.any),
- showStatus: PropTypes.bool
-};
-
-Avatar.defaultProps = {
- metaObj: null,
- showStatus: false
-};
-
-export default Avatar;
diff --git a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/OneColumnPage.svg b/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/OneColumnPage.svg
deleted file mode 100644
index 5f2dec97..00000000
--- a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/OneColumnPage.svg
+++ /dev/null
@@ -1,36 +0,0 @@
-
-
- 1 col
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- A
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/Operator.jsx b/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/Operator.jsx
deleted file mode 100644
index cc1fb28c..00000000
--- a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/Operator.jsx
+++ /dev/null
@@ -1,237 +0,0 @@
-/* eslint-disable no-undef */
-import { useState, useEffect, Fragment } from 'react';
-import {
- Link,
- Button,
- Popover,
- Flex,
- useOuterEvent,
- useElement,
- Progress,
- FormField,
- useTheme
-} from '@pega/cosmos-react-core';
-import { Glimpse } from '@pega/cosmos-react-work';
-import PropTypes from 'prop-types';
-
-import Avatar from './Avatar.jsx';
-
-const Operator = (props) => {
- const { id, name, label, testId, helperText, externalUser, metaObj } = props;
- const [isOpen, setIsOpen] = useState(false);
- const [isLoading, setIsLoading] = useState(true);
- const [popoverTarget, setPopoverTarget] = useState(null);
- const [popoverEl, setPopoverEl] = useElement(null);
- const [popoverContent, setpopoverContent] = useState(null);
- const theme = useTheme();
-
- /* If the id has changed, we need to reset the popover */
- useEffect(() => {
- setPopoverTarget(null);
- }, [id]);
-
-
-
- const OperatorPreview = () => {
- const localizedVal = PCore.getLocaleUtils().getLocaleValue;
- const localeCategory = 'Operator';
- setpopoverContent(
-
- );
- if (externalUser && externalUser.classID !== 'Data-Party-Operator') {
- const fields = [
- {
- id: 'pyFirstName',
- name: localizedVal('Name', localeCategory),
- value: externalUser.name
- },
- {
- id: 'pyEmail1',
- name: localizedVal('Email', localeCategory),
- value:
- externalUser.email !== '' ? {externalUser.email} : ''
- },
- {
- id: 'pyPhoneNumber',
- name: localizedVal('Phone', localeCategory),
- value: externalUser.phone !== '' ? {externalUser.phone} : ''
- }
- ];
- setIsLoading(false);
- setpopoverContent(
-
- }
- primary={externalUser.name}
- secondary={[externalUser.position]}
- fields={fields}
- />
- );
- } else {
- const { getOperatorDetails } = PCore.getUserApi();
- getOperatorDetails(id)
- .then((res) => {
- if (res.data && res.data.pyOperatorInfo && res.data.pyOperatorInfo.pyUserName) {
- const fields = [
- {
- id: 'pyOrganization',
- name: localizedVal('Organization', localeCategory),
- value: res.data.pyOperatorInfo.pyOrganization
- },
- {
- id: 'pyTelephone',
- name: localizedVal('Telephone', localeCategory),
- value:
- res.data.pyOperatorInfo.pyTelephone !== '' ? (
-
- {res.data.pyOperatorInfo.pyTelephone}
-
- ) : (
- ''
- )
- },
- {
- id: 'pyEmailAddress',
- name: localizedVal('Email address', localeCategory),
- value:
- res.data.pyOperatorInfo.pyEmailAddress !== '' ? (
-
- {res.data.pyOperatorInfo.pyEmailAddress}
-
- ) : (
- ''
- )
- },
- {
- id: 'ReportToUserName',
- name: localizedVal('Reports to', localeCategory),
- value: res.data.pyOperatorInfo.pyReportToUserName
- }
- ];
- setIsLoading(false);
- setpopoverContent(
-
- }
- primary={res.data.pyOperatorInfo.pyUserName}
- secondary={[res.data.pyOperatorInfo.pyPosition]}
- fields={fields}
- />
- );
- } else {
- setIsLoading(false);
- setpopoverContent({localizedVal('Operator not found', localeCategory)} );
- }
- })
- .catch(() => {
- setIsLoading(false);
- setpopoverContent(
- {localizedVal('Error loading the operator profile', localeCategory)}
- );
- });
- }
- };
-
-
- const clickAction = (e) => {
- setPopoverTarget(e.currentTarget);
- setIsOpen(!isOpen);
- if (popoverTarget === null) {
- OperatorPreview();
- }
- };
-
- const hidePopover = () => {
- if (isOpen) {
- setIsOpen(false);
- }
- };
- useOuterEvent('mousedown', [popoverEl, popoverTarget], hidePopover); // Call the method on clicking outside these elements
- const hideOnEscape = (e) => {
- if (e.key === 'Escape') hidePopover(); // Call the method when Escape key is pressed
- };
-
- const comp = (
-
- {metaObj ? (
-
-
-
- ) : (
-
- {name}
-
- )}
-
- {isOpen && (
-
- {popoverContent}
-
- )}
-
- );
-
- if (label !== null) {
- return (
-
- {comp}
-
- );
- }
-
- return comp;
-};
-
-Operator.propTypes = {
- name: PropTypes.string,
- id: PropTypes.string,
- label: PropTypes.string,
- testId: PropTypes.string,
- helperText: PropTypes.string,
- metaObj: PropTypes.object
-};
-
-Operator.defaultProps = {
- name: '',
- id: '',
- label: null,
- testId: null,
- helperText: null,
- metaObj: null
-};
-
-export default Operator;
diff --git a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/demo.stories.jsx
deleted file mode 100644
index 2528f406..00000000
--- a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/demo.stories.jsx
+++ /dev/null
@@ -1,68 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-
-import PegaDxilMyPageCaseWidget from './index.jsx';
-
-import { configProps, operatorDetails } from './mock.stories';
-
-export default {
- title: 'PegaDxilMyPageCaseWidget',
- decorators: [withKnobs],
- component: PegaDxilMyPageCaseWidget
-};
-
-if (!window.PCore) {
- window.PCore = {};
-}
-
-window.PCore.getLocaleUtils = () => {
- return {
- getLocaleValue: value => {
- return value;
- }
- };
-};
-
-window.PCore.getUserApi = () => {
- return {
- getOperatorDetails: () => {
- return new Promise(resolve => {
- resolve(operatorDetails);
- });
- }
- };
-};
-
-export const basePegaDxilMyPageCaseWidget = () => {
-
- const props = {
- label: configProps.label,
- createLabel: configProps.createLabel,
- updateLabel: configProps.updateLabel,
- createOperator: configProps.createOperator,
- updateOperator: configProps.updateOperator,
- createDateTime: configProps.createDateTime,
- updateDateTime: configProps.updateDateTime,
- hideLabel: configProps.hideLabel,
-
- getPConnect: () => {
- return {
- getActionsApi: () => {
- return {
- updateFieldValue: () => {/* nothing */},
- triggerFieldChange: () => {/* nothing */}
- };
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- setInheritedProps: () => {/* nothing */},
- resolveConfigProps: () => {/* nothing */}
- };
- }
-};
-
-return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/index.jsx b/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/index.jsx
deleted file mode 100644
index c9903046..00000000
--- a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/index.jsx
+++ /dev/null
@@ -1,108 +0,0 @@
-/* eslint-disable no-nested-ternary */
-import { Fragment } from 'react';
-import { DateTimeDisplay, Card, CardHeader, CardContent, Flex } from '@pega/cosmos-react-core';
-import PropTypes from 'prop-types';
-
-// includes in bundle
-import Operator from './Operator.jsx';
-
-import StyledPegaDxilMyPageCaseWidgetWrapper from './styles';
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-export default function PegaDxilMyPageCaseWidget(props) {
-
- const {
- getPConnect,
- title,
- label,
- createLabel,
- updateLabel,
- createOperator,
- updateOperator,
- createDateTime,
- updateDateTime,
- resolveLabel,
- resolveOperator,
- resolveDateTime,
- hideLabel
- } = props;
-
-
- const [_label, user, dateTimeValue] =
- label === 'Create operator'
- ? [createLabel, createOperator, createDateTime]
- : label === 'Update operator'
- ? [updateLabel, updateOperator, updateDateTime]
- : [resolveLabel, resolveOperator, resolveDateTime];
-
-
-
- return user.userId && user.userName ? (
-
-
- {title}
-
-
-
-
- {dateTimeValue && (
-
- {' '}
-
-
- )}
-
-
-
-
-
- ) : (
-
- defVal
-
- );
-
-
-
-}
-
-PegaDxilMyPageCaseWidget.defaultProps = {
- "label": "Create operator",
- "title": "Create operator",
- createLabel: null,
- updateLabel: null,
- createOperator: null,
- updateOperator: null,
- createDateTime: null,
- updateDateTime: null,
- resolveLabel: null,
- resolveOperator: null,
- resolveDateTime: null,
- hideLabel: false
-};
-
-PegaDxilMyPageCaseWidget.propTypes = {
- getPConnect: PropTypes.func.isRequired,
- label: PropTypes.string,
- title: PropTypes.string,
- createLabel: PropTypes.string,
- updateLabel: PropTypes.string,
- resolveLabel: PropTypes.string,
- createOperator: PropTypes.objectOf(PropTypes.any),
- updateOperator: PropTypes.objectOf(PropTypes.any),
- resolveOperator: PropTypes.objectOf(PropTypes.any),
- createDateTime: PropTypes.string,
- updateDateTime: PropTypes.string,
- resolveDateTime: PropTypes.string,
- hideLabel: PropTypes.bool
-};
-
-// as objects are there in props, shallow comparision fails & re-rendering of comp happens even with
-// same key value pairs in obj. hence using custom comparison function on when to re-render
-// const comparisonFn = (prevProps, nextProps) => {
-// return prevProps.updateDateTime === nextProps.updateDateTime;
-// };
diff --git a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/mock.stories.js b/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/mock.stories.js
deleted file mode 100644
index 62fb4f20..00000000
--- a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/mock.stories.js
+++ /dev/null
@@ -1,51 +0,0 @@
-export const configProps = {
- label: 'Create operator',
- createLabel: 'Created',
- updateLabel: 'Updated',
- updateDateTime: '2023-01-16T14:53:33.280Z',
- createDateTime: '2023-01-16T14:53:33.198Z',
- updateOperator: {
- userId: 'admin@mediaco',
- userName: 'admin'
- },
- createOperator: {
- userId: 'admin@mediaco',
- userName: 'admin'
- },
- hideLabel: true,
- key: '_532zx1dah',
- displayMode: 'LABELS_LEFT'
-};
-
-export const operatorDetails = {
- data: {
- pzLoadTime: 'January 18, 2023 10:33:19 AM EST',
- pzPageNameHash: '_pa1519192551088960pz',
- pyOperatorInfo: {
- pyUserName: 'french DigV2',
- pyPosition: '',
- pyImageInsKey: '',
- pySkills: [
- {
- pySkillName: '',
- pzIndexOwnerKey: 'DATA-ADMIN-OPERATOR-ID FRENCHTEST.DIGV2',
- pySkillRating: 0
- }
- ],
- pyReportToUserName: '',
- pyReportTo: '',
- pyOrganization: 'DXIL',
- pyTitle: '',
- pyLabel: 'frenchTest.DigV2',
- pyEmailAddress: 'User@DigV2',
- pyTelephone: ''
- }
- },
- status: 200,
- statusText: '',
- headers: {
- 'content-length': '435',
- 'content-type': 'application/json;charset=UTF-8'
- },
- request: {}
-};
diff --git a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/styles.js b/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageCaseWidget/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageWidget/OneColumnPage.svg b/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageWidget/OneColumnPage.svg
deleted file mode 100644
index 5f2dec97..00000000
--- a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageWidget/OneColumnPage.svg
+++ /dev/null
@@ -1,36 +0,0 @@
-
-
- 1 col
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- A
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageWidget/demo.stories.jsx b/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageWidget/demo.stories.jsx
deleted file mode 100644
index aef7480b..00000000
--- a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageWidget/demo.stories.jsx
+++ /dev/null
@@ -1,30 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-
-import PegaDxilMyPageWidget from './index.jsx';
-
-
-import configProps from './mock.stories';
-
-export default {
- title: 'PegaDxilMyPageWidget',
- decorators: [withKnobs],
- component: PegaDxilMyPageWidget
-};
-
-export const basePegaDxilMyPageWidget = () => {
-
- const props = {
- label: configProps.label,
- header: configProps.header,
- description: configProps.description,
- image: configProps.image,
- datasource: configProps.datasource,
- whatsnewlink: configProps.whatsnewlink
-};
-
-return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageWidget/index.jsx b/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageWidget/index.jsx
deleted file mode 100644
index f4ce3dcc..00000000
--- a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageWidget/index.jsx
+++ /dev/null
@@ -1,48 +0,0 @@
-import PropTypes from 'prop-types';
-import { AppAnnouncement as PegaAppAnnouncement } from '@pega/cosmos-react-work';
-
-import StyledPegaDxilMyPageWidgetWrapper from './styles';
-
-
-// Duplicated runtime code from Constellation Design System Component
-
-// props passed in combination of props from property panel (config.json) and run time props from Constellation
-// any default values in config.pros should be set in defaultProps at bottom of this file
-export default function PegaDxilMyPageWidget(props) {
-
- const { header, description, datasource, whatsnewlink, image } = props;
- let details = [];
- if (datasource && datasource.source) {
- details = datasource.source.map((item) => {
- return item.name;
- });
- }
- return (
-
-
-
- );
-
-}
-
-PegaDxilMyPageWidget.defaultProps = {
- header: '',
- description: '',
- image: '',
- datasource: [],
- whatsnewlink: ''
-};
-
-PegaDxilMyPageWidget.propTypes = {
- header: PropTypes.string,
- description: PropTypes.string,
- datasource: PropTypes.instanceOf(Object),
- whatsnewlink: PropTypes.string,
- image: PropTypes.string
-};
diff --git a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageWidget/mock.stories.js b/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageWidget/mock.stories.js
deleted file mode 100644
index 93ebf940..00000000
--- a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageWidget/mock.stories.js
+++ /dev/null
@@ -1,23 +0,0 @@
-const configProps = {
- label: 'App announcement',
- header: 'Announcements',
- description: 'Welcome to MediaCo Application for testing SDK frameworks.',
- whatsnewlink: 'https://design.pega.com',
- image:
- ' PHRpdGxlPlBlZ2EgdGV4dC1vbmx5IGxvZ288L3RpdGxlPjxwYXRoIHN0eWxlPSJmaWxsLW9wYWNpdHk6IC4yNTsiIGZpbGw9IiNmZmYiIGQ9Ik03LjcyIDMuODJjMCAyLjI1LTEuNzggMy40MS00IDMuNDFoLTEuNnYzSDBWLjQyaDMuOTRjMi4zNiAwIDMuNzggMS4zOSAzLjc4IDMuNHptLTQtMS40N2gtMS42djNoMS43QTEuNDcgMS40NyAwIDAgMCA1LjUgMy44MmMwLS45MS0uNjUtMS40Ny0xLjc1LTEuNDd6bTcuNjggNS45MWg1LjN2Mkg5LjI5Vi40Mmg3LjM4djEuOTNoLTUuMjR2Mmg0LjI0djEuOWgtNC4yNHpNMjMuMTggMGE1IDUgMCAwIDEgMy41NyAxLjI4TDI1LjYzIDIuOGEzLjc4IDMuNzggMCAwIDAtMS4wNS0uNjNBNC4zMiA0LjMyIDAgMCAwIDIzLjMxIDIgMy4xNyAzLjE3IDAgMCAwIDIwIDUuMjdhMy4xNiAzLjE2IDAgMCAwIDEgMi4zOSAzLjA3IDMuMDcgMCAwIDAgMi4xNy44NCA0LjYgNC42IDAgMCAwIDIuMDktLjVWNi4xOWgtMi4yVjQuMzhoNC4yNXY0LjU2YTUuNDEgNS40MSAwIDAgMS00LjA4IDEuNTdBNS4zNSA1LjM1IDAgMCAxIDE5LjQzIDlhNS4wNSA1LjA1IDAgMCAxLTEuNTYtMy43NCA1LjIxIDUuMjEgMCAwIDEgMS41Ni0zLjc2QTUuMzEgNS4zMSAwIDAgMSAyMy4xOCAwem0xMS4yOS40Mmw0LjEzIDkuNzloLTIuMjVMMzUuNDggOGgtNC4wNmwtLjkgMi4xOGgtMi4yTDMyLjUxLjQyem0uMjUgNS43MkwzMy40NCAzbC0xLjI5IDMuMTR6bTMtNWEuNzEuNzEgMCAwIDEtLjc0Ljc1LjcxLjcxIDAgMCAxLS43My0uNzUuNzMuNzMgMCAwIDEgLjc1LS43Mi43Mi43MiAwIDAgMSAuNzUuNzF6TTM3IC41M2EuNTkuNTkgMCAwIDAtLjYuNi42MS42MSAwIDEgMCAxLjIxIDAgLjYuNiAwIDAgMC0uNjEtLjZ6bS0uMjQgMVYuNzFIMzdjLjEyIDAgLjE4LjA2LjI1LjA2YS4yMS4yMSAwIDAgMSAuMDcuMTguMTkuMTkgMCAwIDEtLjA3LjE4cy0uMDcuMDgtLjEzLjA4bC4yNi4zNmgtLjJMMzcgMS4yOGgtLjF2LjI5em0uMTMtLjQ0aC4yM2EuMjYuMjYgMCAwIDAgLjA3LS4wOWgtLjA2Yy0uMDUtLjE3LS4wNS0uMTctLjEzLS4xN2gtLjF6Ii8 PC9zdmc ',
- datasource: {
- source: [
- {
- name: 'New React based UI rendering'
- },
- {
- name: 'Support for followers and recents'
- },
- {
- name: 'New authoring experience'
- }
- ],
- fields: {}
- }
-};
-export default configProps;
diff --git a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageWidget/styles.js b/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageWidget/styles.js
deleted file mode 100644
index 633cb0e9..00000000
--- a/tests/assets/components/createAll/custom-constellation/widget/Pega_DXIL_MyPageWidget/styles.js
+++ /dev/null
@@ -1,14 +0,0 @@
-// utilizing theming, comment out, if want individual style
-import styled from 'styled-components';
-import { Configuration } from '@pega/cosmos-react-core';
-
-export default styled(Configuration)``;
-
-// individual style, comment out above, and uncomment here and add styles
-// import styled, { css } from 'styled-components';
-//
-// export default styled.div(() => {
-// return css`
-// margin: 0px 0;
-// `;
-// });
diff --git a/tests/assets/components/createAll/custom-constellation/widget/_widget.md b/tests/assets/components/createAll/custom-constellation/widget/_widget.md
deleted file mode 100644
index 11871a8a..00000000
--- a/tests/assets/components/createAll/custom-constellation/widget/_widget.md
+++ /dev/null
@@ -1,5 +0,0 @@
-# The **custom-constellation/widget** directory
-
-The **src/components/custom-constellation/widget** directory contains the code for the Constellation-based associated component for any custom **widget** component you have created for use with the **Angular SDK**.
-
-For each component in the **src/components/custom-constellation/widget** directory, there will be a matching component in the **src/components/custom-sdk/widget** directory.
diff --git a/tests/assets/components/createAll/custom-sdk/_custom-sdk.md b/tests/assets/components/createAll/custom-sdk/_custom-sdk.md
deleted file mode 100644
index d19acbaf..00000000
--- a/tests/assets/components/createAll/custom-sdk/_custom-sdk.md
+++ /dev/null
@@ -1,5 +0,0 @@
-# The **components/custom-sdk** directory
-
-The **src/components/custom-sdk** directory contains the code for custom components that you create and use with the **Angular SDK**.
-
-When you run the **npm run create** command to create new components, the generated code that you can use as a starting point for your component development will be placed in type-specific and component-specific folders in **src/components/custom-sdk**.
diff --git a/tests/assets/components/createAll/custom-sdk/field/_field.md b/tests/assets/components/createAll/custom-sdk/field/_field.md
deleted file mode 100644
index 99d479f7..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/_field.md
+++ /dev/null
@@ -1,6 +0,0 @@
-# The **custom-sdk/field** directory
-
-The **src/components/custom-sdk/field** directory contains the code for the custom **field** components you want to create and use with the **Angular SDK**.
-
-When you run the **npm run create** command to create new _field_ components, the generated code that you can use as a starting point for your component development
-will be placed in component-specific folders in **src/components/custom-sdk/field**.
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/config.json b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/config.json
deleted file mode 100644
index dd93b887..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/config.json
+++ /dev/null
@@ -1,87 +0,0 @@
-{
- "name": "Pega_DXIL_MyBoolean",
- "label": "My Boolean",
- "description": "My Boolean",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyBoolean",
- "type": "Field",
- "subtype": "Boolean",
- "icon": "images/pz-checkbox-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT"
- },
- {
- "name": "hideLabel",
- "label": "Hide Label",
- "format": "BOOLEAN"
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "caption",
- "label": "Caption",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- },
- {
- "label": "Advanced",
- "format": "GROUP",
- "collapsible": true,
- "properties": [
- {
- "name": "testId",
- "label": "Test ID",
- "format": "TEXT",
- "ignorePattern": "[^-_\\p{N}\\p{L}]",
- "includeAnnotations": false
- }
- ]
- }
- ],
- "defaultConfig": {
- "label": "@L $this.label"
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/demo.stories.jsx b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/demo.stories.jsx
deleted file mode 100644
index de9fd078..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/demo.stories.jsx
+++ /dev/null
@@ -1,56 +0,0 @@
-import { useState } from 'react';
-import { withKnobs } from '@storybook/addon-knobs';
-
-import { configProps, stateProps } from './mock.stories';
-
-import PegaDxilMyBoolean from './index.tsx';
-
-export default {
- title: 'PegaDxilMyBoolean',
- decorators: [withKnobs],
- component: PegaDxilMyBoolean
-};
-
-export const BasePegaDxilMyBoolean = () => {
- const [value, setValue] = useState(configProps.value);
-
- const props = {
- value,
- label: configProps.label,
- helperText: configProps.helperText,
- caption: configProps.caption,
- testId: configProps.testId,
- trueLabel: configProps.trueLabel,
- falseLabel: configProps.falseLabel,
-
- getPConnect: () => {
- return {
- getStateProps: () => {
- return stateProps;
- },
- getConfigProps: () => {
- return configProps;
- },
- getActionsApi: () => {
- return {
- updateFieldValue: (propName, theValue) => {
- setValue(theValue);
- },
- triggerFieldChange: () => { /* nothing */}
- };
- },
- getValidationApi: () => {
- return {
- validate: () => { /* nothing */}
- };
- }
- };
- }
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/mock.stories.js b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/mock.stories.js
deleted file mode 100644
index d667da90..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/mock.stories.js
+++ /dev/null
@@ -1,15 +0,0 @@
-export const configProps = {
- "caption": "Boolean Caption",
- "value": false,
- "trueLabel": "Yes",
- "falseLabel": "No",
- "label": "Boolean Sample",
- "helperText": "Boolean Helper Text",
- "testId": "boolean-12345678",
- "hasSuggestions": false
-};
-
-export const stateProps = {
- "value": ".BooleanSample",
- "hasSuggestions": false
-};
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/pega-dxil-my-boolean.component.html b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/pega-dxil-my-boolean.component.html
deleted file mode 100644
index 291e1587..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/pega-dxil-my-boolean.component.html
+++ /dev/null
@@ -1,39 +0,0 @@
-
-
-
-
-
-
-
-
- {{ caption$ }}
-
-
- {{ caption$ }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/pega-dxil-my-boolean.component.scss b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/pega-dxil-my-boolean.component.scss
deleted file mode 100644
index 767c7526..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/pega-dxil-my-boolean.component.scss
+++ /dev/null
@@ -1,24 +0,0 @@
-.psdk-full-width {
- min-width: 9.375rem;
- width: 100%;
- text-align: left;
-}
-
-.psdk-label-readonly {
- top: 0rem;
- margin-top: 0.625rem;
- font-size: 0.875rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/pega-dxil-my-boolean.component.spec.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/pega-dxil-my-boolean.component.spec.ts
deleted file mode 100644
index 17c2e4a7..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/pega-dxil-my-boolean.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyBooleanComponent } from './pega-dxil-my-boolean.component';
-
-describe('PegaDxilMyBooleanComponent', () => {
- let component: PegaDxilMyBooleanComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyBooleanComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyBooleanComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/pega-dxil-my-boolean.component.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/pega-dxil-my-boolean.component.ts
deleted file mode 100644
index a93c6e3e..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-boolean/pega-dxil-my-boolean.component.ts
+++ /dev/null
@@ -1,165 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatCheckboxModule } from '@angular/material/checkbox';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { TextComponent } from '@pega/angular-sdk-library';
-import { FieldValueListComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-boolean',
- templateUrl: './pega-dxil-my-boolean.component.html',
- styleUrls: ['./pega-dxil-my-boolean.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatCheckboxModule, TextComponent, FieldValueListComponent]
-})
-export class PegaDxilMyBooleanComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: any = '';
- caption$: string = '';
- testId: string = '';
- showLabel$: boolean = false;
- checkboxLabelPos$ = 'after';
- isChecked$: boolean = false;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
- this.testId = this.configProps$['testId'];
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
-
- this.caption$ = this.configProps$['caption'];
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- if (this.label$ != '') {
- this.showLabel$ = true;
- }
-
- if (this.value$ === 'true' || this.value$ == true) {
- this.isChecked$ = true;
- } else {
- this.isChecked$ = false;
- }
- }
-
- fieldOnChange(event: any) {
- event.value = event.checked;
-
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- event.value = event.checked;
- this.angularPConnectData.actions.onBlur(this, event);
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-currency/config.json b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-currency/config.json
deleted file mode 100644
index e4729d98..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-currency/config.json
+++ /dev/null
@@ -1,125 +0,0 @@
-{
- "name": "Pega_DXIL_MyCurrency",
- "label": "My Currency",
- "description": "My Currency",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyCurrency",
- "type": "Field",
- "subtype": "Decimal-Currency",
- "icon": "images/pz-currency-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Label value",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "format": "CASCADE",
- "source": {
- "format": "SELECT",
- "label": "ISO Code Selection",
- "name": "isoCodeSelection",
- "defaultValue": "constant",
- "source": [
- {
- "key": "constant",
- "value": "Constant"
- },
- {
- "key": "propertyRef",
- "value": "Property Reference"
- }
- ]
- },
- "cascadeElements": [
- {
- "key": "currencyISOCode",
- "format": "TEXT",
- "name": "currencyISOCode",
- "label": "Currency ISO Code",
- "defaultValue": "USD",
- "match": "constant"
- },
- {
- "key": "currencyISOCode",
- "format": "PROPERTY",
- "name": "currencyISOCode",
- "label": "Currency ISO Code",
- "match": "propertyRef"
- }
- ]
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "allowDecimals",
- "label": "Allow Decimals",
- "format": "BOOLEAN",
- "defaultValue": true
- },
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- },
- {
- "label": "Advanced",
- "format": "GROUP",
- "collapsible": true,
- "properties": [
- {
- "name": "testId",
- "label": "Test ID",
- "format": "TEXT",
- "ignorePattern": "[^-_\\p{N}\\p{L}]",
- "includeAnnotations": false
- }
- ]
- }
- ],
- "defaultConfig": {
- "label": "@L $this.label"
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-currency/pega-dxil-my-currency.component.html b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-currency/pega-dxil-my-currency.component.html
deleted file mode 100644
index 2dfc9fde..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-currency/pega-dxil-my-currency.component.html
+++ /dev/null
@@ -1,30 +0,0 @@
-
-
-
-
-
- {{ label$ }}
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-currency/pega-dxil-my-currency.component.scss b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-currency/pega-dxil-my-currency.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-currency/pega-dxil-my-currency.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-currency/pega-dxil-my-currency.component.spec.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-currency/pega-dxil-my-currency.component.spec.ts
deleted file mode 100644
index 01a2e3f3..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-currency/pega-dxil-my-currency.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyCurrencyComponent } from './pega-dxil-my-currency.component';
-
-describe('PegaDxilMyCurrencyComponent', () => {
- let component: PegaDxilMyCurrencyComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyCurrencyComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyCurrencyComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-currency/pega-dxil-my-currency.component.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-currency/pega-dxil-my-currency.component.ts
deleted file mode 100644
index cb3ac4ec..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-currency/pega-dxil-my-currency.component.ts
+++ /dev/null
@@ -1,175 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { TextComponent } from '@pega/angular-sdk-library';
-import { FieldValueListComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-currency',
- templateUrl: './pega-dxil-my-currency.component.html',
- styleUrls: ['./pega-dxil-my-currency.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, TextComponent, FieldValueListComponent]
-})
-export class PegaDxilMyCurrencyComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: number;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- testId: string;
-
- fieldControl = new FormControl(null, null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // starting very simple...
-
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.testId = this.configProps$['testId'];
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
- let nValue = this.configProps$['value'];
- this.value$ = nValue && typeof nValue == 'string' ? parseFloat(nValue) : nValue;
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
-
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date-time/config.json b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date-time/config.json
deleted file mode 100644
index 03fc53eb..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date-time/config.json
+++ /dev/null
@@ -1,204 +0,0 @@
-{
- "name": "Pega_DXIL_MyDateTime",
- "label": "My DateTime",
- "description": "My DateTime",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyDateTime",
- "type": "Field",
- "subtype": "DateTime",
- "icon": "images/pz-date-time-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "format": "SELECT",
- "name": "clockFormat",
- "label": "Clock",
- "defaultValue": "use locale",
- "source": [
- {
- "key": 0,
- "value": "use locale"
- },
- {
- "key": 12,
- "value": "12 hours"
- },
- {
- "key": 24,
- "value": "24 hours"
- }
- ]
- },
- {
- "name": "withSeconds",
- "label": "Display Seconds",
- "format": "BOOLEAN"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "format": "LABEL",
- "label": "Year range",
- "variant": "secondary"
- },
- {
- "format": "INLINE",
- "elements": [
- {
- "key": "next",
- "format": "LABEL",
- "label": "Next",
- "variant": "secondary"
- },
- {
- "key": "nextYears",
- "format": "NUMBER",
- "label": "",
- "name": "nextYearRange",
- "min": 0
- },
- {
- "key": "year",
- "format": "LABEL",
- "label": "years",
- "variant": "secondary"
- }
- ]
- },
- {
- "format": "INLINE",
- "elements": [
- {
- "key": "previous",
- "format": "LABEL",
- "label": "Previous",
- "variant": "secondary"
- },
- {
- "key": "previousYears",
- "format": "NUMBER",
- "label": "",
- "name": "previousYearRange",
- "min": 0
- },
- {
- "key": "year",
- "format": "LABEL",
- "label": "years",
- "variant": "secondary"
- }
- ]
- },
- {
- "name": "showWeekNumber",
- "label": "Display week numbers on calendar",
- "format": "BOOLEAN"
- },
- {
- "format": "SELECT",
- "name": "pickerInterval",
- "label": "Time picker",
- "defaultValue": "30",
- "source": [
- {
- "key": "5",
- "value": "5 min"
- },
- {
- "key": "10",
- "value": "10 min"
- },
- {
- "key": "15",
- "value": "15 min"
- },
- {
- "key": "20",
- "value": "20 min"
- },
- {
- "key": "30",
- "value": "30 min"
- },
- {
- "key": "60",
- "value": "1 hr"
- }
- ]
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Read-only settings",
- "format": "GROUP",
- "properties": [
- {
- "name": "showAsFormattedText",
- "label": "Show as formatted text",
- "format": "BOOLEAN"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- },
- {
- "label": "Advanced",
- "format": "GROUP",
- "collapsible": true,
- "properties": [
- {
- "name": "testId",
- "label": "Test ID",
- "format": "TEXT",
- "ignorePattern": "[^-_\\p{N}\\p{L}]",
- "includeAnnotations": false
- }
- ]
- }
- ],
- "defaultConfig": {
- "label": "@L $this.label"
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date-time/pega-dxil-my-date-time.component.html b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date-time/pega-dxil-my-date-time.component.html
deleted file mode 100644
index cc153d21..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date-time/pega-dxil-my-date-time.component.html
+++ /dev/null
@@ -1,28 +0,0 @@
-
-
-
-
-
- {{ label$ }}
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date-time/pega-dxil-my-date-time.component.scss b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date-time/pega-dxil-my-date-time.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date-time/pega-dxil-my-date-time.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date-time/pega-dxil-my-date-time.component.spec.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date-time/pega-dxil-my-date-time.component.spec.ts
deleted file mode 100644
index dd255cc5..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date-time/pega-dxil-my-date-time.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed } from '@angular/core/testing';
-
-import { PegaDxilMyDateTimeComponent } from './pega-dxil-my-date-time.component';
-
-describe('PegaDxilMyDateTimeComponent', () => {
- let component: PegaDxilMyDateTimeComponent;
- let fixture: ComponentFixture;
-
- beforeEach(async () => {
- await TestBed.configureTestingModule({
- declarations: [ PegaDxilMyDateTimeComponent ]
- })
- .compileComponents();
- });
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyDateTimeComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date-time/pega-dxil-my-date-time.component.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date-time/pega-dxil-my-date-time.component.ts
deleted file mode 100644
index fa38d6ce..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date-time/pega-dxil-my-date-time.component.ts
+++ /dev/null
@@ -1,177 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { TextComponent } from '@pega/angular-sdk-library';
-import { FieldValueListComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-date-time',
- templateUrl: './pega-dxil-my-date-time.component.html',
- styleUrls: ['./pega-dxil-my-date-time.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, TextComponent, FieldValueListComponent]
-})
-export class PegaDxilMyDateTimeComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: any;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- testId: string = '';
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
- // Then, continue on with other initialization
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // starting very simple...
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
- this.testId = this.configProps$['testId'];
- if (this.configProps$['value'] != undefined) {
- const value = this.configProps$['value'];
- this.value$ = value ? value.replace('Z', '') : value;
- }
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- if (event.target.value) {
- event.value = event.target.value;
- }
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- if (event.target.value) event.value = event.target.value;
-
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
- return errMessage;
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date/config.json b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date/config.json
deleted file mode 100644
index 335c5dad..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date/config.json
+++ /dev/null
@@ -1,147 +0,0 @@
-{
- "name": "Pega_DXIL_MyDate",
- "label": "My Date",
- "description": "My Date",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyDate",
- "type": "Field",
- "subtype": "Date",
- "icon": "images/pz-date-time-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "format": "LABEL",
- "label": "Year range",
- "variant": "secondary"
- },
- {
- "format": "INLINE",
- "elements": [
- {
- "key": "next",
- "format": "LABEL",
- "label": "Next",
- "variant": "secondary"
- },
- {
- "key": "nextYears",
- "format": "NUMBER",
- "label": "",
- "name": "nextYearRange",
- "min": 0
- },
- {
- "key": "year",
- "format": "LABEL",
- "label": "years",
- "variant": "secondary"
- }
- ]
- },
- {
- "format": "INLINE",
- "elements": [
- {
- "key": "previous",
- "format": "LABEL",
- "label": "Previous",
- "variant": "secondary"
- },
- {
- "key": "previousYears",
- "format": "NUMBER",
- "label": "",
- "name": "previousYearRange",
- "min": 0
- },
- {
- "key": "year",
- "format": "LABEL",
- "label": "years",
- "variant": "secondary"
- }
- ]
- },
- {
- "name": "showWeekNumber",
- "label": "Display week numbers on calendar",
- "format": "BOOLEAN"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Read-only settings",
- "format": "GROUP",
- "properties": [
- {
- "name": "showAsFormattedText",
- "label": "Show as formatted text",
- "format": "BOOLEAN"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- },
- {
- "label": "Advanced",
- "format": "GROUP",
- "collapsible": true,
- "properties": [
- {
- "name": "testId",
- "label": "Test ID",
- "format": "TEXT",
- "ignorePattern": "[^-_\\p{N}\\p{L}]",
- "includeAnnotations": false
- }
- ]
- }
- ],
- "defaultConfig": {
- "label": "@L $this.label"
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date/pega-dxil-my-date.component.html b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date/pega-dxil-my-date.component.html
deleted file mode 100644
index 106d9615..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date/pega-dxil-my-date.component.html
+++ /dev/null
@@ -1,32 +0,0 @@
-
-
-
-
-
- {{ label$ }}
-
-
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date/pega-dxil-my-date.component.scss b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date/pega-dxil-my-date.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date/pega-dxil-my-date.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date/pega-dxil-my-date.component.spec.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date/pega-dxil-my-date.component.spec.ts
deleted file mode 100644
index 7a882a17..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date/pega-dxil-my-date.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyDateComponent } from './pega-dxil-my-date.component';
-
-describe('PegaDxilMyDateComponent', () => {
- let component: PegaDxilMyDateComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyDateComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyDateComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date/pega-dxil-my-date.component.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date/pega-dxil-my-date.component.ts
deleted file mode 100644
index 142f88a2..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-date/pega-dxil-my-date.component.ts
+++ /dev/null
@@ -1,209 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatDatepickerModule } from '@angular/material/datepicker';
-import { MatNativeDateModule } from '@angular/material/core';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { TextComponent } from '@pega/angular-sdk-library';
-import { FieldValueListComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-date',
- templateUrl: './pega-dxil-my-date.component.html',
- styleUrls: ['./pega-dxil-my-date.component.scss'],
- standalone: true,
- imports: [
- CommonModule,
- ReactiveFormsModule,
- MatFormFieldModule,
- MatInputModule,
- MatDatepickerModule,
- MatNativeDateModule,
- TextComponent,
- FieldValueListComponent
- ]
-})
-export class PegaDxilMyDateComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
- label$: string = '';
- value$: any;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- testId: string = '';
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // starting very simple...
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- if (this.configProps$['value'] != undefined) {
- let sDateValue: any = '';
- sDateValue = this.configProps$['value'];
-
- if (sDateValue != '') {
- if (typeof sDateValue == 'object') {
- sDateValue = sDateValue.toISOString();
- } else if (sDateValue.indexOf('/') < 0) {
- // if we have the "pega" format, then for display, convert to standard format (US)
- // sDateValue = this.formatDate(sDateValue);
- sDateValue = this.utils.generateDate(sDateValue, 'Date-Long-Custom-YYYY');
- }
- this.value$ = new Date(sDateValue);
- }
- }
- this.testId = this.configProps$['testId'];
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnDateChange(event: any, sValue: string) {
- // this comes from the date pop up
- if (typeof event.value == 'object') {
- // convert date to pega "date" format
- event.value = event.value.toISOString();
- }
- this.angularPConnectData.actions.onChange(this, { value: event.value });
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- if (typeof event.value == 'object') {
- event.value = event.value.toISOString();
- // convert date to pega "date" format
- event.value = event.value.toISOString();
- }
- this.angularPConnectData.actions.onBlur(this, { value: event.value });
- }
-
- hasErrors() {
- return this.fieldControl.status === 'INVALID';
- }
-
- getErrorMessage() {
- let errMessage: string = '';
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = `${this.fieldControl.errors.matDatepickerParse.text} is not a valid date value`;
- }
- return errMessage;
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-decimal/config.json b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-decimal/config.json
deleted file mode 100644
index 059c14f5..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-decimal/config.json
+++ /dev/null
@@ -1,94 +0,0 @@
-{
- "name": "Pega_DXIL_MyDecimal",
- "label": "My Decimal",
- "description": "My Decimal",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyDecimal",
- "type": "Field",
- "subtype": "Decimal",
- "icon": "images/pz-decimal-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "name": "decimalPrecision",
- "label": "Decimal places",
- "format": "NUMBER",
- "min": 0
- },
- {
- "name": "showGroupSeparators",
- "label": "Show thousands separator",
- "format": "BOOLEAN"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- },
- {
- "label": "Advanced",
- "format": "GROUP",
- "collapsible": true,
- "properties": [
- {
- "name": "testId",
- "label": "Test ID",
- "format": "TEXT",
- "ignorePattern": "[^-_\\p{N}\\p{L}]",
- "includeAnnotations": false
- }
- ]
- }
- ],
- "defaultConfig": {
- "label": "@L $this.label"
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-decimal/pega-dxil-my-decimal.component.html b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-decimal/pega-dxil-my-decimal.component.html
deleted file mode 100644
index 03036c89..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-decimal/pega-dxil-my-decimal.component.html
+++ /dev/null
@@ -1,29 +0,0 @@
-
-
-
-
-
- {{ label$ }}
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-decimal/pega-dxil-my-decimal.component.scss b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-decimal/pega-dxil-my-decimal.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-decimal/pega-dxil-my-decimal.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-decimal/pega-dxil-my-decimal.component.spec.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-decimal/pega-dxil-my-decimal.component.spec.ts
deleted file mode 100644
index f63d3837..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-decimal/pega-dxil-my-decimal.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyDecimalComponent } from './pega-dxil-my-decimal.component';
-
-describe('PegaDxilMyDecimalComponent', () => {
- let component: PegaDxilMyDecimalComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyDecimalComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyDecimalComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-decimal/pega-dxil-my-decimal.component.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-decimal/pega-dxil-my-decimal.component.ts
deleted file mode 100644
index 81ca2e17..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-decimal/pega-dxil-my-decimal.component.ts
+++ /dev/null
@@ -1,170 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { TextComponent } from '@pega/angular-sdk-library';
-import { FieldValueListComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-decimal',
- templateUrl: './pega-dxil-my-decimal.component.html',
- styleUrls: ['./pega-dxil-my-decimal.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, TextComponent, FieldValueListComponent]
-})
-export class PegaDxilMyDecimalComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: number;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- testId: string;
-
- fieldControl = new FormControl(null, null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // starting very simple...
-
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.testId = this.configProps$['testId'];
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
- let nValue = this.configProps$['value'];
- if (nValue) {
- if (typeof nValue == 'string') {
- nValue = parseFloat(nValue);
- }
- this.value$ = nValue;
- }
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
- }
-
- fieldOnChange(event: any) {
- // this.angularPConnect.changeHandler( this, event );
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-email/config.json b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-email/config.json
deleted file mode 100644
index f24dc5d3..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-email/config.json
+++ /dev/null
@@ -1,83 +0,0 @@
-{
- "name": "Pega_DXIL_MyEmail",
- "label": "My Email",
- "description": "My Email",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyEmail",
- "type": "Field",
- "subtype": "Text-Email",
- "icon": "images/pz-email-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- },
- {
- "label": "Advanced",
- "format": "GROUP",
- "collapsible": true,
- "properties": [
- {
- "name": "testId",
- "label": "Test ID",
- "format": "TEXT",
- "ignorePattern": "[^-_\\p{N}\\p{L}]",
- "includeAnnotations": false
- }
- ]
- }
- ],
- "defaultConfig": {
- "label": "@L $this.label"
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-email/pega-dxil-my-email.component.html b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-email/pega-dxil-my-email.component.html
deleted file mode 100644
index 499e72d0..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-email/pega-dxil-my-email.component.html
+++ /dev/null
@@ -1,28 +0,0 @@
-
-
-
-
-
- {{ label$ }}
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-email/pega-dxil-my-email.component.scss b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-email/pega-dxil-my-email.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-email/pega-dxil-my-email.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-email/pega-dxil-my-email.component.spec.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-email/pega-dxil-my-email.component.spec.ts
deleted file mode 100644
index 606d5cec..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-email/pega-dxil-my-email.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyEmailComponent } from './pega-dxil-my-email.component';
-
-describe('PegaDxilMyEmailComponent', () => {
- let component: PegaDxilMyEmailComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyEmailComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyEmailComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-email/pega-dxil-my-email.component.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-email/pega-dxil-my-email.component.ts
deleted file mode 100644
index ba126a38..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-email/pega-dxil-my-email.component.ts
+++ /dev/null
@@ -1,175 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { TextComponent } from '@pega/angular-sdk-library';
-import { FieldValueListComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-email',
- templateUrl: './pega-dxil-my-email.component.html',
- styleUrls: ['./pega-dxil-my-email.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, TextComponent, FieldValueListComponent]
-})
-export class PegaDxilMyEmailComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: string;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- testId: string;
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.testId = this.configProps$['testId'];
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
-
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-integer/config.json b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-integer/config.json
deleted file mode 100644
index 88979bea..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-integer/config.json
+++ /dev/null
@@ -1,88 +0,0 @@
-{
- "name": "Pega_DXIL_MyInteger",
- "label": "My Integer",
- "description": "My Integer",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyInteger",
- "type": "Field",
- "subtype": "Integer",
- "icon": "images/pz-integer-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "name": "showGroupSeparators",
- "label": "Show thousands separator",
- "format": "BOOLEAN"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- },
- {
- "label": "Advanced",
- "format": "GROUP",
- "collapsible": true,
- "properties": [
- {
- "name": "testId",
- "label": "Test ID",
- "format": "TEXT",
- "ignorePattern": "[^-_\\p{N}\\p{L}]",
- "includeAnnotations": false
- }
- ]
- }
- ],
- "defaultConfig": {
- "label": "@L $this.label"
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-integer/pega-dxil-my-integer.component.html b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-integer/pega-dxil-my-integer.component.html
deleted file mode 100644
index b61419c9..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-integer/pega-dxil-my-integer.component.html
+++ /dev/null
@@ -1,30 +0,0 @@
-
-
-
-
-
-
- {{ label$ }}
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-integer/pega-dxil-my-integer.component.scss b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-integer/pega-dxil-my-integer.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-integer/pega-dxil-my-integer.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-integer/pega-dxil-my-integer.component.spec.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-integer/pega-dxil-my-integer.component.spec.ts
deleted file mode 100644
index f994c117..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-integer/pega-dxil-my-integer.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyIntegerComponent } from './pega-dxil-my-integer.component';
-
-describe('PegaDxilMyIntegerComponent', () => {
- let component: PegaDxilMyIntegerComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyIntegerComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyIntegerComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-integer/pega-dxil-my-integer.component.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-integer/pega-dxil-my-integer.component.ts
deleted file mode 100644
index 0df13520..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-integer/pega-dxil-my-integer.component.ts
+++ /dev/null
@@ -1,180 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { TextComponent } from '@pega/angular-sdk-library';
-import { FieldValueListComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-integer',
- templateUrl: './pega-dxil-my-integer.component.html',
- styleUrls: ['./pega-dxil-my-integer.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, TextComponent, FieldValueListComponent]
-})
-export class PegaDxilMyIntegerComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: number;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- testId: string;
-
- fieldControl = new FormControl(null, null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.testId = this.configProps$['testId'];
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
- let nValue = this.configProps$['value'];
- if (nValue) {
- if (typeof nValue == 'string') {
- nValue = parseInt(nValue);
- }
- this.value$ = nValue;
- }
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- // field control gets error message from here
-
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-paragraph/config.json b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-paragraph/config.json
deleted file mode 100644
index f84e9697..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-paragraph/config.json
+++ /dev/null
@@ -1,83 +0,0 @@
-{
- "name": "Pega_DXIL_MyParagraph",
- "label": "My Paragraph",
- "description": "My Paragraph",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyParagraph",
- "type": "Field",
- "subtype": "Text-Paragraph",
- "icon": "images/pz-text-area-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- },
- {
- "label": "Advanced",
- "format": "GROUP",
- "collapsible": true,
- "properties": [
- {
- "name": "testId",
- "label": "Test ID",
- "format": "TEXT",
- "ignorePattern": "[^-_\\p{N}\\p{L}]",
- "includeAnnotations": false
- }
- ]
- }
- ],
- "defaultConfig": {
- "label": "@L $this.label"
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-paragraph/pega-dxil-my-paragraph.component.html b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-paragraph/pega-dxil-my-paragraph.component.html
deleted file mode 100644
index 7e2962bd..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-paragraph/pega-dxil-my-paragraph.component.html
+++ /dev/null
@@ -1,28 +0,0 @@
-
-
-
-
-
-
-
-
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-paragraph/pega-dxil-my-paragraph.component.scss b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-paragraph/pega-dxil-my-paragraph.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-paragraph/pega-dxil-my-paragraph.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-paragraph/pega-dxil-my-paragraph.component.spec.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-paragraph/pega-dxil-my-paragraph.component.spec.ts
deleted file mode 100644
index d3d2a7ba..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-paragraph/pega-dxil-my-paragraph.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyParagraphComponent } from './pega-dxil-my-paragraph.component';
-
-describe('PegaDxilMyParagraphComponent', () => {
- let component: PegaDxilMyParagraphComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyParagraphComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyParagraphComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-paragraph/pega-dxil-my-paragraph.component.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-paragraph/pega-dxil-my-paragraph.component.ts
deleted file mode 100644
index 313988ad..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-paragraph/pega-dxil-my-paragraph.component.ts
+++ /dev/null
@@ -1,179 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-paragraph',
- templateUrl: './pega-dxil-my-paragraph.component.html',
- styleUrls: ['./pega-dxil-my-paragraph.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class PegaDxilMyParagraphComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: string = '';
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- nMaxLength$: number;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- testId: string;
- helperText: string;
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
- this.nMaxLength$ = this.pConn$.getFieldMetadata(this.pConn$.getRawConfigProps()?.value)?.maxLength || 100;
- this.testId = this.configProps$['testId'];
- this.displayMode$ = this.configProps$['displayMode'];
- this.label$ = this.configProps$['label'];
- this.helperText = this.configProps$['helperText'];
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- // PConnect wants to use changeHandler for onChange
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- // field control gets error message from here
-
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-percentage/config.json b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-percentage/config.json
deleted file mode 100644
index da8bef1c..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-percentage/config.json
+++ /dev/null
@@ -1,94 +0,0 @@
-{
- "name": "Pega_DXIL_MyPercentage",
- "label": "My Percentage",
- "description": "My Percentage",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyPercentage",
- "type": "Field",
- "subtype": "Decimal-Percentage",
- "icon": "images/pz-text-input-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "name": "decimalPrecision",
- "label": "Decimal places",
- "format": "NUMBER",
- "min": 0
- },
- {
- "name": "showGroupSeparators",
- "label": "Show thousands separator",
- "format": "BOOLEAN"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- },
- {
- "label": "Advanced",
- "format": "GROUP",
- "collapsible": true,
- "properties": [
- {
- "name": "testId",
- "label": "Test ID",
- "format": "TEXT",
- "ignorePattern": "[^-_\\p{N}\\p{L}]",
- "includeAnnotations": false
- }
- ]
- }
- ],
- "defaultConfig": {
- "label": "@L $this.label"
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-percentage/pega-dxil-my-percentage.component.html b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-percentage/pega-dxil-my-percentage.component.html
deleted file mode 100644
index 2c4da1db..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-percentage/pega-dxil-my-percentage.component.html
+++ /dev/null
@@ -1,30 +0,0 @@
-
-
-
-
-
- {{ label$ }}
-
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-percentage/pega-dxil-my-percentage.component.scss b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-percentage/pega-dxil-my-percentage.component.scss
deleted file mode 100644
index af04528b..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-percentage/pega-dxil-my-percentage.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
- }
-
- .psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(.75) perspective(100px) translateZ(.001px);
- -ms-transform: translateY(-1.28125em) scale(.75);
- width: 133.33333%;
- }
-
- .psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
- }
-
- ::ng-deep .mat-mdc-form-field-infix {
- width: auto;
- }
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-percentage/pega-dxil-my-percentage.component.spec.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-percentage/pega-dxil-my-percentage.component.spec.ts
deleted file mode 100644
index 3691b681..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-percentage/pega-dxil-my-percentage.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed } from '@angular/core/testing';
-
-import { PegaDxilMyPercentageComponent } from './pega-dxil-my-percentage.component';
-
-describe('PegaDxilMyPercentageComponent', () => {
- let component: PegaDxilMyPercentageomponent;
- let fixture: ComponentFixture;
-
- beforeEach(async () => {
- await TestBed.configureTestingModule({
- declarations: [ PegaDxilMyPercentageComponent ]
- })
- .compileComponents();
- });
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyPercentageComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-percentage/pega-dxil-my-percentage.component.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-percentage/pega-dxil-my-percentage.component.ts
deleted file mode 100644
index ac3e9598..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-percentage/pega-dxil-my-percentage.component.ts
+++ /dev/null
@@ -1,176 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { TextComponent } from '@pega/angular-sdk-library';
-import { FieldValueListComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-percentage',
- templateUrl: './pega-dxil-my-percentage.component.html',
- styleUrls: ['./pega-dxil-my-percentage.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, TextComponent, FieldValueListComponent]
-})
-export class PegaDxilMyPercentageComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: number;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- testId: string;
-
- fieldControl = new FormControl(null, null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.testId = this.configProps$['testId'];
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
- let nValue = this.configProps$['value'];
- if (nValue) {
- if (typeof nValue == 'string') {
- nValue = parseInt(nValue);
- }
- this.value$ = nValue;
- }
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
-
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- // field control gets error message from here
- let errMessage: string = '';
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
- return errMessage;
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-phone/config.json b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-phone/config.json
deleted file mode 100644
index e7d1b669..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-phone/config.json
+++ /dev/null
@@ -1,95 +0,0 @@
-{
- "name": "Pega_DXIL_MyPhone",
- "label": "My Phone",
- "description": "My Phone",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyPhone",
- "type": "Field",
- "subtype": "Text-Phone",
- "icon": "images/pz-phone-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "name": "showCountryCode",
- "label": "Show Country Code",
- "format": "BOOLEAN",
- "defaultValue": true
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- },
- {
- "label": "Advanced",
- "format": "GROUP",
- "collapsible": true,
- "properties": [
- {
- "name": "testId",
- "label": "Test ID",
- "format": "TEXT",
- "ignorePattern": "[^-_\\p{N}\\p{L}]",
- "includeAnnotations": false
- }
- ]
- }
- ],
- "defaultConfig": {
- "label": "@L $this.label",
- "datasource": {
- "source": "@DATASOURCE D_pyCountryCallingCodeList.pxResults",
- "fields": {
- "value": "@P .pyCallingCode"
- }
- }
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-phone/pega-dxil-my-phone.component.html b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-phone/pega-dxil-my-phone.component.html
deleted file mode 100644
index 5b8bf052..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-phone/pega-dxil-my-phone.component.html
+++ /dev/null
@@ -1,27 +0,0 @@
-
-
-
-
-
-
-
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-phone/pega-dxil-my-phone.component.scss b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-phone/pega-dxil-my-phone.component.scss
deleted file mode 100644
index 40d8f616..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-phone/pega-dxil-my-phone.component.scss
+++ /dev/null
@@ -1,81 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
-
-.phone-label-readonly {
- opacity: 54%;
- font-size: 0.7rem;
-}
-
-::ng-deep .iti {
- display: block !important;
- margin-bottom: 20px;
-
- .dropdown-menu.country-dropdown {
- border-top-left-radius: 0px;
- border-top-right-radius: 0px;
- border-color: #c7cace;
- margin-top: -1px;
- }
-
- .iti__country-list {
- box-shadow: none;
- font-size: 14px;
- margin-left: 0;
- width: 244px;
- max-height: 170px;
- }
-
- .search-container input {
- font-size: 14px;
- border-color: #c7cace;
- border-radius: 0;
- padding: 5px 10px;
- }
-
- .search-container input:focus {
- outline: none;
- }
-}
-
-::ng-deep .iti__flag-container.open + input {
- border-bottom-left-radius: 0px;
- border-bottom-right-radius: 0px;
-}
-
-::ng-deep ngx-mat-intl-tel-input {
- .country-selector {
- opacity: 1 !important;
- bottom: 8px !important;
- }
-
- input:not(.country-search) {
- bottom: 3px;
- left: 10px;
- }
-
- .country-list-button {
- font-size: 0.8rem !important;
- }
-
- .mat-menu-content:not(:empty) {
- max-height: 250px;
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-phone/pega-dxil-my-phone.component.spec.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-phone/pega-dxil-my-phone.component.spec.ts
deleted file mode 100644
index aed2e13c..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-phone/pega-dxil-my-phone.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyPhoneComponent } from './pega-dxil-my-phone.component';
-
-describe('PegaDxilMyPhoneComponent', () => {
- let component: PegaDxilMyPhoneComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyPhoneComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyPhoneComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-phone/pega-dxil-my-phone.component.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-phone/pega-dxil-my-phone.component.ts
deleted file mode 100644
index ed32fe91..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-phone/pega-dxil-my-phone.component.ts
+++ /dev/null
@@ -1,194 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { NgxMatIntlTelInputComponent } from 'ngx-mat-intl-tel-input';
-import { Utils } from '@pega/angular-sdk-library';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { handleEvent } from '@pega/angular-sdk-library';
-import { TextComponent } from '@pega/angular-sdk-library';
-import { FieldValueListComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-phone',
- templateUrl: './pega-dxil-my-phone.component.html',
- styleUrls: ['./pega-dxil-my-phone.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, NgxMatIntlTelInputComponent, TextComponent, FieldValueListComponent]
-})
-export class PegaDxilMyPhoneComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: string;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- testId: string;
- separateDialCode = false;
- afterBlur: boolean;
-
- fieldControl = new FormControl('', null);
-
- phoneForm = new FormGroup({
- phone: new FormControl(undefined)
- });
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
- this.testId = this.configProps$['testId'];
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- if (this.bReadonly$) {
- this.phoneForm.setValue({ phone: this.value$ });
- }
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- if (this.formGroup$.controls[this.controlName$].value) {
- const actionsApi = this.pConn$?.getActionsApi();
- const propName = this.pConn$?.getStateProps().value;
- const value = this.formGroup$.controls[this.controlName$].value;
- const eventObj = {
- target: {
- value
- }
- };
- this.afterBlur = true;
- this.angularPConnectData.actions.onChange(this, eventObj);
- handleEvent(actionsApi, 'blur', propName, value);
- }
- }
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = 'Invalid Phone';
- }
-
- return errMessage;
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-picklist/config.json b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-picklist/config.json
deleted file mode 100644
index ae0d4cbc..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-picklist/config.json
+++ /dev/null
@@ -1,86 +0,0 @@
-{
- "name": "Pega_DXIL_MyPicklist",
- "label": "My Picklist",
- "description": "My Picklist",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyPicklist",
- "type": "Field",
- "subtype": "Picklist",
- "icon": "images/pz-dropdown-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- },
- {
- "label": "Advanced",
- "format": "GROUP",
- "collapsible": true,
- "properties": [
- {
- "name": "testId",
- "label": "Test ID",
- "format": "TEXT",
- "ignorePattern": "[^-_\\p{N}\\p{L}]",
- "includeAnnotations": false
- }
- ]
- }
- ],
- "defaultConfig": {
- "label": "@L $this.label",
- "placeholder": "@L Select...",
- "listType": "associated",
- "datasource": "@ASSOCIATED .$this.name"
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-picklist/pega-dxil-my-picklist.component.html b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-picklist/pega-dxil-my-picklist.component.html
deleted file mode 100644
index 349a06d0..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-picklist/pega-dxil-my-picklist.component.html
+++ /dev/null
@@ -1,27 +0,0 @@
-
-
-
-
-
-
-
- {{ opt.value }}
-
-
- {{ label$ }}
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-picklist/pega-dxil-my-picklist.component.scss b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-picklist/pega-dxil-my-picklist.component.scss
deleted file mode 100644
index 1f792ffe..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-picklist/pega-dxil-my-picklist.component.scss
+++ /dev/null
@@ -1,25 +0,0 @@
-.psdk-form {
- min-width: 9.375rem;
- width: 100%;
-}
-
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-picklist/pega-dxil-my-picklist.component.spec.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-picklist/pega-dxil-my-picklist.component.spec.ts
deleted file mode 100644
index 1d87f6c6..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-picklist/pega-dxil-my-picklist.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyPicklistComponent } from './pega-dxil-my-picklist.component';
-
-describe('PegaDxilMyPicklistComponent', () => {
- let component: PegaDxilMyPicklistComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyPicklistComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyPicklistComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-picklist/pega-dxil-my-picklist.component.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-picklist/pega-dxil-my-picklist.component.ts
deleted file mode 100644
index bd8b4e07..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-picklist/pega-dxil-my-picklist.component.ts
+++ /dev/null
@@ -1,195 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatOptionModule } from '@angular/material/core';
-import { MatSelectModule } from '@angular/material/select';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { TextComponent } from '@pega/angular-sdk-library';
-import { FieldValueListComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-picklist',
- templateUrl: './pega-dxil-my-picklist.component.html',
- styleUrls: ['./pega-dxil-my-picklist.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatSelectModule, MatOptionModule, TextComponent, FieldValueListComponent]
-})
-export class PegaDxilMyPicklistComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: string = '';
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- options$: Array;
- componentReference: string = '';
- testId: string = '';
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
-
- this.testId = this.configProps$['testId'];
- this.displayMode$ = this.configProps$['displayMode'];
- this.label$ = this.configProps$['label'];
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- const optionsList = this.utils.getOptionList(this.configProps$, this.pConn$.getDataObject());
- optionsList?.unshift({ key: 'Select', value: 'Select...' });
- this.options$ = optionsList;
- if (this.value$ === '' && !this.bReadonly$) {
- this.value$ = 'Select';
- }
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- isSelected(buttonValue: string): boolean {
- if (this.value$ === buttonValue) {
- return true;
- }
-
- return false;
- }
-
- fieldOnChange(event: any) {
- if (event?.value === 'Select') {
- event.value = '';
- }
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text-input/config.json b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text-input/config.json
deleted file mode 100644
index 06571142..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text-input/config.json
+++ /dev/null
@@ -1,83 +0,0 @@
-{
- "name": "Pega_DXIL_MyTextInput",
- "label": "My Text Input",
- "description": "My Text Input",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyTextInput",
- "type": "Field",
- "subtype": "Text",
- "icon": "images/pz-url-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- },
- {
- "label": "Advanced",
- "format": "GROUP",
- "collapsible": true,
- "properties": [
- {
- "name": "testId",
- "label": "Test ID",
- "format": "TEXT",
- "ignorePattern": "[^-_\\p{N}\\p{L}]",
- "includeAnnotations": false
- }
- ]
- }
- ],
- "defaultConfig": {
- "label": "@L $this.label"
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text-input/pega-dxil-my-text-input.component.html b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text-input/pega-dxil-my-text-input.component.html
deleted file mode 100644
index 9e180e82..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text-input/pega-dxil-my-text-input.component.html
+++ /dev/null
@@ -1,28 +0,0 @@
-
-
-
-
-
- {{ label$ }}
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text-input/pega-dxil-my-text-input.component.scss b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text-input/pega-dxil-my-text-input.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text-input/pega-dxil-my-text-input.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text-input/pega-dxil-my-text-input.component.spec.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text-input/pega-dxil-my-text-input.component.spec.ts
deleted file mode 100644
index 2aab5616..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text-input/pega-dxil-my-text-input.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyTextInputComponent } from './pega-dxil-my-text-input.component';
-
-describe('PegaDxilMyTextInputComponent', () => {
- let component: PegaDxilMyTextInputComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyTextInputComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyTextInputComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text-input/pega-dxil-my-text-input.component.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text-input/pega-dxil-my-text-input.component.ts
deleted file mode 100644
index 335257a9..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text-input/pega-dxil-my-text-input.component.ts
+++ /dev/null
@@ -1,177 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { TextComponent } from '@pega/angular-sdk-library';
-import { FieldValueListComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-text-input',
- templateUrl: './pega-dxil-my-text-input.component.html',
- styleUrls: ['./pega-dxil-my-text-input.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, TextComponent, FieldValueListComponent]
-})
-export class PegaDxilMyTextInputComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // For interaction with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: string = '';
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- testId: string = '';
- bHasForm$: boolean = true;
- componentReference: string = '';
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- // this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
-
- this.testId = this.configProps$['testId'];
-
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text/config.json b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text/config.json
deleted file mode 100644
index ce4cedd5..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text/config.json
+++ /dev/null
@@ -1,83 +0,0 @@
-{
- "name": "Pega_DXIL_MyText",
- "label": "My Text",
- "description": "My Text",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyText",
- "type": "Field",
- "subtype": "Text",
- "icon": "images/pz-url-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- },
- {
- "label": "Advanced",
- "format": "GROUP",
- "collapsible": true,
- "properties": [
- {
- "name": "testId",
- "label": "Test ID",
- "format": "TEXT",
- "ignorePattern": "[^-_\\p{N}\\p{L}]",
- "includeAnnotations": false
- }
- ]
- }
- ],
- "defaultConfig": {
- "label": "@L $this.label"
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text/pega-dxil-my-text.component.html b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text/pega-dxil-my-text.component.html
deleted file mode 100644
index d135b05c..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text/pega-dxil-my-text.component.html
+++ /dev/null
@@ -1,14 +0,0 @@
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text/pega-dxil-my-text.component.scss b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text/pega-dxil-my-text.component.scss
deleted file mode 100644
index bee2b661..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text/pega-dxil-my-text.component.scss
+++ /dev/null
@@ -1,30 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- opacity: 54%;
- font-size: 0.7rem;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
-
-.psdk-grid-filter {
- display: grid;
- grid-template-columns: repeat(2, minmax(0, 1fr));
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
-
-.psdk-details-fields-label {
- color: rgba(0, 0, 0, 0.54);
- margin: 8px 0px;
-}
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text/pega-dxil-my-text.component.spec.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text/pega-dxil-my-text.component.spec.ts
deleted file mode 100644
index 282a65d2..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text/pega-dxil-my-text.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyTextComponent } from './pega-dxil-my-text.component';
-
-describe('PegaDxilMyTextComponent', () => {
- let component: PegaDxilMyTextComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyTextComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyTextComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text/pega-dxil-my-text.component.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text/pega-dxil-my-text.component.ts
deleted file mode 100644
index 1a62a118..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-text/pega-dxil-my-text.component.ts
+++ /dev/null
@@ -1,145 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-text',
- templateUrl: './pega-dxil-my-text.component.html',
- styleUrls: ['./pega-dxil-my-text.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class PegaDxilMyTextComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formatAs$: string;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: string = '';
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- componentReference: string = '';
- formattedValue$: string;
- format$: string = 'text';
- formattedUrl$: string = '';
-
- constructor(private angularPConnect: AngularPConnectService, private utils: Utils) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- this.checkAndUpdate();
- }
-
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
-
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
-
- // TDB - get formats
- switch (this.formatAs$) {
- case 'text':
- this.formattedValue$ = this.value$;
- break;
- case 'date':
- this.formattedValue$ = this.generateDate(this.value$);
- break;
- case 'date-time':
- this.formattedValue$ = this.generateDateTime(this.value$);
- break;
- case 'time':
- if (this.value$) {
- const timeParts = this.value$.split(':');
- this.formattedValue$ = `${timeParts[0]}:${timeParts[1]}`;
- } else {
- this.formattedValue$ = '';
- }
- break;
- case 'url':
- this.formattedUrl$ = this.generateUrl(this.value$);
- this.formattedValue$ = this.value$;
- break;
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- generateUrl(sVal): string {
- if (sVal.indexOf('https://') == 0 || sVal.indexOf('http://') == 0) {
- } else {
- // assume no http
- sVal = 'http://' + sVal;
- }
-
- return sVal;
- }
-
- generateDate(sVal): string {
- if (!sVal) return '';
- // const value = new Intl.DateTimeFormat('default', {
- // year: 'numeric',
- // month: 'numeric',
- // day: 'numeric'
- // }).format(new Date(sVal + "T00:00"));
-
- return this.utils.generateDate(sVal, 'Date-Long-Custom-YYYY');
- }
-
- generateDateTime(sVal): string {
- if (!sVal) return '';
- if (sVal.length === 10) return this.generateDate(sVal);
- let value = sVal.substring(0, sVal.length - 1);
- // value = new Intl.DateTimeFormat('default', {
- // year: 'numeric',
- // month: 'numeric',
- // day: 'numeric',
- // hour: 'numeric',
- // minute: 'numeric',
- // second: 'numeric',
- // hour12: true,
- // }).format(new Date(value))
-
- return this.utils.generateDateTime(value, 'DateTime-Long-YYYY-Custom');
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-time-of-day/config.json b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-time-of-day/config.json
deleted file mode 100644
index d4add5b5..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-time-of-day/config.json
+++ /dev/null
@@ -1,135 +0,0 @@
-{
- "name": "Pega_DXIL_MyTimeOfDay",
- "label": "My TimeOfDay",
- "description": "My TimeOfDay",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyTimeOfDay",
- "type": "Field",
- "subtype": "TimeOfDay",
- "icon": "images/pz-date-time-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "format": "SELECT",
- "name": "clockFormat",
- "label": "Clock",
- "defaultValue": "use locale",
- "source": [
- {
- "key": 0,
- "value": "use locale"
- },
- {
- "key": 12,
- "value": "12 hours"
- },
- {
- "key": 24,
- "value": "24 hours"
- }
- ]
- },
- {
- "name": "withSeconds",
- "label": "Display Seconds",
- "format": "BOOLEAN"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "format": "SELECT",
- "name": "pickerInterval",
- "label": "Time picker",
- "defaultValue": "30",
- "source": [
- {
- "key": "5",
- "value": "5 min"
- },
- {
- "key": "10",
- "value": "10 min"
- },
- {
- "key": "15",
- "value": "15 min"
- },
- {
- "key": "20",
- "value": "20 min"
- },
- {
- "key": "30",
- "value": "30 min"
- },
- {
- "key": "60",
- "value": "1 hr"
- }
- ]
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- },
- {
- "label": "Advanced",
- "format": "GROUP",
- "collapsible": true,
- "properties": [
- {
- "name": "testId",
- "label": "Test ID",
- "format": "TEXT",
- "ignorePattern": "[^-_\\p{N}\\p{L}]",
- "includeAnnotations": false
- }
- ]
- }
- ],
- "defaultConfig": {
- "label": "@L $this.label"
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-time-of-day/pega-dxil-my-time-of-day.component.html b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-time-of-day/pega-dxil-my-time-of-day.component.html
deleted file mode 100644
index 5f343c50..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-time-of-day/pega-dxil-my-time-of-day.component.html
+++ /dev/null
@@ -1,27 +0,0 @@
-
-
-
-
-
- {{ label$ }}
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-time-of-day/pega-dxil-my-time-of-day.component.scss b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-time-of-day/pega-dxil-my-time-of-day.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-time-of-day/pega-dxil-my-time-of-day.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-time-of-day/pega-dxil-my-time-of-day.component.spec.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-time-of-day/pega-dxil-my-time-of-day.component.spec.ts
deleted file mode 100644
index 170186ed..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-time-of-day/pega-dxil-my-time-of-day.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyTimeOfDayComponent } from './pega-dxil-my-time-of-day.component';
-
-describe('PegaDxilMyTimeOfDayComponent', () => {
- let component: PegaDxilMyTimeOfDayComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyTimeOfDayComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyTimeOfDayComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-time-of-day/pega-dxil-my-time-of-day.component.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-time-of-day/pega-dxil-my-time-of-day.component.ts
deleted file mode 100644
index 176d4a00..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-time-of-day/pega-dxil-my-time-of-day.component.ts
+++ /dev/null
@@ -1,172 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { TextComponent } from '@pega/angular-sdk-library';
-import { FieldValueListComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-time-of-day',
- templateUrl: './pega-dxil-my-time-of-day.component.html',
- styleUrls: ['./pega-dxil-my-time-of-day.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, TextComponent, FieldValueListComponent]
-})
-export class PegaDxilMyTimeOfDayComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: string;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
-
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- event.value = event.target.value;
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- event.value = event.target.value;
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
- return errMessage;
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-url/config.json b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-url/config.json
deleted file mode 100644
index 26b75710..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-url/config.json
+++ /dev/null
@@ -1,111 +0,0 @@
-{
- "name": "Pega_DXIL_MyURL",
- "label": "My URL",
- "description": "My URL",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyURL",
- "type": "Field",
- "subtype": "Text-URL",
- "icon": "images/pz-text-input-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Column settings",
- "format": "GROUP",
- "visibility": "@VIEWTYPE == 'MultiRecordDisplayAsTable'",
- "properties": [
- {
- "name": "columnWidth",
- "label": "Column width",
- "format": "SELECT",
- "source": [
- {
- "key": "auto",
- "value": "Auto"
- },
- {
- "key": "custom",
- "value": "Custom"
- }
- ]
- },
- {
- "name": "width",
- "label": "Width (px)",
- "format": "NUMBER",
- "visibility": "$this.columnWidth == 'custom'"
- }
- ]
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- },
- {
- "label": "Advanced",
- "format": "GROUP",
- "collapsible": true,
- "properties": [
- {
- "name": "testId",
- "label": "Test ID",
- "format": "TEXT",
- "ignorePattern": "[^-_\\p{N}\\p{L}]",
- "includeAnnotations": false
- }
- ]
- }
- ],
- "defaultConfig": {
- "label": "@L $this.label"
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-url/pega-dxil-my-url.component.html b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-url/pega-dxil-my-url.component.html
deleted file mode 100644
index a326928b..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-url/pega-dxil-my-url.component.html
+++ /dev/null
@@ -1,27 +0,0 @@
-
-
-
-
-
- {{ label$ }}
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-url/pega-dxil-my-url.component.scss b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-url/pega-dxil-my-url.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-url/pega-dxil-my-url.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-url/pega-dxil-my-url.component.spec.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-url/pega-dxil-my-url.component.spec.ts
deleted file mode 100644
index e71145d7..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-url/pega-dxil-my-url.component.spec.ts
+++ /dev/null
@@ -1,26 +0,0 @@
-
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyUrlComponent } from './pega-dxil-my-url.component';
-
-describe('PegaDxilMyUrlComponent', () => {
- let component: PegaDxilMyUrlComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyUrlComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyUrlComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-url/pega-dxil-my-url.component.ts b/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-url/pega-dxil-my-url.component.ts
deleted file mode 100644
index dde834bb..00000000
--- a/tests/assets/components/createAll/custom-sdk/field/pega-dxil-my-url/pega-dxil-my-url.component.ts
+++ /dev/null
@@ -1,174 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { TextComponent } from '@pega/angular-sdk-library';
-import { FieldValueListComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-url',
- templateUrl: './pega-dxil-my-url.component.html',
- styleUrls: ['./pega-dxil-my-url.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, TextComponent, FieldValueListComponent]
-})
-export class PegaDxilMyUrlComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: string = '';
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
-
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/template/_template.md b/tests/assets/components/createAll/custom-sdk/template/_template.md
deleted file mode 100644
index f5875c69..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/_template.md
+++ /dev/null
@@ -1,6 +0,0 @@
-# The **custom-sdk/template** directory
-
-The **src/components/custom-sdk/template** directory contains the code for the custom **template** components you want to create and use with the **Angular SDK**.
-
-When you run the **npm run create** command to create new _template_ components, the generated code that you can use as a starting point for your component development
-will be placed in component-specific folders in **src/components/custom-sdk/template**.
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/DefaultForm.svg b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/DefaultForm.svg
deleted file mode 100644
index 9fe86e70..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/DefaultForm.svg
+++ /dev/null
@@ -1,29 +0,0 @@
-
-
- 2 col copy
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/config.json b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/config.json
deleted file mode 100644
index fadc5560..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/config.json
+++ /dev/null
@@ -1,21 +0,0 @@
-{
- "name": "Pega_DXIL_MyDetails",
- "label": "My Details",
- "description": "My Details",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyDetails",
- "type": "Template",
- "subtype": "DETAILS",
- "icon": "DefaultForm.svg",
- "properties": [
- {
- "name": "A",
- "label": "Region A",
- "format": "CONTENTPICKER",
- "addTypeList": ["Fields", "Views", "UIComponents"]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/demo.stories.jsx b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/demo.stories.jsx
deleted file mode 100644
index 0d1cffee..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/demo.stories.jsx
+++ /dev/null
@@ -1,71 +0,0 @@
-import { withKnobs } from "@storybook/addon-knobs";
-
-import PegaDxilMyDetails from "./index.tsx";
-
-import operatorDetails, { pyReviewRaw } from "./mock.stories";
-
-export default {
- title: "PegaDxilMyDetails",
- decorators: [withKnobs],
- component: PegaDxilMyDetails,
- parameters: {
- type: "Details",
- },
-};
-
-if (!window.PCore) {
- window.PCore = {};
-}
-
-window.PCore.getUserApi = () => {
- return {
- getOperatorDetails: () => {
- return new Promise((resolve) => {
- resolve(operatorDetails);
- });
- },
- };
-};
-
-window.PCore.getEnvironmentInfo = () => {
- return {
- getUseLocale: () => {
- return "en-US";
- },
- };
-};
-
-export const BasePegaDxilMyDetails = () => {
- const props = {
- NumCols: "1",
- template: "DefaultForm",
- showHighlightedData: false,
- label: "Details",
- showLabel: true,
- getPConnect: () => {
- return {
- getChildren: () => {
- return pyReviewRaw.children[0].children;
- },
- getRawMetadata: () => {
- return pyReviewRaw;
- },
- getInheritedProps: () => {
- return pyReviewRaw.config.inheritedProps;
- },
- setInheritedProp: () => {
- /* nothing */
- },
- resolveConfigProps: () => {
- /* nothing */
- },
- };
- },
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/mock.stories.js b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/mock.stories.js
deleted file mode 100644
index 7ad86b15..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/mock.stories.js
+++ /dev/null
@@ -1,294 +0,0 @@
-const operatorDetails = {
- data: {
- pzLoadTime: "January 18, 2023 10:33:19 AM EST",
- pzPageNameHash: "_pa1519192551088960pz",
- pyOperatorInfo: {
- pyUserName: "french DigV2",
- pyPosition: "",
- pyImageInsKey: "",
- pySkills: [
- {
- pySkillName: "",
- pzIndexOwnerKey: "DATA-ADMIN-OPERATOR-ID FRENCHTEST.DIGV2",
- pySkillRating: 0,
- },
- ],
- pyReportToUserName: "",
- pyReportTo: "",
- pyOrganization: "DXIL",
- pyTitle: "",
- pyLabel: "frenchTest.DigV2",
- pyEmailAddress: "User@DigV2",
- pyTelephone: "",
- },
- },
- status: 200,
- statusText: "",
- headers: {
- "content-length": "435",
- "content-type": "application/json;charset=UTF-8",
- },
- request: {},
-};
-
-export default operatorDetails;
-
-export const pyReviewRaw = {
- name: "pyReview",
- type: "View",
- config: {
- template: "Details",
- ruleClass: "MyCo-MyCompon-Work-MyComponents",
- showLabel: true,
- label: "@L Details",
- localeReference: "@LR MYCO-MYCOMPON-WORK-MYCOMPONENTS!VIEW!PYREVIEW",
- showHighlightedData: true,
- highlightedData: [
- {
- type: "TextInput",
- config: {
- value: "@P .pyStatusWork",
- label: "@L Work Status",
- displayMode: "STACKED_LARGE_VAL",
- displayAsStatus: true,
- },
- },
- {
- type: "TextInput",
- config: {
- value: "@P .pyID",
- label: "@L Case ID",
- displayMode: "STACKED_LARGE_VAL",
- },
- },
- {
- type: "DateTime",
- config: {
- value: "@P .pxCreateDateTime",
- label: "@L Create date/time",
- displayMode: "STACKED_LARGE_VAL",
- },
- },
- {
- type: "UserReference",
- config: {
- label: "@L Create Operator",
- value: "@USER .pxCreateOperator",
- placeholder: "Select...",
- displayMode: "STACKED_LARGE_VAL",
- },
- },
- ],
- inheritedProps: [
- {
- prop: "label",
- value: "@L Details",
- },
- {
- prop: "showLabel",
- value: true,
- },
- ],
- },
- children: [
- {
- name: "A",
- type: "Region",
- getPConnect: () => {
- return {
- getRawMetadata: () => {
- return pyReviewRaw.children[0];
- },
- };
- },
- children: [
- {
- readOnly: undefined,
- placeholder: "First Name",
- value: "John",
- label: "First Name",
- hasSuggestions: false,
- displayMode: "LABELS_LEFT",
- },
- {
- readOnly: undefined,
- placeholder: "Middle Name",
- value: "",
- label: "Middle Name",
- hasSuggestions: false,
- displayMode: "LABELS_LEFT",
- },
- {
- readOnly: undefined,
- placeholder: "Last Name",
- value: "Doe",
- label: "Last Name",
- hasSuggestions: false,
- displayMode: "LABELS_LEFT",
- },
- {
- value: "john@doe.com",
- label: "Email",
- required: true,
- testId: "CE8AE9DA5B7CD6C3DF2929543A9AF92D",
- hasSuggestions: false,
- displayMode: "LABELS_LEFT",
- },
- {
- readOnly: undefined,
- value: "+16397975093",
- label: "Phone",
- displayMode: "LABELS_LEFT",
- hasSuggestions: false,
- },
- {
- readOnly: undefined,
- placeholder: "Price",
- value: "90.99",
- label: "Price",
- hasSuggestions: false,
- displayMode: "LABELS_LEFT",
- getPConnect: () => {
- return {
- getActionsApi: () => {/* nothing */},
- getStateProps: () => {
- return {
- value: "",
- };
- },
- getComponentName: () => {
- return "currency";
- },
- };
- },
- },
- {
- readOnly: undefined,
- value: "100 Mbps",
- label: "Internet Plan",
- hasSuggestions: false,
- displayMode: "LABELS_LEFT",
- getPConnect: () => {
- return {
- getActionsApi: () => {/* nothing */},
- getStateProps: () => {
- return {
- value: "",
- };
- },
- getComponentName: () => {
- return "radio";
- },
- getConfigProps: () => {
- return {};
- },
- getDataObject: () => {
- return {};
- },
- };
- },
- },
- {
- caseOpConfig: {
- label: "Update operator",
- createLabel: "Created",
- updateLabel: "Updated",
- updateDateTime: "2023-03-10T12:53:04.670Z",
- createDateTime: "2023-03-10T12:52:20.054Z",
- updateOperator: {
- userId: "User.DigV2",
- userName: "User DigV2",
- },
- createOperator: {
- userId: "User.DigV2",
- userName: "User DigV2",
- },
- },
- },
- ],
- },
- ],
- classID: "MyCo-MyCompon-Work-MyComponents",
-};
-
-export const pyReviewResolved = {
- readOnly: true,
- template: "Details",
- ruleClass: "MyCo-MyCompon-Work-MyComponents",
- showLabel: true,
- label: "Details",
- localeReference: "MYCO-MYCOMPON-WORK-MYCOMPONENTS!VIEW!PYREVIEW",
- showHighlightedData: true,
- highlightedData: [
- {
- type: "TextInput",
- config: {
- value: "New",
- label: "Work Status",
- displayMode: "STACKED_LARGE_VAL",
- displayAsStatus: true,
- },
- },
- {
- type: "TextInput",
- config: {
- value: "M-1002",
- label: "Case ID",
- displayMode: "STACKED_LARGE_VAL",
- },
- },
- {
- type: "DateTime",
- config: {
- value: "2022-12-11T20:06:27.232Z",
- label: "Create date/time",
- displayMode: "STACKED_LARGE_VAL",
- },
- },
- {
- type: "UserReference",
- config: {
- label: "Create Operator",
- value: {
- userId: "conns",
- userName: "Sara Connor",
- },
- placeholder: "Select...",
- displayMode: "STACKED_LARGE_VAL",
- },
- },
- ],
- displayMode: "LABELS_LEFT",
-};
-
-export const regionChildrenResolved = [
- {
- readOnly: true,
- value: "",
- label: "SLA Deadline",
- displayMode: "LABELS_LEFT",
- },
- {
- readOnly: true,
- value: "",
- label: "SLA Goal",
- displayMode: "LABELS_LEFT",
- },
- {
- readOnly: true,
- value: "",
- label: "SLA Start Time",
- listType: "associated",
- datasource: [
- {
- key: "AssignmentCreation",
- value: "The creation time of the Assignment",
- },
- {
- key: "CurrentTime",
- value: "Current Date Time",
- },
- ],
- displayMode: "LABELS_LEFT",
- },
-];
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/pega-dxil-my-details.component.html b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/pega-dxil-my-details.component.html
deleted file mode 100644
index 9bab94e3..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/pega-dxil-my-details.component.html
+++ /dev/null
@@ -1,7 +0,0 @@
-
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/pega-dxil-my-details.component.scss b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/pega-dxil-my-details.component.scss
deleted file mode 100644
index be9bb2d2..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/pega-dxil-my-details.component.scss
+++ /dev/null
@@ -1,7 +0,0 @@
-.psdk-grid-filter {
- display: grid;
- grid-template-columns: repeat(2, minmax(0, 1fr));
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/pega-dxil-my-details.component.spec.ts b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/pega-dxil-my-details.component.spec.ts
deleted file mode 100644
index 8f57e55f..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/pega-dxil-my-details.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyDetailsComponent } from './pega-dxil-my-details.component';
-
-describe('PegaDxilMyDetailsComponent', () => {
- let component: PegaDxilMyDetailsComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyDetailsComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyDetailsComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/pega-dxil-my-details.component.ts b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/pega-dxil-my-details.component.ts
deleted file mode 100644
index 4b20badf..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-details/pega-dxil-my-details.component.ts
+++ /dev/null
@@ -1,121 +0,0 @@
-import { Component, OnInit, Input } from '@angular/core';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { MaterialDetailsComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-details',
- templateUrl: './pega-dxil-my-details.component.html',
- styleUrls: ['./pega-dxil-my-details.component.scss'],
- standalone: true,
- imports: [MaterialDetailsComponent]
-})
-export class PegaDxilMyDetailsComponent implements OnInit {
- constructor(private angularPConnect: AngularPConnectService) {}
-
- @Input() pConn$: any;
-
- PCore$: any;
-
- highlightedDataArr: Array = [];
- showHighlightedData: boolean;
- arFields$: Array = [];
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
-
- ngOnInit(): void {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
-
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- //this.updateSelf();
- this.checkAndUpdate();
- }
-
- ngOnDestroy() {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- const rawMetaData = this.pConn$.resolveConfigProps(this.pConn$.getRawMetadata().config);
- this.showHighlightedData = rawMetaData?.showHighlightedData;
-
- if( this.showHighlightedData ){
- const highlightedData = rawMetaData?.highlightedData;
- this.highlightedDataArr = highlightedData.map(field => {
- field.config.displayMode = 'STACKED_LARGE_VAL';
-
- if (field.config.value === '@P .pyStatusWork') {
- field.type = 'TextInput';
- field.config.displayAsStatus = true;
- }
-
- return field;
- });
- }
-
- let kids = this.pConn$.getChildren();
- for (let kid of kids) {
- this.arFields$ = [];
- let pKid = kid.getPConnect();
- const fields = pKid.getChildren();
- fields?.forEach((field) => {
- const thePConn = field.getPConnect();
- const theCompType = thePConn.getComponentName().toLowerCase();
- if (theCompType === 'reference') {
- const configProps = thePConn.getConfigProps();
- configProps.readOnly = true;
- configProps.displayMode = 'LABELS_LEFT';
- const propToUse = { ...thePConn.getInheritedProps() };
- configProps.label = propToUse?.label;
- const options = {
- context: thePConn.getContextName(),
- pageReference: thePConn.getPageReference(),
- referenceList: thePConn.getReferenceList()
- };
- const viewContConfig = {
- meta: {
- type: theCompType,
- config: configProps
- },
- options
- };
- const theViewCont = this.PCore$.createPConnect(viewContConfig);
- const data = {
- type: theCompType,
- pConn: theViewCont?.getPConnect()
- };
- this.arFields$.push(data);
- } else {
- const data = {
- type: theCompType,
- config: thePConn.getConfigProps()
- };
- this.arFields$.push(data);
- }
- });
- }
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/DefaultForm.svg b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/DefaultForm.svg
deleted file mode 100644
index 9fe86e70..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/DefaultForm.svg
+++ /dev/null
@@ -1,29 +0,0 @@
-
-
- 2 col copy
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/config.json b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/config.json
deleted file mode 100644
index 98107e5d..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/config.json
+++ /dev/null
@@ -1,45 +0,0 @@
-{
- "name": "Pega_DXIL_MyForm",
- "label": "My Form",
- "description": "My Form",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyForm",
- "type": "Template",
- "subtype": "FORM",
- "icon": "DefaultForm.svg",
- "properties": [
- {
- "format": "SELECT",
- "name": "NumCols",
- "label": "Number of columns",
- "defaultValue": "1",
- "source": [
- { "key": "1", "value": "One" },
- { "key": "2", "value": "Two" },
- { "key": "3", "value": "Three" }
- ]
- },
- {
- "format": "SELECT",
- "name": "templateOverrideMode",
- "label": "Template for embedded views",
- "defaultValue": "USE_TEMPLATE",
- "source": [
- { "key": "USE_TEMPLATE", "value": "Use template" },
- { "key": "IGNORE_TEMPLATE", "value": "Ignore template" }
- ]
- },
- {
- "format": "INSTRUCTIONS"
- },
- {
- "name": "Fields",
- "label": "Fields",
- "format": "CONTENTPICKER",
- "allowCreatingGroup": true
- }
- ]
-}
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/demo.stories.jsx b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/demo.stories.jsx
deleted file mode 100644
index b03bc18d..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/demo.stories.jsx
+++ /dev/null
@@ -1,215 +0,0 @@
-import { useState } from 'react';
-
-import { withKnobs } from '@storybook/addon-knobs';
-
-import PegaDxilMyForm from './index.tsx';
-
-export default {
- title: 'PegaDxilMyForm',
- decorators: [withKnobs],
- component: PegaDxilMyForm
-};
-
-if (!window.PCore) {
- window.PCore = {};
-}
-
-window.PCore.getErrorHandler = () => {
- return {
- getGenericFailedMessage() {
- /* nothing */
- }
- };
-};
-
-window.PCore.getConstants = () => {
- return {
- CASE_INFO: {
- INSTRUCTIONS: ""
- }
- }
-};
-
-export const BasePegaDxilMyForm = () => {
-
- const [firstName, setFirstName] = useState('John');
- const [middleName, setMiddleName] = useState('');
- const [lastName, setLastName] = useState('Joe');
- const [phone, setPhone] = useState('+16397975093');
- const [suffix, setSuffix] = useState('');
- const [email, setEmail] = useState('john@doe.com');
-
- const props = {
- NumCols: "1",
- template: 'DefaultForm',
-
- getPConnect: () => {
- return {
- getChildren: () => {
- return [
- {
- getPConnect: () => {
- return {
- getChildren: () => {
- return [
- {
- readOnly: undefined,
- placeholder: 'First Name',
- value: firstName,
- label: 'First Name',
- hasSuggestions: false,
- onChange: val => {
- setFirstName(val.target.value);
- }
- },
- {
- readOnly: undefined,
- placeholder: 'Middle Name',
- value: middleName,
- label: 'Middle Name',
- hasSuggestions: false,
- onChange: val => {
- setMiddleName(val.target.value);
- }
- },
-
- {
- value: lastName,
- label: 'Last Name',
- required: true,
- placeholder: 'Last Name',
- testId: '77587239BF4C54EA493C7033E1DBF636',
- hasSuggestions: false,
- onChange: val => {
- setLastName(val.target.value);
- }
- },
-
- {
- readOnly: undefined,
- value: phone,
- label: 'Phone Number',
- datasource: {
- fields: {
- value: undefined
- },
- source: [
- {
- value: '+1'
- },
- {
- value: '+91'
- },
- {
- value: '+48'
- },
- {
- value: '+44'
- }
- ]
- },
- hasSuggestions: false,
- onChange: val => {
- setPhone(val.value);
- },
- onBlur: () => {
- /* nothing */
- }
- },
-
- {
- value: suffix,
- label: 'Suffix',
- placeholder: 'Select...',
- listType: 'associated',
- datasource: [
- {
- key: 'Sr',
- value: 'Sr'
- },
- {
- key: 'Jr',
- value: 'Jr'
- },
- {
- key: 'III',
- value: 'III'
- },
- {
- key: 'IV',
- value: 'IV'
- },
- {
- key: 'V',
- value: 'V'
- }
- ],
- testId: '56E6DDD1CB6CEC596B433440DFB21C17',
- hasSuggestions: false,
- deferDatasource: false,
- getPConnect: () => {
- return {
- getContextName: () => {
- return null;
- },
- getDataObject: () => {
- return null;
- },
- getActionsApi: () => {
- return {
- updateFieldValue: (propName, value) => {
- setSuffix(value);
- },
- triggerFieldChange: () => {
- /* nothing */
- }
- };
- },
- getStateProps: () => {
- return {
- value: ''
- };
- }
- };
- },
- onChange: val => {
- setSuffix(val.target.value);
- }
- },
-
- {
- value: email,
- label: 'Email',
- required: true,
- testId: 'CE8AE9DA5B7CD6C3DF2929543A9AF92D',
- hasSuggestions: false,
- onChange: val => {
- setEmail(val.target.value);
- }
- }
- ];
- }
- };
- }
- }
- ];
- },
- getValue: (val) => {
- return val;
- },
- getCurrentView: () => {
- return "";
- },
- getCurrentClassID: () => {
- return "";
- }
- };
- }
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/pega-dxil-my-form.component.html b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/pega-dxil-my-form.component.html
deleted file mode 100644
index a9b23146..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/pega-dxil-my-form.component.html
+++ /dev/null
@@ -1,20 +0,0 @@
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/pega-dxil-my-form.component.scss b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/pega-dxil-my-form.component.scss
deleted file mode 100644
index 0d25bbaf..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/pega-dxil-my-form.component.scss
+++ /dev/null
@@ -1,33 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-.psdk-default-form-one-column {
- display: grid;
- grid-template-columns: repeat(1, minmax(0, 1fr));
- gap: calc(1rem);
-}
-
-.psdk-default-form-two-column {
- display: grid;
- grid-template-columns: repeat(2, 1fr);
- gap: calc(1rem);
-}
-
-.psdk-default-form-three-column {
- display: grid;
- grid-template-columns: repeat(3, 1fr);
- gap: calc(1rem);
-}
-
-.psdk-default-form-two-column .grid-column {
- grid-column: 1 / span 2;
-}
-
-.psdk-default-form-three-column .grid-column {
- grid-column: 1 / span 3;
-}
-
-.template-title-container {
- font-size: calc(0.9375rem);
- font-weight: 600;
- margin: 10px 0px;
-}
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/pega-dxil-my-form.component.spec.ts b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/pega-dxil-my-form.component.spec.ts
deleted file mode 100644
index 985f1486..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/pega-dxil-my-form.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyFormComponent } from './pega-dxil-my-form.component';
-
-describe('PegaDxilMyFormComponent', () => {
- let component: PegaDxilMyFormComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyFormComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyFormComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/pega-dxil-my-form.component.ts b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/pega-dxil-my-form.component.ts
deleted file mode 100644
index 9ec90d89..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-form/pega-dxil-my-form.component.ts
+++ /dev/null
@@ -1,71 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { ReferenceComponent } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-import { TemplateUtils } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-pega-dxil-my-form',
- templateUrl: './pega-dxil-my-form.component.html',
- styleUrls: ['./pega-dxil-my-form.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class PegaDxilMyFormComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- configProps$: Object;
- arChildren$: Array;
- divClass$: string;
- template: any;
- showLabel: any;
- label: any;
- instructions: string;
-
- NO_HEADER_TEMPLATES = [
- 'SubTabs',
- 'SimpleTable',
- 'Details',
- 'DetailsTwoColumn',
- 'DetailsThreeColumn',
- 'NarrowWideDetails',
- 'WideNarrowDetails',
- 'Confirmation'
- ];
-
- constructor(private templateUtils: TemplateUtils) {}
-
- ngOnInit(): void {
- let configProps = this.pConn$.getConfigProps();
- this.template = configProps?.template;
- const propToUse = { ...this.pConn$.getInheritedProps() };
- this.showLabel = propToUse?.showLabel;
- this.label = propToUse?.label;
- let kids = this.pConn$.getChildren();
- this.instructions = this.templateUtils.getInstructions(this.pConn$, configProps?.instructions);
- console.log("instructions" + this.instructions);
-
- let numCols = configProps.NumCols ? configProps.NumCols : '1';
- switch (numCols) {
- case '1':
- this.divClass$ = 'psdk-default-form-one-column';
- break;
- case '2':
- this.divClass$ = 'psdk-default-form-two-column';
- break;
- case '3':
- this.divClass$ = 'psdk-default-form-three-column';
- break;
- default:
- this.divClass$ = 'psdk-default-form-one-column';
- break;
- }
-
- // repoint children before getting templateArray
- // Children may contain 'reference' component, so we need to
- // normalize them
- this.arChildren$ = ReferenceComponent.normalizePConnArray(kids[0].getPConnect().getChildren());
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/OneColumnPage.svg b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/OneColumnPage.svg
deleted file mode 100644
index da2634ed..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/OneColumnPage.svg
+++ /dev/null
@@ -1,28 +0,0 @@
-
-
- 1-col icon
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- A
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/config.json b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/config.json
deleted file mode 100644
index b7a36c63..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/config.json
+++ /dev/null
@@ -1,32 +0,0 @@
-{
- "name": "Pega_DXIL_MyPage",
- "label": "My Page",
- "description": "My Page",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyPage",
- "type": "Template",
- "subtype": "PAGE",
- "icon": "OneColumnPage.svg",
- "properties": [
- {
- "name": "useConfigurableLayout",
- "label": "Use inline layout for insights",
- "format": "BOOLEAN"
- },
- {
- "name": "enableGetNextWork",
- "label": "Enable Get next work",
- "format": "BOOLEAN"
- },
- {
- "name": "A",
- "label": "Region A",
- "format": "CONTENTPICKER",
- "addTypeList": ["Widgets", "Views", "Insights"]
- }
- ],
- "defaultConfig": {}
-}
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/demo.stories.jsx b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/demo.stories.jsx
deleted file mode 100644
index 7bbfcc6a..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/demo.stories.jsx
+++ /dev/null
@@ -1,80 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-
-import AppAnnouncement from "@pega/react-sdk-components/lib/components/widget/AppAnnouncement";
-
-import { pyHome1Resolved, pyHome1Raw } from './mock.stories';
-
-import PegaDxilMyPage from './index.tsx';
-
-export default {
- title: 'PegaDxilMyPage',
- decorators: [withKnobs],
- component: PegaDxilMyPage
-};
-
-export const BasePegaDxilMyPage = () => {
-
- const configProps = pyHome1Resolved.children[0].children[0].config;
-
- const props = {
- getPConnect: () => {
- return {
- getStateProps: () => {
- return {};
- },
- getActionsApi: () => {
- return {
- getNextWork: () => {
- return new Promise(resolve => {
- resolve({});
- });
- },
- updateFieldValue: () => {/* nothing */},
- triggerFieldChange: () => {/* nothing */}
- };
- },
- getChildren: () => {
- return pyHome1Raw.children;
- },
- getComponentName: () => {
- return '';
- },
- getLocalizedValue: value => {
- return value;
- },
- getRawMetadata: () => {
- return pyHome1Raw;
- },
- createComponent: config => {
- if(config.type === 'AppAnnouncement') {
- return (
-
- );
- }
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- setInheritedProps: () => {/* nothing */},
- resolveConfigProps: () => {/* nothing */}
- };
- }
- };
-
- const regionAChildren = pyHome1Raw.children[0].children.map(child => {
- return props.getPConnect().createComponent(child);
- });
-
- return (
- <>
- {regionAChildren}
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/mock.stories.js b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/mock.stories.js
deleted file mode 100644
index 67eb333b..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/mock.stories.js
+++ /dev/null
@@ -1,115 +0,0 @@
-export const pyHome1Raw = {
- name: 'pyHome1',
- type: 'View',
- config: {
- type: 'landingpage',
- template: 'OneColumnPage',
- icon: 'home-solid',
- title: '@ENV APPLICATION_DESC',
- ruleClass: 'DIXL-MediaCo-UIPages',
- localeReference: '@LR DIXL-MEDIACO-UIPAGES!PAGE!PYHOME1',
- enableGetNextWork: true,
- context: 'pyPortal'
- },
- children: [
- {
- name: 'A',
- type: 'Region',
- children: [
- {
- type: 'AppAnnouncement',
- config: {
- label: '@L App announcement',
- description:
- "We've launched a brand new experience to accelerate your workflow. Check out the guides to help you get the most of Cosmos.",
- whatsnewlink: 'https://design.pega.com',
- image:
- '',
- datasource: {
- source: [
- {
- "name": "New React based UI rendering"
- },
- {
- "name": "Support for followers and recents"
- },
- {
- "name": "New authoring experience"
- }
- ],
- fields: {
- name: '@P .pyLabel'
- }
- }
- }
- }
- ]
- }
- ],
- classID: 'DIXL-MediaCo-UIPages'
-};
-
-export const pyHome1Resolved = {
- name: 'pyHome1',
- type: 'View',
- config: {
- type: 'landingpage',
- template: 'OneColumnPage',
- icon: 'home-solid',
- title: '@ENV APPLICATION_DESC',
- ruleClass: 'DIXL-MediaCo-UIPages',
- localeReference: '@LR DIXL-MEDIACO-UIPAGES!PAGE!PYHOME1',
- enableGetNextWork: true,
- context: 'pyPortal'
- },
- children: [
- {
- name: 'A',
- type: 'Region',
- getPConnect: () => {
- return {
- getComponentName: () => {
- return '';
- },
- getComponent: () => {
- return pyHome1Resolved.children[0];
- },
- getConfigProps: () => {
- return {};
- }
- };
- },
- children: [
- {
- type: 'AppAnnouncement',
- config: {
- label: '@L App announcement',
- description:
- "We've launched a brand new experience to accelerate your workflow. Check out the guides to help you get the most of Cosmos.",
- whatsnewlink: 'https://design.pega.com',
- image:
- '',
- datasource: {
- source: [
- {
- "name": "New React based UI rendering"
- },
- {
- "name": "Support for followers and recents"
- },
- {
- "name": "New authoring experience"
- }
- ]
- ,
- fields: {
- name: '@P .pyLabel'
- }
- }
- }
- }
- ]
- }
- ],
- classID: 'DIXL-MediaCo-UIPages'
-};
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/pega-dxil-my-page.component.html b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/pega-dxil-my-page.component.html
deleted file mode 100644
index c8cab928..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/pega-dxil-my-page.component.html
+++ /dev/null
@@ -1,12 +0,0 @@
-
-
{{ title$ }}
-
-
-
-
-
-
-
PegaDxilMyPage Missing: {{ kid.getPConnect().getComponentName() }}
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/pega-dxil-my-page.component.scss b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/pega-dxil-my-page.component.scss
deleted file mode 100644
index 541a2eb2..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/pega-dxil-my-page.component.scss
+++ /dev/null
@@ -1,3 +0,0 @@
-.psdk-page-title {
- padding-left: 0.2rem;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/pega-dxil-my-page.component.spec.ts b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/pega-dxil-my-page.component.spec.ts
deleted file mode 100644
index a4d4b398..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/pega-dxil-my-page.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyPageComponent } from './pega-dxil-my-page.component';
-
-describe('PegaDxilMyPageComponent', () => {
- let component: PegaDxilMyPageComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyPageComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyPageComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/pega-dxil-my-page.component.ts b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/pega-dxil-my-page.component.ts
deleted file mode 100644
index ea333cfc..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-page/pega-dxil-my-page.component.ts
+++ /dev/null
@@ -1,63 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { RegionComponent } from '@pega/angular-sdk-library';
-import { ViewComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-pega-dxil-my-page',
- templateUrl: './pega-dxil-my-page.component.html',
- styleUrls: ['./pega-dxil-my-page.component.scss'],
- standalone: true,
- imports: [CommonModule, RegionComponent, forwardRef(() => ViewComponent)]
-})
-export class PegaDxilMyPageComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
-
- configProps$: Object;
- arChildren$: Array;
- title$: string;
-
- constructor(private angularPConnect: AngularPConnectService) {}
-
- ngOnInit() {
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.arChildren$ = this.pConn$.getChildren();
-
- this.title$ = this.configProps$['title'];
- let operator = this.configProps$['operator'];
-
- if (operator && operator != '') {
- this.title$ += ', ' + operator;
- }
-
- // when showing a page, similar to updating root, need to cause viewContainer to call "initContainer"
- sessionStorage.setItem('hasViewContainer', 'false');
- }
-
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- onStateChange() {
- // Should always check the bridge to see if the component should update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- // AND removing the "gate" that was put there since shouldComponentUpdate
- // should be the real "gate"
- if (bUpdateSelf) {
- // turn off spinner
- //this.psService.sendMessage(false);
- }
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/TwoColumnDetails.svg b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/TwoColumnDetails.svg
deleted file mode 100644
index 4d15fcd0..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/TwoColumnDetails.svg
+++ /dev/null
@@ -1,28 +0,0 @@
-
-
- 2 col
-
-
-
-
-
-
-
-
-
-
-
-
-
- B
-
-
-
- A
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/config.json b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/config.json
deleted file mode 100644
index f96796f3..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/config.json
+++ /dev/null
@@ -1,27 +0,0 @@
-{
- "name": "Pega_DXIL_MyTwoColumnDetails",
- "label": "My Two Column Details",
- "description": "My Two Column Details",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyTwoColumnDetails",
- "type": "Template",
- "subtype": "DETAILS",
- "icon": "TwoColumnDetails.svg",
- "properties": [
- {
- "name": "A",
- "label": "Region A",
- "format": "CONTENTPICKER",
- "addTypeList": ["Fields", "Views", "UIComponents"]
- },
- {
- "name": "B",
- "label": "Region B",
- "format": "CONTENTPICKER",
- "addTypeList": ["Fields", "Views", "UIComponents"]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/demo.stories.jsx b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/demo.stories.jsx
deleted file mode 100644
index 6ef06e90..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/demo.stories.jsx
+++ /dev/null
@@ -1,73 +0,0 @@
-import { withKnobs } from "@storybook/addon-knobs";
-
-import PegaDxilMyTwoColumnDetails from "./index.tsx";
-
-import operatorDetails, { pyReviewRaw } from "./mock.stories";
-
-export default {
- title: "PegaDxilMyTwoColumnDetails",
- decorators: [withKnobs],
- component: PegaDxilMyTwoColumnDetails,
- parameters: {
- type: "DetailsRegion",
- },
-};
-
-export const BaseYourOrgRequiredDxilDetailsRegion = () => {
- if (!window.PCore) {
- window.PCore = {};
- }
-
- window.PCore.getUserApi = () => {
- return {
- getOperatorDetails: () => {
- return new Promise((resolve) => {
- resolve(operatorDetails);
- });
- },
- };
- };
-
- window.PCore.getEnvironmentInfo = () => {
- return {
- getUseLocale: () => {
- return "en-US";
- },
- };
- };
-
- const props = {
- NumCols: "2",
- template: "DefaultForm",
- showHighlightedData: false,
- label: "Details Region",
- showLabel: true,
- getPConnect: () => {
- return {
- getChildren: () => {
- return pyReviewRaw.children[0].children;
- },
- getRawMetadata: () => {
- return pyReviewRaw;
- },
- getInheritedProps: () => {
- return pyReviewRaw.config.inheritedProps;
- },
- setInheritedProp: () => {
- /* nothing */
- },
- resolveConfigProps: () => {
- /* nothing */
- },
- };
- },
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/mock.stories.js b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/mock.stories.js
deleted file mode 100644
index 20323a70..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/mock.stories.js
+++ /dev/null
@@ -1,290 +0,0 @@
-const operatorDetails = {
- data: {
- pzLoadTime: "January 18, 2023 10:33:19 AM EST",
- pzPageNameHash: "_pa1519192551088960pz",
- pyOperatorInfo: {
- pyUserName: "french DigV2",
- pyPosition: "",
- pyImageInsKey: "",
- pySkills: [
- {
- pySkillName: "",
- pzIndexOwnerKey: "DATA-ADMIN-OPERATOR-ID FRENCHTEST.DIGV2",
- pySkillRating: 0,
- },
- ],
- pyReportToUserName: "",
- pyReportTo: "",
- pyOrganization: "DXIL",
- pyTitle: "",
- pyLabel: "frenchTest.DigV2",
- pyEmailAddress: "User@DigV2",
- pyTelephone: "",
- },
- },
- status: 200,
- statusText: "",
- headers: {
- "content-length": "435",
- "content-type": "application/json;charset=UTF-8",
- },
- request: {},
-};
-
-export default operatorDetails;
-
-export const pyReviewRaw = {
- name: "pyReview",
- type: "View",
- config: {
- template: "Details",
- ruleClass: "MyCo-MyCompon-Work-MyComponents",
- showLabel: true,
- label: "@L Details",
- localeReference: "@LR MYCO-MYCOMPON-WORK-MYCOMPONENTS!VIEW!PYREVIEW",
- showHighlightedData: true,
- highlightedData: [
- {
- type: "TextInput",
- config: {
- value: "@P .pyStatusWork",
- label: "@L Work Status",
- displayMode: "STACKED_LARGE_VAL",
- displayAsStatus: true,
- },
- },
- {
- type: "TextInput",
- config: {
- value: "@P .pyID",
- label: "@L Case ID",
- displayMode: "STACKED_LARGE_VAL",
- },
- },
- {
- type: "DateTime",
- config: {
- value: "@P .pxCreateDateTime",
- label: "@L Create date/time",
- displayMode: "STACKED_LARGE_VAL",
- },
- },
- {
- type: "UserReference",
- config: {
- label: "@L Create Operator",
- value: "@USER .pxCreateOperator",
- placeholder: "Select...",
- displayMode: "STACKED_LARGE_VAL",
- },
- },
- ],
- inheritedProps: [
- {
- prop: "label",
- value: "@L Details",
- },
- {
- prop: "showLabel",
- value: true,
- },
- ],
- },
- children: [
- {
- name: "A",
- type: "Region",
- getPConnect: () => {
- return {
- getRawMetadata: () => {
- return pyReviewRaw.children[0];
- },
- };
- },
- children: [
- {
- readOnly: undefined,
- placeholder: "First Name",
- value: "John",
- label: "First Name",
- hasSuggestions: false,
- displayMode: "LABELS_LEFT",
- },
- {
- readOnly: undefined,
- placeholder: "Middle Name",
- value: "",
- label: "Middle Name",
- hasSuggestions: false,
- displayMode: "LABELS_LEFT",
- },
- {
- readOnly: undefined,
- placeholder: "Last Name",
- value: "Doe",
- label: "Last Name",
- hasSuggestions: false,
- displayMode: "LABELS_LEFT",
- },
- {
- value: "john@doe.com",
- label: "Email",
- required: true,
- testId: "CE8AE9DA5B7CD6C3DF2929543A9AF92D",
- hasSuggestions: false,
- displayMode: "LABELS_LEFT",
- },
- {
- readOnly: undefined,
- value: "+16397975093",
- label: "Phone",
- displayMode: "LABELS_LEFT",
- hasSuggestions: false,
- },
- {
- readOnly: undefined,
- placeholder: "Price",
- value: "90.99",
- label: "Price",
- hasSuggestions: false,
- displayMode: "LABELS_LEFT",
- getPConnect: () => {
- return {
- getActionsApi: () => {/* nothing */},
- getStateProps: () => {
- return {
- value: "",
- };
- },
- getComponentName: () => {
- return "currency";
- },
- };
- },
- },
- {
- readOnly: undefined,
- value: "100 Mbps",
- label: "Internet Plan",
- hasSuggestions: false,
- displayMode: "LABELS_LEFT",
- getPConnect: () => {
- return {
- getActionsApi: () => {/* nothing */},
- getStateProps: () => {
- return {
- value: "",
- };
- },
- getComponentName: () => {
- return "radio";
- },
- getConfigProps: () => {
- return {};
- },
- getDataObject: () => {
- return {};
- },
- };
- },
- },
- {
- readOnly: undefined,
- placeholder: "Middle Name",
- value: "",
- label: "Middle Name",
- hasSuggestions: false,
- displayMode: "LABELS_LEFT",
- },
- {
- readOnly: undefined,
- placeholder: "Last Name",
- value: "Doe",
- label: "Last Name",
- hasSuggestions: false,
- displayMode: "LABELS_LEFT",
- },
- {
- value: "john@doe.com",
- label: "Email",
- required: true,
- testId: "CE8AE9DA5B7CD6C3DF2929543A9AF92D",
- hasSuggestions: false,
- displayMode: "LABELS_LEFT",
- },
- {
- readOnly: undefined,
- value: "+16397975093",
- label: "Phone",
- displayMode: "LABELS_LEFT",
- hasSuggestions: false,
- },
- {
- readOnly: undefined,
- placeholder: "Price",
- value: "90.89",
- label: "Price",
- hasSuggestions: false,
- displayMode: "LABELS_LEFT",
- getPConnect: () => {
- return {
- getActionsApi: () => {/* nothing */},
- getStateProps: () => {
- return {
- value: "",
- };
- },
- getComponentName: () => {
- return "currency";
- },
- };
- },
- },
- {
- readOnly: undefined,
- value: "100 Mbps",
- label: "Internet Plan",
- hasSuggestions: false,
- displayMode: "LABELS_LEFT",
- getPConnect: () => {
- return {
- getActionsApi: () => {/* nothing */},
- getStateProps: () => {
- return {
- value: "",
- };
- },
- getComponentName: () => {
- return "radio";
- },
- getConfigProps: () => {
- return {};
- },
- getDataObject: () => {
- return {};
- },
- };
- },
- },
- {
- caseOpConfig: {
- label: "Create operator",
- createLabel: "Created",
- updateLabel: "Updated",
- updateDateTime: "2023-03-10T15:45:56.919Z",
- createDateTime: "2023-03-10T15:45:40.154Z",
- updateOperator: {
- userId: "rep@mediaco",
- userName: "representative",
- },
- createOperator: {
- userId: "rep@mediaco",
- userName: "representative",
- },
- },
- },
- ],
- },
- ],
- classID: "MyCo-MyCompon-Work-MyComponents",
-};
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/pega-dxil-my-two-column-details.component.html b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/pega-dxil-my-two-column-details.component.html
deleted file mode 100644
index 1c73cc38..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/pega-dxil-my-two-column-details.component.html
+++ /dev/null
@@ -1,6 +0,0 @@
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/pega-dxil-my-two-column-details.component.scss b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/pega-dxil-my-two-column-details.component.scss
deleted file mode 100644
index be9bb2d2..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/pega-dxil-my-two-column-details.component.scss
+++ /dev/null
@@ -1,7 +0,0 @@
-.psdk-grid-filter {
- display: grid;
- grid-template-columns: repeat(2, minmax(0, 1fr));
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/pega-dxil-my-two-column-details.component.spec.ts b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/pega-dxil-my-two-column-details.component.spec.ts
deleted file mode 100644
index e6977fe9..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/pega-dxil-my-two-column-details.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyTwoColumnDetailsComponent } from './pega-dxil-my-two-column-details.component';
-
-describe('PegaDxilMyTwoColumnDetailsComponent', () => {
- let component: PegaDxilMyTwoColumnDetailsComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyTwoColumnDetailsComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyTwoColumnDetailsComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/pega-dxil-my-two-column-details.component.ts b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/pega-dxil-my-two-column-details.component.ts
deleted file mode 100644
index 31a071f9..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-details/pega-dxil-my-two-column-details.component.ts
+++ /dev/null
@@ -1,92 +0,0 @@
-import { Component, OnInit, Input } from '@angular/core';
-import { FormGroup } from '@angular/forms';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { MaterialDetailsComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-pega-dxil-my-two-column-details',
- templateUrl: './pega-dxil-my-two-column-details.component.html',
- styleUrls: ['./pega-dxil-my-two-column-details.component.scss'],
- standalone: true,
- imports: [MaterialDetailsComponent]
-})
-export class PegaDxilMyTwoColumnDetailsComponent implements OnInit {
- constructor(private angularPConnect: AngularPConnectService) {}
-
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- showHighlightedData: boolean;
- highlightedDataArr: any;
-
- arFields$: Array = [];
- arFields2$: Array = [];
- arFields3$: Array = [];
-
- propsToUse: any = {};
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- //this.updateSelf();
- this.checkAndUpdate();
- }
-
- ngOnDestroy() {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- const rawMetaData = this.pConn$.resolveConfigProps(this.pConn$.getRawMetadata().config);
- this.showHighlightedData = rawMetaData?.showHighlightedData;
-
- if( this.showHighlightedData ){
- const highlightedData = rawMetaData?.highlightedData;
- this.highlightedDataArr = highlightedData.map(field => {
- field.config.displayMode = 'STACKED_LARGE_VAL';
-
- if (field.config.value === '@P .pyStatusWork') {
- field.type = 'TextInput';
- field.config.displayAsStatus = true;
- }
-
- return field;
- });
- }
-
- this.pConn$.setInheritedProp('displayMode', 'LABELS_LEFT');
- this.pConn$.setInheritedProp('readOnly', true);
-
- let kids = this.pConn$.getChildren();
- for (let kid of kids) {
- let pKid = kid.getPConnect();
- let pKidData = pKid.resolveConfigProps(pKid.getRawMetadata());
- if (kids.indexOf(kid) == 0) {
- this.arFields$ = pKidData.children;
- } else {
- this.arFields2$ = pKidData.children;
- }
- }
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/TwoColumn.svg b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/TwoColumn.svg
deleted file mode 100644
index 3533e017..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/TwoColumn.svg
+++ /dev/null
@@ -1,38 +0,0 @@
-
-
- 2-col icon
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- A
-
-
-
- B
-
-
-
-
-
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/config.json b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/config.json
deleted file mode 100644
index a312fc7c..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/config.json
+++ /dev/null
@@ -1,49 +0,0 @@
-{
- "name": "Pega_DXIL_MyTwoColumnForm",
- "label": "My Two Column Form",
- "description": "My Two Column Form",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyTwoColumnForm",
- "type": "Template",
- "subtype": "FORM",
- "icon": "TwoColumn.svg",
- "properties": [
- {
- "name": "A",
- "label": "Region A",
- "format": "CONTENTPICKER"
- },
- {
- "name": "B",
- "label": "Region B",
- "format": "CONTENTPICKER"
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "saveToReference": true
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "saveToReference": true
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY",
- "saveToReference": true
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/demo.stories.jsx b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/demo.stories.jsx
deleted file mode 100644
index e35f422f..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/demo.stories.jsx
+++ /dev/null
@@ -1,180 +0,0 @@
-import { useState } from 'react';
-import PegaDxilMyTwoColumnForm from './index.tsx';
-import { pyReviewRaw } from './mock.stories';
-import { TextField } from '@material-ui/core';
-import MuiPhoneNumber from 'material-ui-phone-number';
-import { KeyboardDatePicker, MuiPickersUtilsProvider } from '@material-ui/pickers';
-import DayjsUtils from '@date-io/dayjs';
-
-export default {
- title: 'PegaDxilMyTwoColumnForm',
- component: PegaDxilMyTwoColumnForm
-};
-
-const renderField = resolvedProps => {
- const { displayMode, value = '', label = '', onChange} = resolvedProps;
-
- const variant = displayMode === 'LABELS_LEFT' ? 'inline' : 'stacked';
- let val = '';
- if (label === 'Service Date')
- val =
-
-
-
- if (label === 'Email')
- val = ;
-
- if (label === 'First Name' || label === 'Last Name' || label === 'Middle Name')
- val = ;
-
- if (label === 'Phone Number')
- val = ;
-
-
- if (variant === 'inline') {
- val = value || –– ;
- }
-
- return val;
-};
-
-export const BasePegaDxilMyTwoColumnForm = () => {
- const [firstName, setFirstName] = useState('John');
- const [middleName, setMiddleName] = useState('');
- const [lastName, setLastName] = useState('Joe');
- const [phone, setPhone] = useState('+16397975093');
- const [serviceDate, setServiceDate] = useState('2023-01-25');
- const [email, setEmail] = useState('john@doe.com');
- const regionChildrenResolved = [
- {
- readOnly: undefined,
- value: firstName,
- label: 'First Name',
- hasSuggestions: false,
- onChange: val => {
- setFirstName(val.target.value);
- }
- },
- {
- readOnly: undefined,
- value: middleName,
- label: 'Middle Name',
- hasSuggestions: false,
- onChange: val => {
- setMiddleName(val.target.value);
- }
- },
- {
- readOnly: undefined,
- value: lastName,
- label: 'Last Name',
- hasSuggestions: false,
- onChange: val => {
- setLastName(val.target.value);
- }
- },
- {
- readOnly: undefined,
- value: email,
- label: 'Email',
- hasSuggestions: false,
- onChange: val => {
- setEmail(val.target.value);
- }
- },
- {
- readOnly: undefined,
- value: phone,
- label: 'Phone Number',
- datasource: {
- fields: {
- value: undefined
- },
- source: [
- {
- value: '+1'
- },
- {
- value: '+91'
- },
- {
- value: '+48'
- },
- {
- value: '+44'
- }
- ]
- },
- hasSuggestions: false,
- onChange: val => {
- setPhone(val);
- }
- },
- {
- readOnly: undefined,
- value: serviceDate,
- label: 'Service Date',
- hasSuggestions: false,
- onChange: date => {
- const changeValue = date && date.isValid() ? date.toISOString() : null;
- setServiceDate(changeValue);
- }
-
- }
- ];
- const props = {
- template: 'DefaultForm',
- getPConnect: () => {
- return {
- getChildren: () => {
- return pyReviewRaw.children;
- },
- createComponent: config => {
- switch (config.config.value) {
- case '@P .FirstName':
- return renderField(regionChildrenResolved[0]);
- case '@P .MiddleName':
- return renderField(regionChildrenResolved[1]);
- case '@P .LastName':
- return renderField(regionChildrenResolved[2]);
- case '@P .Email':
- return renderField(regionChildrenResolved[3]);
- case '@P .PhoneNumber':
- return renderField(regionChildrenResolved[4]);
- case '@P .ServiceDate':
- return renderField(regionChildrenResolved[5]);
- default:
- break;
- }
- }
- };
- }
- };
-
- const regionAChildren = pyReviewRaw.children[0].children.map(child => {
- return props.getPConnect().createComponent(child);
- });
- const regionBChildren = pyReviewRaw.children[1].children.map(child => {
- return props.getPConnect().createComponent(child);
- });
-
- return (
- <>
-
- {regionAChildren}
- {regionBChildren}
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/mock.stories.js b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/mock.stories.js
deleted file mode 100644
index 0b1d0ec1..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/mock.stories.js
+++ /dev/null
@@ -1,132 +0,0 @@
-export const pyReviewRaw = {
- name: 'CollectInformation',
- type: 'View',
- config: {
- template: 'DefaultForm',
- ruleClass: 'OM5W9U-SampleApp-Work-Test',
- localeReference: '@LR OM5W9U-SAMPLEAPP-WORK-TEST!VIEW!COLLECTINFORMATION',
- context: '@P .pyViewContext'
- },
- children: [
- {
- name: 'A',
- type: 'Region',
- children: [
- {
- type: 'TextInput',
- config: {
- value: '@P .FirstName',
- label: '@L First Name'
- }
- },
- {
- type: 'TextInput',
- config: {
- value: '@P .MiddleName',
- label: '@L Middle Name'
- }
- },
- {
- type: 'TextInput',
- config: {
- value: '@P .LastName',
- label: '@L Last Name'
- }
- }
- ]
- },
- {
- name: 'B',
- type: 'Region',
- children: [
- {
- type: 'Email',
- config: {
- value: '@P .Email',
- label: '@L Email'
- }
- },
- {
- type: 'Phone',
- config: {
- value: '@P .PhoneNumber',
- label: '@L Phone Number',
- datasource: {
- source: '@DATASOURCE D_pyCountryCallingCodeList.pxResults',
- fields: {
- value: '@P .pyCallingCode'
- }
- }
- }
- },
- {
- type: 'Date',
- config: {
- value: '@P .ServiceDate',
- label: '@L Service Date'
- }
- }
- ]
- }
- ],
- classID: 'OM5W9U-SampleApp-Work-Test'
- };
-
- export const regionChildrenResolved = [
- {
- readOnly: undefined,
- value: 'John',
- label: 'First Name',
- hasSuggestions: false
- },
- {
- readOnly: undefined,
- value: 'Din',
- label: 'Middle Name',
- hasSuggestions: false
- },
- {
- readOnly: undefined,
- value: 'Doe',
- label: 'Last Name',
- hasSuggestions: false
- },
- {
- readOnly: undefined,
- value: 'John@doe.com',
- label: 'Email',
- hasSuggestions: false
- },
- {
- readOnly: undefined,
- value: '+16397975093',
- label: 'Phone Number',
- datasource: {
- fields: {
- value: undefined
- },
- source: [
- {
- value: '+1'
- },
- {
- value: '+91'
- },
- {
- value: '+48'
- },
- {
- value: '+44'
- }
- ]
- },
- hasSuggestions: false
- },
- {
- readOnly: undefined,
- value: '2023-01-25',
- label: 'Service Date',
- hasSuggestions: false
- }
- ];
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/pega-dxil-my-two-column-form.component.html b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/pega-dxil-my-two-column-form.component.html
deleted file mode 100644
index 0b639153..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/pega-dxil-my-two-column-form.component.html
+++ /dev/null
@@ -1,16 +0,0 @@
-
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/pega-dxil-my-two-column-form.component.scss b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/pega-dxil-my-two-column-form.component.scss
deleted file mode 100644
index a26771fe..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/pega-dxil-my-two-column-form.component.scss
+++ /dev/null
@@ -1,28 +0,0 @@
-* {
- box-sizing: border-box;
-}
-
-.psdk-two-column {
- display: flow-root;
- height: 100%;
-}
-
-/* Create two equal columns that floats next to each other */
-.psdk-two-column-column {
- width: 50%;
- float: left;
- padding: 0rem 0.3125rem;
- height: 100%;
-}
-
-.psdk-two-column-left {
- float: left;
- min-width: 50%;
- padding: 0rem 0.3125rem;
-}
-
-.psdk-two-column-right {
- float: left;
- width: 50%;
- padding: 0rem 0.3125rem;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/pega-dxil-my-two-column-form.component.spec.ts b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/pega-dxil-my-two-column-form.component.spec.ts
deleted file mode 100644
index f2d62146..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/pega-dxil-my-two-column-form.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyTwoColumnFormComponent } from './pega-dxil-my-two-column-form.component';
-
-describe('PegaDxilMyTwoColumnFormComponent', () => {
- let component: PegaDxilMyTwoColumnFormComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyTwoColumnFormComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyTwoColumnFormComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/pega-dxil-my-two-column-form.component.ts b/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/pega-dxil-my-two-column-form.component.ts
deleted file mode 100644
index 404de442..00000000
--- a/tests/assets/components/createAll/custom-sdk/template/pega-dxil-my-two-column-form/pega-dxil-my-two-column-form.component.ts
+++ /dev/null
@@ -1,26 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { RegionComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-pega-dxil-my-two-column-form',
- templateUrl: './pega-dxil-my-two-column-form.component.html',
- styleUrls: ['./pega-dxil-my-two-column-form.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => RegionComponent)]
-})
-export class PegaDxilMyTwoColumnFormComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- configProps$: Object;
- arChildren$: Array;
-
- constructor() {}
-
- ngOnInit() {
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.arChildren$ = this.pConn$.getChildren();
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/widget/_widget.md b/tests/assets/components/createAll/custom-sdk/widget/_widget.md
deleted file mode 100644
index ca4cf89e..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/_widget.md
+++ /dev/null
@@ -1,6 +0,0 @@
-# The **custom-sdk/widget** directory
-
-The **src/components/custom-sdk/widget** directory contains the code for the custom **widget** components you want to create and use with the **Angular SDK**.
-
-When you run the **npm run create** command to create new _widget_ components, the generated code that you can use as a starting point for your component
-development will be placed in component-specific folders in **src/components/custom-sdk/widget**.
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/OneColumnPage.svg b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/OneColumnPage.svg
deleted file mode 100644
index 5f2dec97..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/OneColumnPage.svg
+++ /dev/null
@@ -1,36 +0,0 @@
-
-
- 1 col
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- A
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/config.json b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/config.json
deleted file mode 100644
index 28399f10..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/config.json
+++ /dev/null
@@ -1,23 +0,0 @@
-{
- "name": "Pega_DXIL_MyCaseWidget",
- "label": "My Case Widget",
- "description": "My Case Widget",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyCaseWidget",
- "type": "Widget",
- "subtype": "CASE",
- "icon": "OneColumnPage.svg",
- "properties": [
- {
- "name": "label",
- "label": "Label value",
- "format": "TEXT"
- }
- ],
- "defaultConfig": {
- "label": "Case Widget"
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/demo.stories.jsx b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/demo.stories.jsx
deleted file mode 100644
index 8cffb67c..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/demo.stories.jsx
+++ /dev/null
@@ -1,70 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-
-import { historyData } from './mock.stories';
-
-import PegaDxilMyCaseWidget from './index.tsx';
-
-export default {
- title: 'PegaDxilMyCaseWidget',
- decorators: [withKnobs],
- component: PegaDxilMyCaseWidget
-};
-
-if (!window.PCore) {
- window.PCore = {};
-}
-
-window.PCore.getConstants = () => {
- return {
- CASE_INFO: {
- CASE_INFO_ID: 'caseInfo.ID'
- }
- };
-};
-
-window.PCore.getDataApiUtils = () => {
- return {
- getData: () => {
- return new Promise(resolve => {
- resolve(historyData);
- });
- }
- };
-};
-
-export const BasePegaDxilMyCaseWidget = () => {
-
- const props = {
- label: 'Case history',
-
- getPConnect: () => {
- return {
- getValue: value => {
- return value;
- },
- getContextName: () => {
- return 'app/primary_1';
- },
- getLocalizedValue: value => {
- return value;
- },
- getActionsApi: () => {
- return {
- updateFieldValue: () => {/* nothing */},
- triggerFieldChange: () => {/* nothing */}
- };
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- setInheritedProps: () => {/* nothing */},
- resolveConfigProps: () => {/* nothing */}
- };
- }
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/mock.stories.js b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/mock.stories.js
deleted file mode 100644
index 08f1bf94..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/mock.stories.js
+++ /dev/null
@@ -1,390 +0,0 @@
-// eslint-disable-next-line import/prefer-default-export
-export const historyData = {
- data: {
- fetchDateTime: '2023-01-18T12:04:56.517Z',
- pxObjClass: 'Pega-API-DataExploration-Data',
- resultCount: 31,
- data: [
- {
- pxTimeCreated: '2023-01-13T21:46:33.339Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214633.339 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214633.339 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxTimeCreated: '2023-01-13T21:46:33.332Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214633.332 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214633.332 GMT',
- pxLongitude: null,
- pyMessageKey: "Assignment to 'complete task' completed by performing a 'EmbeddedData'.",
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxTimeCreated: '2023-01-13T21:46:32.005Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214632.005 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214632.005 GMT',
- pxLongitude: null,
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxTimeCreated: '2023-01-13T21:46:31.998Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214631.998 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214631.998 GMT',
- pxLongitude: null,
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assignment to 'complete task' removed via ticket.",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:46:31.175Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214631.175 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214631.175 GMT',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:46:31.168Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214631.168 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214631.168 GMT',
- pxLongitude: null,
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assignment to 'complete task' completed by performing a 'EmbeddedData'.",
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:46:29.893Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214629.893 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214629.893 GMT',
- pxLongitude: null,
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:46:29.887Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214629.887 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214629.887 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assignment to 'complete task' removed via ticket.",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:46:28.248Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214628.248 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214628.248 GMT',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:46:28.242Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214628.242 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214628.242 GMT',
- pyMessageKey: "Assignment to 'complete task' completed by performing a 'EmbeddedData'.",
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:46:08.399Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214608.399 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214608.399 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:46:08.393Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214608.393 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214608.393 GMT',
- pyMessageKey: "Assignment to 'complete task' removed via ticket.",
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:46:07.584Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214607.584 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214607.584 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:46:07.579Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214607.579 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214607.579 GMT',
- pxLongitude: null,
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assignment to 'complete task' completed by performing a 'EmbeddedData'.",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:46:06.262Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214606.262 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214606.262 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:46:06.256Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214606.256 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214606.256 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assignment to 'complete task' removed via ticket.",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:45:57.503Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214557.503 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214557.503 GMT',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:45:57.496Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214557.496 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214557.496 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assignment to 'complete task' completed by performing a 'EmbeddedData'.",
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:45:36.250Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214536.250 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214536.250 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:45:36.244Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214536.244 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214536.244 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assignment to 'complete task' removed via ticket.",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:45:35.364Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214535.364 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214535.364 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:45:35.356Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214535.356 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214535.356 GMT',
- pxLongitude: null,
- pyMessageKey: "Assignment to 'complete task' completed by performing a 'EmbeddedData'.",
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:45:33.224Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214533.224 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214533.224 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:45:33.218Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214533.218 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214533.218 GMT',
- pxLongitude: null,
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assignment to 'complete task' removed via ticket.",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:45:32.436Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214532.436 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214532.436 GMT',
- pxLongitude: null,
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:45:32.430Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214532.430 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214532.430 GMT',
- pyMessageKey: "Assignment to 'complete task' completed by performing a 'EmbeddedData'.",
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxTimeCreated: '2023-01-13T21:45:25.003Z',
- pxObjClass: 'History-DXIL-DigV2-Work',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214525.003 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214525.003 GMT',
- pxLongitude: null,
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pxLatitude: null,
- pyMemo: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:45:24.994Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214524.994 GMT',
- pxLongitude: null,
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214524.994 GMT',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assignment to 'complete task' completed by performing a 'Select Test'.",
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:45:23.570Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214523.570 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214523.570 GMT',
- pxLongitude: null,
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMessageKey: "Assigned to User DigV2 to 'complete task' ",
- pyMemo: null,
- pxLatitude: null
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:45:23.563Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214523.563 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214523.563 GMT',
- pxLongitude: null,
- pyMessageKey: 'ChangeStageAutomatic\tCreate\tPick Test',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pxLatitude: null,
- pyMemo: 'ChangeStageAutomatic\tCreate\tPick Test'
- },
- {
- pxObjClass: 'History-DXIL-DigV2-Work',
- pxTimeCreated: '2023-01-13T21:45:23.550Z',
- pyPerformer: 'User DigV2',
- pxInsName: 'DXIL-DIGV2-WORK C-7430!20230113T214523.550 GMT',
- pzInsKey: 'HISTORY-DXIL-DIGV2-WORK DXIL-DIGV2-WORK C-7430!20230113T214523.550 GMT',
- pxLongitude: null,
- pyMessageKey: 'Item created.',
- pxHistoryForReference: 'DXIL-DIGV2-WORK C-7430',
- pyMemo: null,
- pxLatitude: null
- }
- ],
- hasMoreResults: false
- },
- status: 200,
- statusText: '',
- headers: {
- 'content-length': '1328',
- 'content-type': 'application/json;charset=UTF-8'
- },
- request: {}
-};
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/pega-dxil-my-case-widget.component.html b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/pega-dxil-my-case-widget.component.html
deleted file mode 100644
index f68fa036..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/pega-dxil-my-case-widget.component.html
+++ /dev/null
@@ -1,12 +0,0 @@
-
-
{{ configProps$.label }}
-
-
- {{ dCol.label }}
- {{ element[dCol.fieldName] }}
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/pega-dxil-my-case-widget.component.scss b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/pega-dxil-my-case-widget.component.scss
deleted file mode 100644
index f9eafd57..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/pega-dxil-my-case-widget.component.scss
+++ /dev/null
@@ -1,22 +0,0 @@
-table {
- width: 100%;
-}
-
-.mat-mdc-row .mat-mdc-cell {
- text-align: left;
-}
-
-.psdk-search {
- padding-left: 0.625rem;
-}
-
-.psdk-icon-search {
- vertical-align: sub;
- padding: 0rem 0.125rem;
- min-width: unset;
- width: 1.1rem;
-}
-
-.psdk-case-history-title {
- margin-left: 0.5rem;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/pega-dxil-my-case-widget.component.spec.ts b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/pega-dxil-my-case-widget.component.spec.ts
deleted file mode 100644
index 3fa17525..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/pega-dxil-my-case-widget.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyCaseWidgetComponent } from './pega-dxil-my-case-widget.component';
-
-describe('PegaDxilMyCaseWidgetComponent', () => {
- let component: PegaDxilMyCaseWidgetComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyCaseWidgetComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyCaseWidgetComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/pega-dxil-my-case-widget.component.ts b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/pega-dxil-my-case-widget.component.ts
deleted file mode 100644
index 0e8c1994..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-case-widget/pega-dxil-my-case-widget.component.ts
+++ /dev/null
@@ -1,111 +0,0 @@
-import { Component, OnInit, Input } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { MatTableDataSource, MatTableModule } from '@angular/material/table';
-import { Utils } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-case-widget',
- templateUrl: './pega-dxil-my-case-widget.component.html',
- styleUrls: ['./pega-dxil-my-case-widget.component.scss'],
- standalone: true,
- imports: [CommonModule, MatTableModule]
-})
-export class PegaDxilMyCaseWidgetComponent implements OnInit {
- @Input() pConn$: any;
-
- PCore$: any;
- configProps$: any;
-
- repeatList$: MatTableDataSource;
- fields$: Array;
- displayedColumns$ = Array();
- waitingForData: boolean = false;
-
- constructor(private utils: Utils) {}
-
- ngOnInit(): void {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
-
- this.configProps$ = this.pConn$.getConfigProps();
-
- const caseID = this.pConn$.getValue(this.PCore$.getConstants().CASE_INFO.CASE_INFO_ID);
- const dataViewName = 'D_pyWorkHistory';
- const context = this.pConn$.getContextName();
-
- this.waitingForData = true;
-
- const caseHistoryData = this.PCore$.getDataApiUtils().getData(
- dataViewName,
- `{"dataViewParameters":[{"CaseInstanceKey":"${caseID}"}]}`,
- context
- );
-
- caseHistoryData.then((historyJSON: Object) => {
- this.fields$ = [
- { label: 'Date', type: 'DateTime', fieldName: 'pxTimeCreated' },
- { label: 'Description', type: 'TextInput', fieldName: 'pyMessageKey' },
- { label: 'User', type: 'TextInput', fieldName: 'pyPerformer' }
- ];
-
- const tableDataResults = this.updateData(historyJSON['data'].data, this.fields$);
-
- this.displayedColumns$ = this.getDisplayColums(this.fields$);
-
- this.repeatList$ = new MatTableDataSource(tableDataResults);
-
- this.waitingForData = false;
- });
- }
-
- ngOnDestroy() {}
-
- updateFields(arFields, arColumns): Array {
- let arReturn = arFields;
- for (let i in arReturn) {
- arReturn[i].config.name = arColumns[i];
- }
-
- return arReturn;
- }
-
- updateData(listData: Array, fieldData: Array): Array {
- let returnList: Array = new Array();
- for (let row in listData) {
- // copy
- let rowData = JSON.parse(JSON.stringify(listData[row]));
-
- for (let field of fieldData) {
- let fieldName = field['fieldName'];
- let formattedDate;
-
- switch (field['type']) {
- case 'Date':
- formattedDate = this.utils.generateDate(rowData[fieldName], 'Date-Short-YYYY');
- rowData[fieldName] = formattedDate;
- break;
- case 'DateTime':
- formattedDate = this.utils.generateDateTime(rowData[fieldName], 'DateTime-Short-YYYY');
- rowData[fieldName] = formattedDate;
- break;
- }
- }
-
- returnList.push(rowData);
- }
-
- return returnList;
- }
-
- getDisplayColums(fields = []) {
- let arReturn = fields.map((field, colIndex) => {
- let theField = field.fieldName;
-
- return theField;
- });
- return arReturn;
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/OneColumnPage.svg b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/OneColumnPage.svg
deleted file mode 100644
index 5f2dec97..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/OneColumnPage.svg
+++ /dev/null
@@ -1,36 +0,0 @@
-
-
- 1 col
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- A
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/config.json b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/config.json
deleted file mode 100644
index 05bbe8c1..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/config.json
+++ /dev/null
@@ -1,66 +0,0 @@
-{
- "name": "Pega_DXIL_MyPageCaseWidget",
- "label": "My PageCase Widget",
- "description": "My PageCase Widget",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyPageCaseWidget",
- "type": "Widget",
- "subtype": ["PAGE","CASE"],
- "icon": "OneColumnPage.svg",
- "properties": [
- {
- "name": "title",
- "label": "Label value",
- "format": "TEXT"
- },
- {
- "format": "SELECT",
- "label": "Usage",
- "name": "label",
- "defaultValue": "Create operator",
- "localize": true,
- "source": [
- {
- "key": "Create operator",
- "value": "Create operator"
- },
- {
- "key": "Update operator",
- "value": "Update operator"
- },
- {
- "key": "Resolve operator",
- "value": "Resolve operator"
- }
- ]
- },
-
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ],
- "defaultConfig": {
- "label": "Create operator",
- "title": "Create operator",
- "createLabel": "@L Created",
- "updateLabel": "@L Updated",
- "createOperator": "@USER .pxCreateOperator",
- "updateOperator": "@USER .pxUpdateOperator",
- "createDateTime": "@P .pxCreateDateTime",
- "updateDateTime": "@P .pxUpdateDateTime",
- "resolveLabel": "@L Resolved",
- "resolveOperator": "@USER .pyResolvedUserID",
- "resolveDateTime": "@P .pyResolvedTimestamp"
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/demo.stories.jsx b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/demo.stories.jsx
deleted file mode 100644
index 1847748f..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/demo.stories.jsx
+++ /dev/null
@@ -1,52 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-
-import { caseOpConfig, operatorDetails } from './mock.stories';
-
-import PegaDxilMyPageCaseWidget from './index.tsx';
-
-export default {
- title: 'PegaDxilMyPageCaseWidget',
- decorators: [withKnobs],
- component: PegaDxilMyPageCaseWidget
-};
-
-if (!window.PCore) {
- window.PCore = {};
-}
-
-window.PCore.getUserApi = () => {
- return {
- getOperatorDetails: () => {
- return new Promise(resolve => {
- resolve(operatorDetails);
- });
- }
- };
-};
-
-export const BasePegaDxilMyPageCaseWidget = () => {
-
- const props = {
- caseOpConfig,
- getPConnect: () => {
- return {
- getActionsApi: () => {
- return {
- updateFieldValue: () => {/* nothing */},
- triggerFieldChange: () => {/* nothing */}
- };
- },
- ignoreSuggestion: () => {/* nothing */},
- acceptSuggestion: () => {/* nothing */},
- setInheritedProps: () => {/* nothing */},
- resolveConfigProps: () => {/* nothing */}
- };
- }
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/mock.stories.js b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/mock.stories.js
deleted file mode 100644
index e8121cf4..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/mock.stories.js
+++ /dev/null
@@ -1,52 +0,0 @@
-
-export const caseOpConfig = {
- label: 'Create operator',
- createLabel: 'Created',
- updateLabel: 'Updated',
- updateDateTime: '2023-01-16T14:53:33.280Z',
- createDateTime: '2023-01-16T14:53:33.198Z',
- updateOperator: {
- userId: 'admin@mediaco',
- userName: 'admin'
- },
- createOperator: {
- userId: 'admin@mediaco',
- userName: 'admin'
- },
- hideLabel: true,
- key: '_532zx1dah',
- displayMode: 'LABELS_LEFT'
-};
-
-export const operatorDetails = {
- data: {
- pzLoadTime: 'January 18, 2023 10:33:19 AM EST',
- pzPageNameHash: '_pa1519192551088960pz',
- pyOperatorInfo: {
- pyUserName: 'french DigV2',
- pyPosition: '',
- pyImageInsKey: '',
- pySkills: [
- {
- pySkillName: '',
- pzIndexOwnerKey: 'DATA-ADMIN-OPERATOR-ID FRENCHTEST.DIGV2',
- pySkillRating: 0
- }
- ],
- pyReportToUserName: '',
- pyReportTo: '',
- pyOrganization: 'DXIL',
- pyTitle: '',
- pyLabel: 'frenchTest.DigV2',
- pyEmailAddress: 'User@DigV2',
- pyTelephone: ''
- }
- },
- status: 200,
- statusText: '',
- headers: {
- 'content-length': '435',
- 'content-type': 'application/json;charset=UTF-8'
- },
- request: {}
-};
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/pega-dxil-my-page-case-widget.component.html b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/pega-dxil-my-page-case-widget.component.html
deleted file mode 100644
index 26a603e3..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/pega-dxil-my-page-case-widget.component.html
+++ /dev/null
@@ -1,25 +0,0 @@
-
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/pega-dxil-my-page-case-widget.component.scss b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/pega-dxil-my-page-case-widget.component.scss
deleted file mode 100644
index 9481e1eb..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/pega-dxil-my-page-case-widget.component.scss
+++ /dev/null
@@ -1,137 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-.psdk-case-summary {
- display: block;
- margin: 0.625rem;
-}
-
-.psdk-case-summary-primary {
- text-align: left;
- margin-bottom: 0.75rem;
-}
-
-.psdk-case-summary-secondary {
- text-align: left;
- margin-bottom: 0.75rem;
-}
-
-.psdk-case-summary-status {
- text-align: left;
- margin-bottom: 0.75rem;
-}
-
-.psdk-case-summary-status-data {
- display: block;
- background-color: lavender;
- color: $app-primary-color;
- padding: 0rem 0.625rem;
- display: inline;
- font-size: 0.75rem;
- font-weight: 700;
- text-transform: uppercase;
- line-height: 1.5rem;
-}
-
-.psdk-case-summary-primary .label {
- font-weight: 600;
-}
-
-.psdk-case-summary-primary .data {
- font-weight: 600;
- font-size: 1.625rem;
-}
-
-.psdk-case-summary-secondary .label {
- font-weight: 600;
-}
-.psdk-case-summary-secondary .data {
- font-weight: 600;
- color: $app-primary-color;
- padding-left: 1.25rem;
-}
-
-.psdk-case-summary-fields {
- padding: calc(2 * 0.5rem);
- display: inline-flex;
- grid-row-gap: calc(2 * 0.5rem);
- column-gap: 4rem;
-}
-
-.psdk-case-summary-fields-primary {
- grid-template-columns: 20ch 1fr;
- display: grid;
- grid-column-gap: calc(2 * 0.5rem);
- grid-row-gap: calc(2 * 0.5rem);
-}
-
-.psdk-csf-primary-field {
- display: grid;
- grid-template-columns: 1fr;
- grid-column-gap: calc(0 * 0.5rem);
-}
-
-.psdk-csf-primary-field-header {
- word-break: break-word;
- grid-column-start: 1;
- grid-row-start: 1;
- max-width: max-content;
- font-size: 0.8125rem;
- font-weight: 400;
- color: rgba(0, 0, 0, 0.8);
-}
-
-.psdk-csf-primary-field-data {
- word-break: break-word;
- grid-column-start: 1;
- grid-row-start: 2;
- margin-inline-start: unset;
-}
-
-.psdk-case-summary-fields-secondary {
- width: 100%;
- display: grid;
- grid-template-columns: 1fr;
- grid-column-gap: calc(2 * 0.5rem);
- grid-row-gap: calc(1 * 0.5rem);
-}
-
-.psdk-csf-secondary-field {
- display: grid;
- grid-template-columns: auto;
- grid-column-gap: calc(2 * 0.5rem);
-}
-
-.psdk-csf-secondary-field-header {
- word-break: break-word;
- grid-column-start: 1;
- grid-row-start: 1;
- max-width: max-content;
- font-size: 0.8125rem;
- font-weight: 400;
- color: rgba(0, 0, 0, 0.8);
-}
-
-.psdk-csf-secondary-field-data {
- word-break: break-word;
- grid-column-start: 2;
- grid-row-start: 1;
- margin-inline-start: unset;
-}
-
-span.psdk-csf-text-style {
- font-size: 1.125rem;
- font-weight: 600;
-}
-
-span.psdk-csf-status-style {
- background-color: #e9eef3;
- border-radius: calc(0.25 * 0.5rem);
- color: #4c5a67;
- display: inline-block;
- font-size: 0.75rem;
- font-weight: bold;
- line-height: calc(0.5rem * 2.5);
- height: calc(0.5rem * 2.5);
- padding: 0 0.5rem;
- text-transform: uppercase;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/pega-dxil-my-page-case-widget.component.spec.ts b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/pega-dxil-my-page-case-widget.component.spec.ts
deleted file mode 100644
index dc994def..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/pega-dxil-my-page-case-widget.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyPageCaseWidgetComponent } from './pega-dxil-my-page-case-widget.component';
-
-describe('PegaDxilMyPageCaseWidgetComponent', () => {
- let component: PegaDxilMyPageCaseWidgetComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyPageCaseWidgetComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyPageCaseWidgetComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/pega-dxil-my-page-case-widget.component.ts b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/pega-dxil-my-page-case-widget.component.ts
deleted file mode 100644
index 9cc64b2f..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-case-widget/pega-dxil-my-page-case-widget.component.ts
+++ /dev/null
@@ -1,115 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pega-dxil-my-page-case-widget',
- templateUrl: './pega-dxil-my-page-case-widget.component.html',
- styleUrls: ['./pega-dxil-my-page-case-widget.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class PegaDxilMyPageCaseWidgetComponent implements OnInit {
- @Input() status$: string;
- @Input() bShowStatus$: boolean;
-
- @Input() primaryFields$: Array;
-
- @Input() pConn$: any;
- PCore$: any;
-
- // For interaction with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- controlName$: string;
-
-
- constructor(private utils: Utils, private angularPConnect: AngularPConnectService) {}
-
- ngOnInit(): void {
-
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
-
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // call updateSelf when initializing
- // this.updateSelf();
- this.checkAndUpdate();
-
-
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- this.primaryFields$ = new Array();
-
- let createConfig = {}
- createConfig["label"] = this.configProps$["label"];
- createConfig["updateDateTime"] = this.configProps$["createDateTime"];
- createConfig["displayLabel"] = this.configProps$["createLabel"];
- createConfig["createOperator"] = this.configProps$["createOperator"];
- let elConfig = {};
- elConfig["config"] = createConfig;
-
- this.primaryFields$.push(elConfig);
-
- let updateConfig = {};
- updateConfig["label"] = this.configProps$["updateLabel"];
- updateConfig["updateDateTime"] = this.configProps$["updateDateTime"];
- updateConfig["displayLabel"] = this.configProps$["updateLabel"];
- updateConfig["updateOperator"] = this.configProps$["updateOperator"];
- let elConfig1 = {};
- elConfig1["config"] = updateConfig;
-
- this.primaryFields$.push(elConfig1);
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- ngOnChanges() {
- this.updateLabelAndDate(this.primaryFields$);
- }
-
- updateLabelAndDate(arData: Array) {
- for (let field of arData) {
- switch (field.type.toLowerCase()) {
- case 'caseoperator':
- if (field.config.label.toLowerCase() == 'create operator') {
- field.config['displayLabel'] = field.config.createLabel;
- } else if (field.config.label.toLowerCase() == 'update operator') {
- field.config['displayLabel'] = field.config.updateLabel;
- }
- break;
- case 'date':
- field.config.value = this.utils.generateDate(field.config.value, 'Date-Long');
- break;
- }
- }
- }
-}
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/OneColumnPage.svg b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/OneColumnPage.svg
deleted file mode 100644
index 5f2dec97..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/OneColumnPage.svg
+++ /dev/null
@@ -1,36 +0,0 @@
-
-
- 1 col
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- A
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/config.json b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/config.json
deleted file mode 100644
index 91422f16..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/config.json
+++ /dev/null
@@ -1,59 +0,0 @@
-{
- "name": "Pega_DXIL_MyPageWidget",
- "label": "My Page Widget",
- "description": "My Page Widget",
- "organization": "Pega",
- "version": "0.0.1",
- "library": "DXIL",
- "allowedApplications": [],
- "componentKey": "Pega_DXIL_MyPageWidget",
- "type": "Widget",
- "subtype": "PAGE",
- "icon": "OneColumnPage.svg",
- "properties": [
- {
- "name": "description",
- "label": "Description",
- "format": "TEXT",
- "defaultValue": "We've launched a brand new experience to accelerate your workflow. Check out the guides to help you get the most of Cosmos."
- },
- {
- "name": "whatsnewlink",
- "label": "What's new link",
- "format": "TEXT",
- "defaultValue": "https://design.pega.com"
- },
- {
- "name": "image",
- "label": "Image link",
- "format": "TEXT",
- "defaultValue": ""
- },
- {
- "name": "datasource",
- "label": "Data source for details",
- "defaultValue": "@DATASOURCE D_pyAnnouncements.pxResults",
- "format": "DATASOURCE",
- "required": true,
- "properties": [
- {
- "name": "name",
- "label": "Label",
- "defaultValue": "@P .pyLabel"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ],
- "defaultConfig": {}
-}
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/demo.stories.jsx b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/demo.stories.jsx
deleted file mode 100644
index 8e5cbe2e..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/demo.stories.jsx
+++ /dev/null
@@ -1,29 +0,0 @@
-import { withKnobs } from '@storybook/addon-knobs';
-
-import PegaDxilMyPageWidget from './index.tsx';
-
-import { configProps } from './mock.stories';
-
-export default {
- title: 'PegaDxilMyPageWidget',
- decorators: [withKnobs],
- component: PegaDxilMyPageWidget
-};
-
-export const BasePegaDxilMyPageWidget = () => {
-
- const props = {
- label: configProps.label,
- header: configProps.header,
- description: configProps.description,
- image: configProps.image,
- datasource: configProps.datasource,
- whatsnewlink: configProps.whatsnewlink
- };
-
- return (
- <>
-
- >
- );
-};
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/mock.stories.js b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/mock.stories.js
deleted file mode 100644
index 64830af8..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/mock.stories.js
+++ /dev/null
@@ -1,23 +0,0 @@
-// eslint-disable-next-line import/prefer-default-export
-export const configProps = {
- label: 'App announcement',
- header: 'Announcements',
- description: 'Welcome to MediaCo Application for testing SDK frameworks.',
- whatsnewlink: 'https://design.pega.com',
- image:
- ' PHRpdGxlPlBlZ2EgdGV4dC1vbmx5IGxvZ288L3RpdGxlPjxwYXRoIHN0eWxlPSJmaWxsLW9wYWNpdHk6IC4yNTsiIGZpbGw9IiNmZmYiIGQ9Ik03LjcyIDMuODJjMCAyLjI1LTEuNzggMy40MS00IDMuNDFoLTEuNnYzSDBWLjQyaDMuOTRjMi4zNiAwIDMuNzggMS4zOSAzLjc4IDMuNHptLTQtMS40N2gtMS42djNoMS43QTEuNDcgMS40NyAwIDAgMCA1LjUgMy44MmMwLS45MS0uNjUtMS40Ny0xLjc1LTEuNDd6bTcuNjggNS45MWg1LjN2Mkg5LjI5Vi40Mmg3LjM4djEuOTNoLTUuMjR2Mmg0LjI0djEuOWgtNC4yNHpNMjMuMTggMGE1IDUgMCAwIDEgMy41NyAxLjI4TDI1LjYzIDIuOGEzLjc4IDMuNzggMCAwIDAtMS4wNS0uNjNBNC4zMiA0LjMyIDAgMCAwIDIzLjMxIDIgMy4xNyAzLjE3IDAgMCAwIDIwIDUuMjdhMy4xNiAzLjE2IDAgMCAwIDEgMi4zOSAzLjA3IDMuMDcgMCAwIDAgMi4xNy44NCA0LjYgNC42IDAgMCAwIDIuMDktLjVWNi4xOWgtMi4yVjQuMzhoNC4yNXY0LjU2YTUuNDEgNS40MSAwIDAgMS00LjA4IDEuNTdBNS4zNSA1LjM1IDAgMCAxIDE5LjQzIDlhNS4wNSA1LjA1IDAgMCAxLTEuNTYtMy43NCA1LjIxIDUuMjEgMCAwIDEgMS41Ni0zLjc2QTUuMzEgNS4zMSAwIDAgMSAyMy4xOCAwem0xMS4yOS40Mmw0LjEzIDkuNzloLTIuMjVMMzUuNDggOGgtNC4wNmwtLjkgMi4xOGgtMi4yTDMyLjUxLjQyem0uMjUgNS43MkwzMy40NCAzbC0xLjI5IDMuMTR6bTMtNWEuNzEuNzEgMCAwIDEtLjc0Ljc1LjcxLjcxIDAgMCAxLS43My0uNzUuNzMuNzMgMCAwIDEgLjc1LS43Mi43Mi43MiAwIDAgMSAuNzUuNzF6TTM3IC41M2EuNTkuNTkgMCAwIDAtLjYuNi42MS42MSAwIDEgMCAxLjIxIDAgLjYuNiAwIDAgMC0uNjEtLjZ6bS0uMjQgMVYuNzFIMzdjLjEyIDAgLjE4LjA2LjI1LjA2YS4yMS4yMSAwIDAgMSAuMDcuMTguMTkuMTkgMCAwIDEtLjA3LjE4cy0uMDcuMDgtLjEzLjA4bC4yNi4zNmgtLjJMMzcgMS4yOGgtLjF2LjI5em0uMTMtLjQ0aC4yM2EuMjYuMjYgMCAwIDAgLjA3LS4wOWgtLjA2Yy0uMDUtLjE3LS4wNS0uMTctLjEzLS4xN2gtLjF6Ii8 PC9zdmc ',
- datasource: {
- source: [
- {
- name: 'New React based UI rendering'
- },
- {
- name: 'Support for followers and recents'
- },
- {
- name: 'New authoring experience'
- }
- ],
- fields: {}
- }
-};
\ No newline at end of file
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/pagecomponent.spec.ts b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/pagecomponent.spec.ts
deleted file mode 100644
index b441c83c..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/pagecomponent.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PegaDxilMyPageWidgetComponent } from './pega-dxil-my-page-widget.component';
-
-describe('PegaDxilMyPageWidgetComponent', () => {
- let component: PegaDxilMyPageWidgetComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PegaDxilMyPageWidgetComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PegaDxilMyPageWidgetComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/pega-dxil-my-page-widget.component.html b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/pega-dxil-my-page-widget.component.html
deleted file mode 100644
index f3bd53cc..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/pega-dxil-my-page-widget.component.html
+++ /dev/null
@@ -1,14 +0,0 @@
-
-
- {{ header$ }}
-
- See what's new
-
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/pega-dxil-my-page-widget.component.scss b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/pega-dxil-my-page-widget.component.scss
deleted file mode 100644
index b13ef7ea..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/pega-dxil-my-page-widget.component.scss
+++ /dev/null
@@ -1,19 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-h2 {
- font-size: 1.2rem;
- margin-block-start: 0rem;
-}
-
-h3 {
- font-size: 1.1rem;
-}
-ul {
- padding-inline-start: 20px;
-}
-.psdk-announcement {
- background-color: $app-primary-light-color;
- padding: 1rem;
- margin: 0.5rem;
- border-radius: 0.6125rem;
-}
diff --git a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/pega-dxil-my-page-widget.component.ts b/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/pega-dxil-my-page-widget.component.ts
deleted file mode 100644
index ede59bf9..00000000
--- a/tests/assets/components/createAll/custom-sdk/widget/pega-dxil-my-page-widget/pega-dxil-my-page-widget.component.ts
+++ /dev/null
@@ -1,32 +0,0 @@
-import { Component, OnInit, Input } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { MatButtonModule } from '@angular/material/button';
-
-@Component({
- selector: 'app-pega-dxil-my-page-widget',
- templateUrl: './pega-dxil-my-page-widget.component.html',
- styleUrls: ['./pega-dxil-my-page-widget.component.scss'],
- standalone: true,
- imports: [CommonModule, MatButtonModule]
-})
-export class PegaDxilMyPageWidgetComponent implements OnInit {
- @Input() pConn$: any;
-
- header$: string;
- description$: string;
- arDetails$: Array;
- label$: string;
- whatsnewlink$: string;
-
- constructor() {}
-
- ngOnInit(): void {
- let configProps = this.pConn$.getConfigProps();
-
- this.header$ = configProps.header;
- this.description$ = configProps.description;
- this.arDetails$ = configProps.details;
- this.label$ = configProps.label;
- this.whatsnewlink$ = configProps.whatsnewlink;
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/_override-sdk.md b/tests/assets/components/createAll/override-sdk/_override-sdk.md
deleted file mode 100644
index bd18b767..00000000
--- a/tests/assets/components/createAll/override-sdk/_override-sdk.md
+++ /dev/null
@@ -1,5 +0,0 @@
-# The **components/override-sdk** directory
-
-The **src/components/override-sdk** directory contains the code for components for which you want to override the default implementation for use with the **Angular SDK**.
-
-When you run the **npm run override** command to override the default implementation of a component, the generated code that you can use as a starting point for your component development will be placed in type-specific and component-specific folders in **src/components/override-sdk**.
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/_designSystemExtension.md b/tests/assets/components/createAll/override-sdk/designSystemExtension/_designSystemExtension.md
deleted file mode 100644
index 341a695c..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/_designSystemExtension.md
+++ /dev/null
@@ -1,6 +0,0 @@
-# The **override-sdk/designSystemExtension** directory
-
-The **src/components/override-sdk/designSystemExtension** directory contains the code for components that **extend** the design system and for which you want to override the default implementation for use with the **Angular SDK**.
-
-When you run the **npm run create** command to override the default implementation of a **design system extension** component, the generated code that you can use
-as a starting point for your component development will be placed in type-specific and component-specific folders in **src/components/override-sdk/designSystemExtension**.
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/alert-banner/alert-banner.component.html b/tests/assets/components/createAll/override-sdk/designSystemExtension/alert-banner/alert-banner.component.html
deleted file mode 100644
index 10ecec40..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/alert-banner/alert-banner.component.html
+++ /dev/null
@@ -1,12 +0,0 @@
-
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/alert-banner/alert-banner.component.scss b/tests/assets/components/createAll/override-sdk/designSystemExtension/alert-banner/alert-banner.component.scss
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/alert-banner/alert-banner.component.spec.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/alert-banner/alert-banner.component.spec.ts
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/alert-banner/alert-banner.component.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/alert-banner/alert-banner.component.ts
deleted file mode 100644
index 218b3cd2..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/alert-banner/alert-banner.component.ts
+++ /dev/null
@@ -1,32 +0,0 @@
-import { Component, OnInit, Input } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { AlertComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-alert-banner',
- templateUrl: './alert-banner.component.html',
- styleUrls: ['./alert-banner.component.scss'],
- standalone: true,
- imports: [CommonModule, AlertComponent]
-})
-export class AlertBannerComponent implements OnInit {
- constructor() { }
-
- @Input() banners: Array;
-
- SEVERITY_MAP = {
- urgent: 'error',
- warning: 'warning',
- success: 'success',
- info: 'info'
- };
-
- ngOnInit(): void { }
-
- onAlertClose(config) {
- const { PAGE, type, target } = config
- const { clearMessages } = window.PCore.getMessageManager();
- clearMessages({ category: PAGE, type, context: target });
- }
-
-}
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/alert/alert.component.html b/tests/assets/components/createAll/override-sdk/designSystemExtension/alert/alert.component.html
deleted file mode 100644
index 2e73cbff..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/alert/alert.component.html
+++ /dev/null
@@ -1,18 +0,0 @@
-
-
- {{ getMatIcon(severity) }}
-
-
{{ message }}
-
-
- close
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/alert/alert.component.scss b/tests/assets/components/createAll/override-sdk/designSystemExtension/alert/alert.component.scss
deleted file mode 100644
index b26f9e48..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/alert/alert.component.scss
+++ /dev/null
@@ -1,52 +0,0 @@
-.psdk-alert {
- border: 1px solid;
- display: flex;
- align-items: center;
- border-radius: 4px;
- padding: 10px;
- margin: 5px 0px;
-}
-
-.psdk-alert-icon {
- display: flex;
- align-items: center;
- margin-right: 10px;
-}
-
-.psdk-alert-error {
- color: rgb(82, 21, 8);
- border: 1px solid rgb(207, 53, 22);
- .mat-icon {
- color: rgb(207, 53, 22);
- }
-}
-
-.psdk-grid-warning {
- color: rgb(102, 60, 0);
- border: 1px solid #ff9800;
- .mat-icon {
- color: #ff9800;
- }
-}
-
-.psdk-grid-success {
- color: rgb(2, 46, 9);
- border: 1px solid rgb(6, 116, 23);
- .mat-icon {
- color: rgb(6, 116, 23);
- }
-}
-
-.psdk-grid-info {
- color: rgb(13, 60, 97);
- border: 1px solid #2196f3;
- .mat-icon {
- color: #2196f3;
- }
-}
-
-.close-button {
- background: none;
- border: none;
- cursor: pointer;
-}
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/alert/alert.component.spec.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/alert/alert.component.spec.ts
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/alert/alert.component.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/alert/alert.component.ts
deleted file mode 100644
index 90328dfa..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/alert/alert.component.ts
+++ /dev/null
@@ -1,45 +0,0 @@
-import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { MatIconModule } from '@angular/material/icon';
-
-@Component({
- selector: 'app-alert',
- templateUrl: './alert.component.html',
- styleUrls: ['./alert.component.scss'],
- standalone: true,
- imports: [CommonModule, MatIconModule]
-})
-export class AlertComponent implements OnInit {
- constructor() { }
-
- @Input() message: Array;
- @Input() severity;
- @Input() hideClose;
- @Output() onClose: EventEmitter = new EventEmitter();
-
- ngOnInit(): void { }
-
- getMatIcon(severity) {
- let variant;
- switch (severity) {
- case 'error':
- variant = 'error_outline';
- break;
- case 'warning':
- variant = 'warning_amber';
- break;
- case 'success':
- variant = 'task_alt';
- break;
- case 'info':
- variant = 'info_outline';
- break;
- }
- return variant;
- }
-
- onCloseClick() {
- this.onClose.emit();
- }
-
-}
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/case-create-stage/case-create-stage.component.html b/tests/assets/components/createAll/override-sdk/designSystemExtension/case-create-stage/case-create-stage.component.html
deleted file mode 100644
index 62409bdc..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/case-create-stage/case-create-stage.component.html
+++ /dev/null
@@ -1,12 +0,0 @@
-
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/case-create-stage/case-create-stage.component.scss b/tests/assets/components/createAll/override-sdk/designSystemExtension/case-create-stage/case-create-stage.component.scss
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/case-create-stage/case-create-stage.component.spec.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/case-create-stage/case-create-stage.component.spec.ts
deleted file mode 100644
index 39bbde65..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/case-create-stage/case-create-stage.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { CaseCreateStageComponent } from './case-create-stage.component';
-
-describe('CaseCreateStageComponent', () => {
- let component: CaseCreateStageComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ CaseCreateStageComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(CaseCreateStageComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/case-create-stage/case-create-stage.component.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/case-create-stage/case-create-stage.component.ts
deleted file mode 100644
index 9cce458f..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/case-create-stage/case-create-stage.component.ts
+++ /dev/null
@@ -1,58 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-case-create-stage',
- templateUrl: './case-create-stage.component.html',
- styleUrls: ['./case-create-stage.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class CaseCreateStageComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- arChildren$: Array;
-
- // For interaction with AngularPConnect
- angularPConnectData: any = {};
-
- constructor(private angularPConnect: AngularPConnectService) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- //this.updateSelf();
- this.checkAndUpdate();
- }
-
- ngOnDestroy() {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- this.arChildren$ = this.pConn$.getChildren();
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-case-summary/material-case-summary.component.html b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-case-summary/material-case-summary.component.html
deleted file mode 100644
index c7d88918..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-case-summary/material-case-summary.component.html
+++ /dev/null
@@ -1,47 +0,0 @@
-
-
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-case-summary/material-case-summary.component.scss b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-case-summary/material-case-summary.component.scss
deleted file mode 100644
index db6ad025..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-case-summary/material-case-summary.component.scss
+++ /dev/null
@@ -1,136 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-.psdk-case-summary {
- display: block;
- margin: 0.625rem;
-}
-
-.psdk-case-summary-primary {
- text-align: left;
- margin-bottom: 0.75rem;
-}
-
-.psdk-case-summary-secondary {
- text-align: left;
- margin-bottom: 0.75rem;
-}
-
-.psdk-case-summary-status {
- text-align: left;
- margin-bottom: 0.75rem;
-}
-
-.psdk-case-summary-status-data {
- display: block;
- background-color: lavender;
- color: $app-primary-color;
- padding: 0rem 0.625rem;
- display: inline;
- font-size: 0.75rem;
- font-weight: 700;
- text-transform: uppercase;
- line-height: 1.5rem;
-}
-
-.psdk-case-summary-primary .label {
- font-weight: 600;
-}
-
-.psdk-case-summary-primary .data {
- font-weight: 600;
- font-size: 1.625rem;
-}
-
-.psdk-case-summary-secondary .label {
- font-weight: 600;
-}
-.psdk-case-summary-secondary .data {
- font-weight: 600;
- color: $app-primary-color;
- padding-left: 1.25rem;
-}
-
-.psdk-case-summary-fields {
- padding: calc(2 * 0.5rem);
- display: grid;
- grid-row-gap: calc(2 * 0.5rem);
-}
-
-.psdk-case-summary-fields-primary {
- grid-template-columns: 20ch 1fr;
- display: grid;
- grid-column-gap: calc(2 * 0.5rem);
- grid-row-gap: calc(2 * 0.5rem);
-}
-
-.psdk-csf-primary-field {
- display: grid;
- grid-template-columns: 1fr;
- grid-column-gap: calc(0 * 0.5rem);
-}
-
-.psdk-csf-primary-field-header {
- word-break: break-word;
- grid-column-start: 1;
- grid-row-start: 1;
- max-width: max-content;
- font-size: 0.8125rem;
- font-weight: 400;
- color: rgba(0, 0, 0, 0.8);
-}
-
-.psdk-csf-primary-field-data {
- word-break: break-word;
- grid-column-start: 1;
- grid-row-start: 2;
- margin-inline-start: unset;
-}
-
-.psdk-case-summary-fields-secondary {
- width: 100%;
- display: grid;
- grid-template-columns: 1fr;
- grid-column-gap: calc(2 * 0.5rem);
- grid-row-gap: calc(1 * 0.5rem);
-}
-
-.psdk-csf-secondary-field {
- display: grid;
- grid-template-columns: auto;
- grid-column-gap: calc(2 * 0.5rem);
-}
-
-.psdk-csf-secondary-field-header {
- word-break: break-word;
- grid-column-start: 1;
- grid-row-start: 1;
- max-width: max-content;
- font-size: 0.8125rem;
- font-weight: 400;
- color: rgba(0, 0, 0, 0.8);
-}
-
-.psdk-csf-secondary-field-data {
- word-break: break-word;
- grid-column-start: 2;
- grid-row-start: 1;
- margin-inline-start: unset;
-}
-
-span.psdk-csf-text-style {
- font-size: 1.125rem;
- font-weight: 600;
-}
-
-span.psdk-csf-status-style {
- background-color: #e9eef3;
- border-radius: calc(0.25 * 0.5rem);
- color: #4c5a67;
- display: inline-block;
- font-size: 0.75rem;
- font-weight: bold;
- line-height: calc(0.5rem * 2.5);
- height: calc(0.5rem * 2.5);
- padding: 0 0.5rem;
- text-transform: uppercase;
-}
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-case-summary/material-case-summary.component.spec.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-case-summary/material-case-summary.component.spec.ts
deleted file mode 100644
index 0f192982..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-case-summary/material-case-summary.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { MaterialCaseSummaryComponent } from './material-case-summary.component';
-
-describe('MaterialCaseSummaryComponent', () => {
- let component: MaterialCaseSummaryComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ MaterialCaseSummaryComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(MaterialCaseSummaryComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-case-summary/material-case-summary.component.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-case-summary/material-case-summary.component.ts
deleted file mode 100644
index 330068ae..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-case-summary/material-case-summary.component.ts
+++ /dev/null
@@ -1,69 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-material-case-summary',
- templateUrl: './material-case-summary.component.html',
- styleUrls: ['./material-case-summary.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class MaterialCaseSummaryComponent implements OnInit {
- @Input() status$: string;
- @Input() bShowStatus$: boolean;
- @Input() primaryFields$: Array;
- @Input() secondaryFields$: Array;
-
- primaryFieldsWithStatus$: Array;
-
- constructor(private utils: Utils) {}
-
- ngOnInit(): void {
- this.updatePrimaryWithStatus();
- this.updateLabelAndDate(this.primaryFieldsWithStatus$);
- this.updateLabelAndDate(this.secondaryFields$);
- }
-
- ngOnChanges() {
- this.updatePrimaryWithStatus();
- this.updateLabelAndDate(this.primaryFieldsWithStatus$);
- this.updateLabelAndDate(this.secondaryFields$);
- }
-
- updateLabelAndDate(arData: Array) {
- for (let field of arData) {
- switch (field.type.toLowerCase()) {
- case 'caseoperator':
- if (field.config.label.toLowerCase() == 'create operator') {
- field.config['displayLabel'] = field.config.createLabel;
- } else if (field.config.label.toLowerCase() == 'update operator') {
- field.config['displayLabel'] = field.config.updateLabel;
- }
- break;
- case 'date':
- field.config.value = this.utils.generateDate(field.config.value, 'Date-Long');
- break;
- }
- }
- }
-
- updatePrimaryWithStatus() {
- this.primaryFieldsWithStatus$ = [];
- for (let prim of this.primaryFields$) {
- this.primaryFieldsWithStatus$.push(prim);
- }
-
- if (this.bShowStatus$) {
- const oStatus = { type: 'status', config: { value: this.status$, label: 'Status' } };
-
- const count = this.primaryFieldsWithStatus$.length;
- if (count < 2) {
- this.primaryFieldsWithStatus$.push(oStatus);
- } else {
- this.primaryFieldsWithStatus$.splice(1, 0, oStatus);
- }
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details-fields/material-details-fields.component.html b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details-fields/material-details-fields.component.html
deleted file mode 100644
index 17eb9369..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details-fields/material-details-fields.component.html
+++ /dev/null
@@ -1,23 +0,0 @@
-
-
-
-
-
-
-
-
- {{ field.config.label }}
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details-fields/material-details-fields.component.scss b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details-fields/material-details-fields.component.scss
deleted file mode 100644
index bf59b6ef..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details-fields/material-details-fields.component.scss
+++ /dev/null
@@ -1,33 +0,0 @@
-.psdk-details-fields-label {
- color: rgba(0, 0, 0, 0.54);
- margin: 8px 0px;
- }
-
- span.psdk-details-text-style-hf{
- font-weight: bold;
- }
-
- span.psdk-details-status-style-hf {
- background-color: #e9eef3;
- border-radius: calc(0.25 * 0.5rem);
- color: #4c5a67;
- display: inline-block;
- font-size: 0.75rem;
- font-weight: bold;
- line-height: calc(0.5rem * 2.5);
- height: calc(0.5rem * 2.5);
- padding: 0 0.5rem;
- text-transform: uppercase;
- }
-
- .psdk-grid-filter {
- display: grid;
- grid-template-columns: repeat(2, minmax(0, 1fr));
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
- }
-
- .psdk-csf-primary-field-value {
- margin: 8px 0;
- }
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details-fields/material-details-fields.component.spec.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details-fields/material-details-fields.component.spec.ts
deleted file mode 100644
index 548cac9d..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details-fields/material-details-fields.component.spec.ts
+++ /dev/null
@@ -1,23 +0,0 @@
-import { ComponentFixture, TestBed } from '@angular/core/testing';
-
-import { MaterialDetailsFieldsComponent } from './material-details-fields.component';
-
-describe('MaterialDetailsFieldsComponent', () => {
- let component: MaterialDetailsFieldsComponent;
- let fixture: ComponentFixture;
-
- beforeEach(async () => {
- await TestBed.configureTestingModule({
- declarations: [ MaterialDetailsFieldsComponent ]
- })
- .compileComponents();
-
- fixture = TestBed.createComponent(MaterialDetailsFieldsComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details-fields/material-details-fields.component.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details-fields/material-details-fields.component.ts
deleted file mode 100644
index 00155a12..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details-fields/material-details-fields.component.ts
+++ /dev/null
@@ -1,37 +0,0 @@
-import { Component, Input, forwardRef } from '@angular/core';
-import { Utils } from '@pega/angular-sdk-library';
-import { CommonModule } from '@angular/common';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-material-details-fields',
- templateUrl: './material-details-fields.component.html',
- styleUrls: ['./material-details-fields.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => ComponentMapperComponent) ]
-})
-export class MaterialDetailsFieldsComponent {
-
- PCore$: any;
- angularPConnect: any;
- constructor(private utils: Utils) {}
-
- @Input() arFields$: Array;
- @Input() arHighlightedFields: Array;
-
- ngOnInit(): void {}
-
-
- _getValue(configValue) {
- if (configValue && configValue != '') {
- return configValue;
- } else {
- return '---';
- }
- }
-
- _formatDate(dateValue: string, dateFormat: string): string {
- return this.utils.generateDate(dateValue, dateFormat);
- }
-
-}
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details/material-details.component.html b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details/material-details.component.html
deleted file mode 100644
index f8de53eb..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details/material-details.component.html
+++ /dev/null
@@ -1,40 +0,0 @@
-
-
0"
- [ngClass]="{
- 'psdk-grid-filter-1': this.layout === 'one-column',
- 'psdk-grid-filter-2': this.layout === 'two-column',
- 'psdk-grid-filter-3': this.layout === 'three-column',
- 'psdk-grid-filter-wide-narrow': this.layout === 'wide-narrow',
- 'psdk-grid-filter-narrow-wide': this.layout === 'narrow-wide'
- }"
- >
-
-
- {{ field.config.label }}
-
-
-
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details/material-details.component.scss b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details/material-details.component.scss
deleted file mode 100644
index 6c64f1f9..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details/material-details.component.scss
+++ /dev/null
@@ -1,121 +0,0 @@
-.psdk-details-group {
- display: flex;
- flex-direction: row;
- justify-content: space-between;
-}
-.psdk-details-fields {
- padding: calc(2 * 0.5rem);
- grid-row-gap: calc(2 * 0.5rem);
-}
-
-.psdk-details-fields-primary {
- width: 100%;
- display: grid;
- grid-template-columns: 1fr;
- grid-column-gap: calc(2 * 0.5rem);
- grid-row-gap: calc(1 * 0.5rem);
-}
-
-.psdk-details-fields-single {
- display: grid;
- grid-template-columns: 20ch 1fr;
- grid-column-gap: calc(2 * 0.5rem);
-}
-
-.psdk-details-fields-label {
- color: rgba(0, 0, 0, 0.54);
- margin: 8px 0px;
-}
-
-.psdk-details-fields-value {
- word-break: break-word;
- grid-column-start: 2;
- grid-row-start: 1;
-}
-
-span.psdk-details-text-style-hf{
- font-weight: 500;
- font-size: 1.25rem;
-}
-
-span.psdk-details-text-style {
- font-weight: 400;
-}
-
-span.psdk-details-status-style {
- background-color: #e9eef3;
- border-radius: calc(0.25 * 0.5rem);
- color: #4c5a67;
- display: inline-block;
- font-size: 0.75rem;
- font-weight: bold;
- line-height: calc(0.5rem * 2.5);
- height: calc(0.5rem * 2.5);
- padding: 0 0.5rem;
- text-transform: uppercase;
-}
-
-.psdk-grid-filter {
- display: grid;
- grid-template-columns: repeat(2, minmax(0, 1fr));
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
-
-.psdk-csf-primary-field-value {
- margin: 8px 0;
-}
-
-span.psdk-details-status-style-hf {
- background-color: #e9eef3;
- border-radius: calc(0.25 * 0.5rem);
- color: #4c5a67;
- display: inline-block;
- font-size: 1.25rem;
- font-weight: 500;
- line-height: calc(0.5rem * 2.5);
- height: calc(0.5rem * 2.5);
- padding: 0 0.5rem;
- text-transform: uppercase;
-}
-
-.psdk-grid-filter-1 {
- display: grid;
- grid-template-columns: repeat(1,minmax(0,1fr));
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
-
-.psdk-grid-filter-2 {
- display: grid;
- grid-template-columns: repeat(2,minmax(0,1fr));
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
-
-.psdk-grid-filter-3 {
- display: grid;
- grid-template-columns: repeat(3,minmax(0,1fr));
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
-
-.psdk-grid-filter-wide-narrow {
- display: grid;
- grid-template-columns: 7fr 3fr;
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
-
-.psdk-grid-filter-narrow-wide {
- display: grid;
- grid-template-columns: 3fr 7fr;
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details/material-details.component.spec.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details/material-details.component.spec.ts
deleted file mode 100644
index 472b8fdc..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details/material-details.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed } from '@angular/core/testing';
-
-import { MaterialDetailsComponent } from './material-details.component';
-
-describe('MaterialDetailsComponent', () => {
- let component: MaterialDetailsComponent;
- let fixture: ComponentFixture;
-
- beforeEach(async () => {
- await TestBed.configureTestingModule({
- declarations: [ MaterialDetailsComponent ]
- })
- .compileComponents();
- });
-
- beforeEach(() => {
- fixture = TestBed.createComponent(MaterialDetailsComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details/material-details.component.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details/material-details.component.ts
deleted file mode 100644
index 57970782..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-details/material-details.component.ts
+++ /dev/null
@@ -1,35 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-material-details',
- templateUrl: './material-details.component.html',
- styleUrls: ['./material-details.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class MaterialDetailsComponent implements OnInit {
- constructor(private utils: Utils) {}
-
- @Input() arFields$: Array;
- @Input() arFields2$: Array;
- @Input() arFields3$: Array;
- @Input() arHighlightedFields: Array;
- @Input() layout: any;
-
- ngOnInit(): void {}
-
- _getValue(configValue) {
- if (configValue && configValue != '') {
- return configValue;
- } else {
- return '---';
- }
- }
-
- _formatDate(dateValue: string, dateFormat: string): string {
- return this.utils.generateDate(dateValue, dateFormat);
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-item/material-summary-item.component.html b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-item/material-summary-item.component.html
deleted file mode 100644
index 40810601..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-item/material-summary-item.component.html
+++ /dev/null
@@ -1,39 +0,0 @@
-
-
-
-
-
-
-
- {{item$.primary.name}}
-
-
-
-
- {{item$.primary.name}}
-
-
{{item$.secondary.text}}
-
-
-
-
-
-
-
-
-
-
- {{action.text}}
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-item/material-summary-item.component.scss b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-item/material-summary-item.component.scss
deleted file mode 100644
index 69a30c28..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-item/material-summary-item.component.scss
+++ /dev/null
@@ -1,128 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-.psdk-icon {
- padding: 0rem 0.125rem;
- min-width: unset;
-}
-
-.psdk-utility-divider {
- border-bottom: 0.0625rem solid $app-neutral-light-color;
-}
-
-.psdk-utility-view-all {
- width: 100%;
- display: flex;
- justify-content: center;
-}
-
-.psdk-utility-count {
- background: $app-primary-light-color;
- border-radius: calc(1.125 * 0.5rem);
- color: black;
- display: inline-block;
- font-size: 0.75rem;
- font-weight: bold;
- text-align: center;
- width: 1.125rem;
-
- vertical-align: top;
- margin: 0 0 0.313rem 1rem;
-}
-
-.psdk-utility .header-text {
- font-size: 1rem;
- font-weight: bold;
- padding-bottom: 0.3125rem;
- text-align: left;
- display: inline-block;
-}
-
-.psdk-utility .header-icon {
- display: inline-block;
-}
-
-.psdk-utility {
- width: 100%;
- padding: 0.625rem 0rem;
- text-align: left;
- background-color: $app-form-color;
- border-radius: 0.6125rem;
- margin: 0.3125rem 0rem;
-}
-.psdk-utility .header {
- text-align: left;
- display: flex;
- align-items: center;;
-}
-
-.psdk-utility-svg-icon {
- width: 1.4rem;
- display: inline-block;
-}
-
-.psdk-settings-svg-icon {
- width: 1.4rem;
- display: inline-block;
- filter: $app-primary-color-filter;
-}
-
-
-.psdk-utility .message {
- text-align: center;
-}
-
-.psdk-utility-card {
- display: flex;
- flex-direction: row;
- padding: 0.25rem 0rem 0.25rem 0.25rem;
-}
-
-.psdk-utility-card-icon {
- flex-grow: 1;
- max-width: 2.813rem;
-}
-
-.psdk-utility-card-svg-icon {
- width: 2.5rem;
- display: inline-block;
-}
-
-.psdk-utility-card-main {
- flex-grow: 2;
- max-width: 16.563rem;
-}
-
-.psdk-utility-card-main-primary-url {
- color: $app-primary-color;
-}
-
-.psdk-utility-card-main-primary-url .mat-mdc-button.mat-primary {
- padding-left: 0px;
-}
-
-.psdk-utility-card-main-primary-label {
- font-weight: bold;
-}
-
-.psdk-utility-card-actions {
- flex-grow: 1;
- text-align: right;
-}
-
-.psdk-utility-card-action-svg-icon {
- width: 1.4rem;
- display: inline-block;
-}
-
-.psdk-utility-card-actions-svg-icon {
- width: 1.4rem;
- display: inline-block;
- vertical-align: middle;
- filter: $app-primary-color-filter;
-}
-
-.psdk-utility-card-action-actions-svg-icon {
- width: 1.4rem;
- display: inline-block;
- vertical-align: bottom;
-}
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-item/material-summary-item.component.spec.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-item/material-summary-item.component.spec.ts
deleted file mode 100644
index 1ad3e7b9..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-item/material-summary-item.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { MaterialSummaryItemComponent } from './material-summary-item.component';
-
-describe('MaterialSummaryItemComponent', () => {
- let component: MaterialSummaryItemComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ MaterialSummaryItemComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(MaterialSummaryItemComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-item/material-summary-item.component.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-item/material-summary-item.component.ts
deleted file mode 100644
index 14a62e71..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-item/material-summary-item.component.ts
+++ /dev/null
@@ -1,33 +0,0 @@
-import { Component, OnInit, Input } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { MatButtonModule } from '@angular/material/button';
-import { MatMenuModule } from '@angular/material/menu';
-import { Utils } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-material-summary-item',
- templateUrl: './material-summary-item.component.html',
- styleUrls: ['./material-summary-item.component.scss'],
- standalone: true,
- imports: [CommonModule, MatButtonModule, MatMenuModule]
-})
-export class MaterialSummaryItemComponent implements OnInit {
- @Input() PCore$: any;
- @Input() item$: any;
- @Input() menuIconOverride$: string = '';
- @Input() menuIconOverrideAction$: any;
-
- settingsSvgIcon$: string;
- imagePath$: string = '';
-
- constructor(private utils: Utils) {}
-
- ngOnInit(): void {
- this.imagePath$ = this.utils.getIconPath(this.utils.getSDKStaticContentUrl());
-
- this.settingsSvgIcon$ = this.utils.getImageSrc('more', this.utils.getSDKStaticContentUrl());
- if (this.menuIconOverride$ != '') {
- this.menuIconOverride$ = this.utils.getImageSrc(this.menuIconOverride$, this.utils.getSDKStaticContentUrl());
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-list/material-summary-list.component.html b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-list/material-summary-list.component.html
deleted file mode 100644
index 4b747b04..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-list/material-summary-list.component.html
+++ /dev/null
@@ -1,3 +0,0 @@
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-list/material-summary-list.component.scss b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-list/material-summary-list.component.scss
deleted file mode 100644
index f1197474..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-list/material-summary-list.component.scss
+++ /dev/null
@@ -1 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-list/material-summary-list.component.spec.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-list/material-summary-list.component.spec.ts
deleted file mode 100644
index 67f8a38a..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-list/material-summary-list.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { MaterialSummaryListComponent } from './material-summary-list.component';
-
-describe('MaterialSummaryListComponent', () => {
- let component: MaterialSummaryListComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ MaterialSummaryListComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(MaterialSummaryListComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-list/material-summary-list.component.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-list/material-summary-list.component.ts
deleted file mode 100644
index 571dc6a2..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-summary-list/material-summary-list.component.ts
+++ /dev/null
@@ -1,29 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-material-summary-list',
- templateUrl: './material-summary-list.component.html',
- styleUrls: ['./material-summary-list.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class MaterialSummaryListComponent implements OnInit {
- @Input() arItems$: Array;
- @Input() icon$: string;
- @Input() menuIconOverride$: string = '';
- @Input() menuIconOverrideAction$: any;
-
- PCore$: any;
-
- constructor() {}
-
- ngOnInit(): void {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-utility/material-utility.component.html b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-utility/material-utility.component.html
deleted file mode 100644
index 64a0c477..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-utility/material-utility.component.html
+++ /dev/null
@@ -1,17 +0,0 @@
-
-
-
-
-
-
{{ noItemsMessage$ }}
-
-
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-utility/material-utility.component.scss b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-utility/material-utility.component.scss
deleted file mode 100644
index f646c260..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-utility/material-utility.component.scss
+++ /dev/null
@@ -1,52 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-.psdk-icon {
- padding: 0rem 0.125rem;
- min-width: unset;
-}
-
-.psdk-case-view-divider {
- border-bottom: 0.0625rem solid $app-neutral-light-color;
-}
-
-.psdk-utility .header-text {
- font-size: 1rem;
- font-weight: bold;
- padding-bottom: 0.3125rem;
- text-align: left;
- display: inline-block;
-}
-
-.psdk-utility .header-icon {
- display: inline-block;
-}
-
-.psdk-utility {
- width: 100%;
- height: 6.25rem;
- padding: 0.625rem 0rem;
- text-align: left;
- background-color: $app-form-color;
- border-radius: 0.6125rem;
- margin: 0.3125rem 0rem;
-}
-.psdk-utility .header {
- text-align: left;
- display: flex;
- align-items: center;
-}
-
-.psdk-utility-svg-icon {
- width: 1.4rem;
- display: inline-block;
-}
-
-.psdk-settings-svg-icon {
- width: 1.4rem;
- display: inline-block;
- filter: $app-primary-color-filter;
-}
-
-.psdk-utility .message {
- text-align: center;
-}
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-utility/material-utility.component.spec.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-utility/material-utility.component.spec.ts
deleted file mode 100644
index 72896d64..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-utility/material-utility.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { MaterialUtilityComponent } from './material-utility.component';
-
-describe('MaterialutilityComponent', () => {
- let component: MaterialUtilityComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ MaterialUtilityComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(MaterialUtilityComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-utility/material-utility.component.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-utility/material-utility.component.ts
deleted file mode 100644
index 4a3ae4bf..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-utility/material-utility.component.ts
+++ /dev/null
@@ -1,26 +0,0 @@
-import { Component, OnInit, Input } from '@angular/core';
-import { Utils } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-material-utility',
- templateUrl: './material-utility.component.html',
- styleUrls: ['./material-utility.component.scss'],
- providers: [Utils],
- standalone: true
-})
-export class MaterialUtilityComponent implements OnInit {
- @Input() headerText$: string;
- @Input() headerIcon$: string;
- @Input() headerIconUrl$: string;
- @Input() noItemsMessage$: string;
-
- headerSvgIcon$: string;
- settingsSvgIcon$: string;
-
- constructor(private utils: Utils) {}
-
- ngOnInit(): void {
- this.headerSvgIcon$ = this.utils.getImageSrc(this.headerIcon$, this.headerIconUrl$);
- this.settingsSvgIcon$ = this.utils.getImageSrc('plus', this.headerIconUrl$);
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-vertical-tabs/material-vertical-tabs.component.html b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-vertical-tabs/material-vertical-tabs.component.html
deleted file mode 100644
index f15c2aa8..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-vertical-tabs/material-vertical-tabs.component.html
+++ /dev/null
@@ -1,12 +0,0 @@
-
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-vertical-tabs/material-vertical-tabs.component.scss b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-vertical-tabs/material-vertical-tabs.component.scss
deleted file mode 100644
index 92f2bd87..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-vertical-tabs/material-vertical-tabs.component.scss
+++ /dev/null
@@ -1,28 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-mat-button-toggle-group {
- width: 100%;
- border-width: 0.0625rem 0rem;
-}
-
-mat-button-toggle-group ::ng-deep .mat-button-toggle-appearance-standard {
- background-color: transparent;
-}
-
-mat-button-toggle-group ::ng-deep .mat-button-toggle.mat-button-toggle-checked.mat-button-toggle-appearance-standard {
- background-color: transparent;
- border-right: 0.1875rem solid $app-primary-color;
-}
-
-mat-button-toggle-group ::ng-deep .mat-button-toggle.mat-focus-indicator.mat-button-toggle-appearance-standard {
- background-color: transparent;
- border-right: 0.1875rem solid transparent;
-}
-
-mat-button-toggle-group ::ng-deep .mat-button-toggle-appearance-standard .mat-button-toggle-label-content {
- text-align: left;
-}
-
-.psdk-vtab-badge .mat-badge-content {
- top: 0rem;
-}
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-vertical-tabs/material-vertical-tabs.component.spec.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-vertical-tabs/material-vertical-tabs.component.spec.ts
deleted file mode 100644
index 63efb373..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-vertical-tabs/material-vertical-tabs.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { MaterialVerticalTabsComponent } from './material-vertical-tabs.component';
-
-describe('MaterialVerticalTabsComponent', () => {
- let component: MaterialVerticalTabsComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ MaterialVerticalTabsComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(MaterialVerticalTabsComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-vertical-tabs/material-vertical-tabs.component.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/material-vertical-tabs/material-vertical-tabs.component.ts
deleted file mode 100644
index d3c95f12..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/material-vertical-tabs/material-vertical-tabs.component.ts
+++ /dev/null
@@ -1,42 +0,0 @@
-import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { MatBadgeModule } from '@angular/material/badge';
-import { MatButtonToggleModule } from '@angular/material/button-toggle';
-
-@Component({
- selector: 'app-material-vertical-tabs',
- templateUrl: './material-vertical-tabs.component.html',
- styleUrls: ['./material-vertical-tabs.component.scss'],
- standalone: true,
- imports: [CommonModule, MatButtonToggleModule, MatBadgeModule]
-})
-export class MaterialVerticalTabsComponent implements OnInit {
- @Input() tabConfig$: Array;
- @Output() tabClick: EventEmitter = new EventEmitter();
-
- selectedTabId$: any;
-
- constructor() {}
-
- ngOnInit(): void {
- // tabConfig$ [ {name: , id: , count: }]
-
- if (this.tabConfig$) {
- // seletedTabId is the first tab, unless another is selected
- this.selectedTabId$ = this.tabConfig$[0]?.id;
-
- // run through and see anything is selected
- for (let i in this.tabConfig$) {
- let aTab = this.tabConfig$[i];
- if (aTab?.selected) {
- this.selectedTabId$ = aTab.id;
- break;
- }
- }
- }
- }
-
- onChange(tab: any) {
- this.tabClick.emit(tab);
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/operator/operator.component.html b/tests/assets/components/createAll/override-sdk/designSystemExtension/operator/operator.component.html
deleted file mode 100644
index 74181960..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/operator/operator.component.html
+++ /dev/null
@@ -1,17 +0,0 @@
-
-
- {{ name$ }}
-
-
{{ date$ }}
-
-
-
-
-
-
-
{{ field.name }}
- {{ field.value }}
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/operator/operator.component.scss b/tests/assets/components/createAll/override-sdk/designSystemExtension/operator/operator.component.scss
deleted file mode 100644
index cca72694..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/operator/operator.component.scss
+++ /dev/null
@@ -1,74 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-.psdk-operator {
- display: flex;
- flex-direction: row;
- font-size: 0.8rem;
- color: $app-neutral-color;
-}
-
-.psdk-operator-popover {
- display: table;
- margin: auto;
- min-width: 100px;
- background-color: white;
- border: 1px solid black;
- border-radius: 10px;
- padding: 20px;
- box-shadow: 0 0 10px 3px #777;
- position: absolute;
- z-index: 99;
-}
-
-.psdk-operator-name {
- color: $app-neutral-color;
-}
-
-.psdk-operator-value {
- padding-left: 5px;
- color: $app-neutral-dark-color;
- margin: 0px;
-}
-
-.psdk-single {
- flex: 1;
-}
-
-.psdk-double {
- flex: 2;
-}
-
-.psdk-top-pad {
- padding-top: 10px;
-}
-
-dl {
- display: grid;
- grid-template-columns: auto 1fr;
- grid-column-gap: calc(2 * 0.5rem);
- grid-row-gap: calc(1 * 0.5rem);
-}
-
-dl::before,
-dl::after {
- box-sizing: border-box;
- margin: 0;
- padding: 0;
-}
-
-dt {
- max-width: 20ch;
- grid-column-start: 1;
-}
-
-dd {
- max-width: 75ch;
- grid-column-start: 2;
-}
-
-.mat-mdc-button.mat-primary,
-.mat-mdc-icon-button.mat-primary,
-.mat-mdc-outlined-button.mat-primary {
- padding: 0px;
- line-height: unset;
-}
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/operator/operator.component.spec.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/operator/operator.component.spec.ts
deleted file mode 100644
index 96ce9c56..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/operator/operator.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { OperatorComponent } from './operator.component';
-
-describe('OperatorComponent', () => {
- let component: OperatorComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ OperatorComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(OperatorComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/operator/operator.component.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/operator/operator.component.ts
deleted file mode 100644
index 607ff9b9..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/operator/operator.component.ts
+++ /dev/null
@@ -1,87 +0,0 @@
-import { Component, OnInit, Input, Renderer2, ChangeDetectorRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { MatButtonModule } from '@angular/material/button';
-import { Utils } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-operator',
- templateUrl: './operator.component.html',
- styleUrls: ['./operator.component.scss'],
- standalone: true,
- imports: [CommonModule, MatButtonModule]
-})
-export class OperatorComponent implements OnInit {
- @Input() date$: string;
- @Input() name$: string;
-
- @Input() label$: string;
- @Input() helperText$: string;
- @Input() id$: string;
-
- PCore$: any;
-
- fields$: Array = [];
- bShowPopover$: boolean;
-
- constructor(private renderer: Renderer2, private cdRef: ChangeDetectorRef, private utils: Utils) {}
-
- ngOnInit(): void {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
-
- this.renderer.listen('window', 'click', (e: Event) => {
- if (this.bShowPopover$) {
- this.bShowPopover$ = false;
- }
- });
-
- this.date$ = this.utils.generateDate(this.date$, 'DateTime-Since');
- this.bShowPopover$ = false;
- }
-
- ngOnDestroy(): void {
- this.renderer.destroy();
- }
-
- showOperator() {
- const operatorPreviewPromise = this.PCore$.getUserApi().getOperatorDetails(this.id$);
-
- operatorPreviewPromise.then((res) => {
- if (res.data && res.data.pyOperatorInfo && res.data.pyOperatorInfo.pyUserName) {
- this.fields$ = [
- {
- id: 'pyPosition',
- name: 'Position',
- value: res.data.pyOperatorInfo.pyPosition != '' ? res.data.pyOperatorInfo.pyPosition : '---'
- },
- {
- id: 'pyOrganization',
- name: 'Organization',
- value: res.data.pyOperatorInfo.pyOrganization != '' ? res.data.pyOperatorInfo.pyOrganization : '---'
- },
- {
- id: 'ReportToUserName',
- name: 'Reports to',
- value: res.data.pyOperatorInfo.pyReportToUserName != '' ? res.data.pyOperatorInfo.pyReportToUserName : '---'
- },
- {
- id: 'pyTelephone',
- name: 'Telephone',
- value: res.data.pyOperatorInfo.pyTelephone != '' ? res.data.pyOperatorInfo.pyTelephone : '---'
- },
- {
- id: 'pyEmailAddress',
- name: 'Email address',
- value: res.data.pyOperatorInfo.pyEmailAddress != '' ? res.data.pyOperatorInfo.pyEmailAddress : '---'
- }
- ];
-
- this.bShowPopover$ = true;
- this.cdRef.detectChanges();
- }
- });
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/pulse/pulse.component.html b/tests/assets/components/createAll/override-sdk/designSystemExtension/pulse/pulse.component.html
deleted file mode 100644
index 655cb83f..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/pulse/pulse.component.html
+++ /dev/null
@@ -1 +0,0 @@
-
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/pulse/pulse.component.scss b/tests/assets/components/createAll/override-sdk/designSystemExtension/pulse/pulse.component.scss
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/pulse/pulse.component.spec.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/pulse/pulse.component.spec.ts
deleted file mode 100644
index 26433f28..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/pulse/pulse.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PulseComponent } from './pulse.component';
-
-describe('PulseComponent', () => {
- let component: PulseComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PulseComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PulseComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/designSystemExtension/pulse/pulse.component.ts b/tests/assets/components/createAll/override-sdk/designSystemExtension/pulse/pulse.component.ts
deleted file mode 100644
index 5f714161..00000000
--- a/tests/assets/components/createAll/override-sdk/designSystemExtension/pulse/pulse.component.ts
+++ /dev/null
@@ -1,45 +0,0 @@
-import { Component, OnInit, Input } from '@angular/core';
-import { FeedContainerComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-pulse',
- templateUrl: './pulse.component.html',
- styleUrls: ['./pulse.component.scss'],
- standalone: true,
- imports: [FeedContainerComponent]
-})
-export class PulseComponent implements OnInit {
- @Input() pConn$: any;
-
- PCore$: any;
-
- configProps$: Object;
- currentUser$: string;
- currentUserInitials$: string = '--';
-
- constructor() {}
-
- ngOnInit() {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
-
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- //this.currentUser$ = this.configProps$["currentUser"];
- this.currentUser$ = this.PCore$.getEnvironmentInfo().getOperatorName();
-
- if (this.currentUser$ != '') {
- this.currentUserInitials$ = this.currentUser$.charAt(0);
-
- if (this.currentUser$.lastIndexOf(' ') > 0) {
- let lastName = this.currentUser$.substring(this.currentUser$.lastIndexOf(' ') + 1);
- this.currentUserInitials$ += lastName.charAt(0);
- } else if (this.currentUser$.lastIndexOf('.') > 0) {
- let lastName = this.currentUser$.substring(this.currentUser$.lastIndexOf('.') + 1);
- this.currentUserInitials$ += lastName.charAt(0);
- }
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/_field.md b/tests/assets/components/createAll/override-sdk/field/_field.md
deleted file mode 100644
index 2ede8890..00000000
--- a/tests/assets/components/createAll/override-sdk/field/_field.md
+++ /dev/null
@@ -1,6 +0,0 @@
-# The **override-sdk/field** directory
-
-The **src/components/override-sdk/field** directory contains the code for **field** components for which you want to override the default implementation for use with the **Angular SDK**.
-
-When you run the **npm run create** command to override the default implementation of a **field** component, the generated code that you can use as a starting point
-for your component development will be placed in type-specific and component-specific folders in **src/components/override-sdk/field**.
diff --git a/tests/assets/components/createAll/override-sdk/field/auto-complete/auto-complete.component.html b/tests/assets/components/createAll/override-sdk/field/auto-complete/auto-complete.component.html
deleted file mode 100644
index 2d7f86d8..00000000
--- a/tests/assets/components/createAll/override-sdk/field/auto-complete/auto-complete.component.html
+++ /dev/null
@@ -1,33 +0,0 @@
-
-
-
-
-
-
-
- {{ label$ }}
-
-
-
- {{ opt.value }}
-
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/field/auto-complete/auto-complete.component.scss b/tests/assets/components/createAll/override-sdk/field/auto-complete/auto-complete.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/override-sdk/field/auto-complete/auto-complete.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/auto-complete/auto-complete.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/auto-complete/auto-complete.component.spec.ts
deleted file mode 100644
index bc91b1db..00000000
--- a/tests/assets/components/createAll/override-sdk/field/auto-complete/auto-complete.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { AutoCompleteComponent } from './auto-complete.component';
-
-describe('AutoCompleteComponent', () => {
- let component: AutoCompleteComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ AutoCompleteComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(AutoCompleteComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/auto-complete/auto-complete.component.ts b/tests/assets/components/createAll/override-sdk/field/auto-complete/auto-complete.component.ts
deleted file mode 100644
index 0621dc93..00000000
--- a/tests/assets/components/createAll/override-sdk/field/auto-complete/auto-complete.component.ts
+++ /dev/null
@@ -1,318 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatOptionModule } from '@angular/material/core';
-import { MatAutocompleteModule } from '@angular/material/autocomplete';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-import { DatapageService } from '@pega/angular-sdk-library';
-import { handleEvent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-auto-complete',
- templateUrl: './auto-complete.component.html',
- styleUrls: ['./auto-complete.component.scss'],
- standalone: true,
- imports: [
- CommonModule,
- ReactiveFormsModule,
- MatFormFieldModule,
- MatInputModule,
- MatAutocompleteModule,
- MatOptionModule,
- forwardRef(() => ComponentMapperComponent)
- ]
-})
-export class AutoCompleteComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- PCore$: any;
- configProps$: any;
-
- label$: string = '';
- value$: string = '';
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- options$: Array;
- componentReference: string = '';
- testId: string;
- listType: string;
- columns = [];
-
- helperText: string;
- fieldControl = new FormControl('', null);
- parameters: {};
- hideLabel: any;
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils,
- private dataPageService: DatapageService
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // starting very simple...
-
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- if (this.configProps$['value'] != undefined) {
- const index = this.options$?.findIndex((element) => element.key === this.configProps$['value']);
- this.value$ = index > -1 ? this.options$[index].value : this.configProps$['value'];
- }
-
- this.testId = this.configProps$['testId'];
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
- this.listType = this.configProps$['listType'];
- const displayMode = this.configProps$['displayMode'];
- let datasource = this.configProps$['datasource'];
- let columns = this.configProps$['columns'];
- this.hideLabel = this.configProps$['hideLabel'];
- const { deferDatasource, datasourceMetadata } = this.configProps$;
- this.helperText = this.configProps$['helperText'];
- this.parameters = this.configProps$?.parameters;
- const context = this.pConn$.getContextName();
- // convert associated to datapage listtype and transform props
- // Process deferDatasource when datapage name is present. WHhen tableType is promptList / localList
- if (deferDatasource && datasourceMetadata?.datasource?.name) {
- this.listType = 'datapage';
- datasource = datasourceMetadata.datasource.name;
- this.parameters = this.flattenParameters(datasourceMetadata?.datasource?.parameters);
- const displayProp = datasourceMetadata.datasource.propertyForDisplayText.startsWith('@P')
- ? datasourceMetadata.datasource.propertyForDisplayText.substring(3)
- : datasourceMetadata.datasource.propertyForDisplayText;
- const valueProp = datasourceMetadata.datasource.propertyForValue.startsWith('@P')
- ? datasourceMetadata.datasource.propertyForValue.substring(3)
- : datasourceMetadata.datasource.propertyForValue;
- columns = [
- {
- key: 'true',
- setProperty: 'Associated property',
- value: valueProp
- },
- {
- display: 'true',
- primary: 'true',
- useForSearch: true,
- value: displayProp
- }
- ];
- }
- if (columns) {
- this.columns = this.preProcessColumns(columns);
- }
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
- if (this.listType === 'associated') {
- this.options$ = this.utils.getOptionList(this.configProps$, this.pConn$.getDataObject());
- }
-
- if (!displayMode && this.listType !== 'associated') {
- const workListData = this.PCore$.getDataApiUtils().getData(datasource, {});
-
- workListData.then((workListJSON: Object) => {
- const optionsData: Array = [];
- const results = workListJSON['data'].data;
- const displayColumn = this.getDisplayFieldsMetaData(this.columns);
- results?.forEach((element) => {
- const obj = {
- key: element.pyGUID || element[displayColumn.primary],
- value: element[displayColumn.primary]?.toString()
- };
- optionsData.push(obj);
- });
- this.options$ = optionsData;
- });
- }
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- flattenParameters(params = {}) {
- const flatParams = {};
- Object.keys(params).forEach((key) => {
- const { name, value: theVal } = params[key];
- flatParams[name] = theVal;
- });
-
- return flatParams;
- }
-
- getDisplayFieldsMetaData(columnList) {
- const displayColumns = columnList.filter((col) => col.display === 'true');
- const metaDataObj: any = { key: '', primary: '', secondary: [] };
- const keyCol = columnList.filter((col) => col.key === 'true');
- metaDataObj.key = keyCol.length > 0 ? keyCol[0].value : 'auto';
- for (let index = 0; index < displayColumns.length; index += 1) {
- if (displayColumns[index].primary === 'true') {
- metaDataObj.primary = displayColumns[index].value;
- } else {
- metaDataObj.secondary.push(displayColumns[index].value);
- }
- }
- return metaDataObj;
- }
-
- preProcessColumns(columnList) {
- return columnList?.map((col) => {
- const tempColObj = { ...col };
- tempColObj.value = col.value && col.value.startsWith('.') ? col.value.substring(1) : col.value;
- return tempColObj;
- });
- }
-
- isSelected(buttonValue: string): boolean {
- if (this.value$ === buttonValue) {
- return true;
- }
-
- return false;
- }
-
- fieldOnChange(event: any) {
- // this works - this.pConn$.setValue( this.componentReference, `property: ${this.componentReference}`);
- // this works - this.pConn$.setValue( this.componentReference, this.fieldControl.value);
- // PConnect wants to use changeHandler for onChange
- // this.angularPConnect.changeHandler( this, event);
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- optionChanged(event: any) {
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- let key = '';
- if (event?.target?.value) {
- const index = this.options$?.findIndex((element) => element.value === event.target.value);
- key = index > -1 ? (key = this.options$[index].key) : event.target.value;
- }
-
- const value = key;
- const actionsApi = this.pConn$?.getActionsApi();
- const propName = this.pConn$?.getStateProps().value;
- handleEvent(actionsApi, 'changeNblur', propName, value);
- if (this.configProps$?.onRecordChange) {
- event.target.value = value;
- this.configProps$.onRecordChange(event);
- }
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/auto-complete/config.json b/tests/assets/components/createAll/override-sdk/field/auto-complete/config.json
deleted file mode 100644
index b3e56275..00000000
--- a/tests/assets/components/createAll/override-sdk/field/auto-complete/config.json
+++ /dev/null
@@ -1,60 +0,0 @@
-{
- "name": "AutoComplete",
- "description": "Picklist",
- "type": "Field",
- "subtype": "PICKERS",
- "icon": "",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/cancel-alert/cancel-alert.component.html b/tests/assets/components/createAll/override-sdk/field/cancel-alert/cancel-alert.component.html
deleted file mode 100644
index 6d7a8296..00000000
--- a/tests/assets/components/createAll/override-sdk/field/cancel-alert/cancel-alert.component.html
+++ /dev/null
@@ -1,18 +0,0 @@
-
-
-
{{ heading$ }}
-
-
{{ body1$ }}
-
{{ body2$ }}
-
-
-
- Save for later
-
-
- Continue working
- Delete
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/field/cancel-alert/cancel-alert.component.scss b/tests/assets/components/createAll/override-sdk/field/cancel-alert/cancel-alert.component.scss
deleted file mode 100644
index 0c0caef5..00000000
--- a/tests/assets/components/createAll/override-sdk/field/cancel-alert/cancel-alert.component.scss
+++ /dev/null
@@ -1,24 +0,0 @@
-.psdk-cancel-alert-background {
- display: flex;
- flex-direction: column;
- justify-content: center;
- align-items: center;
- height: 100%;
- width: 100%;
- background-color: rgba(100, 100, 100, 0.4);
- position: fixed;
- z-index: 9999;
- top: 0px;
- left: 0px;
-}
-
-.psdk-cancel-alert-top {
- display: table;
- margin: auto;
- min-width: 550px;
- background-color: white;
- border: 1px solid black;
- border-radius: 10px;
- padding: 20px;
- box-shadow: 0 0 10px 3px #777;
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/cancel-alert/cancel-alert.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/cancel-alert/cancel-alert.component.spec.ts
deleted file mode 100644
index cd12ab0e..00000000
--- a/tests/assets/components/createAll/override-sdk/field/cancel-alert/cancel-alert.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { CancelAlertComponent } from './cancel-alert.component';
-
-describe('CancelAlertComponent', () => {
- let component: CancelAlertComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ CancelAlertComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(CancelAlertComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/cancel-alert/cancel-alert.component.ts b/tests/assets/components/createAll/override-sdk/field/cancel-alert/cancel-alert.component.ts
deleted file mode 100644
index f3f35441..00000000
--- a/tests/assets/components/createAll/override-sdk/field/cancel-alert/cancel-alert.component.ts
+++ /dev/null
@@ -1,121 +0,0 @@
-import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { MatButtonModule } from '@angular/material/button';
-import { MatGridListModule } from '@angular/material/grid-list';
-import { ProgressSpinnerService } from '@pega/angular-sdk-library';
-import { ErrorMessagesService } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-cancel-alert',
- templateUrl: './cancel-alert.component.html',
- styleUrls: ['./cancel-alert.component.scss'],
- standalone: true,
- imports: [CommonModule, MatGridListModule, MatButtonModule]
-})
-export class CancelAlertComponent implements OnInit {
- @Input() pConn$: any;
- @Input() bShowAlert$: boolean;
- @Output() onAlertState$ = new EventEmitter();
-
- PCore$: any;
-
- heading$: string;
- body1$: string;
- body2$: string;
- itemKey: string;
- snackBarRef: any;
-
- constructor(private erService: ErrorMessagesService, private psService: ProgressSpinnerService) {}
-
- ngOnInit(): void {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
- }
-
- ngOnChanges(changes) {
- if (this.bShowAlert$) {
- this.psService.sendMessage(false);
-
- const contextName = this.pConn$.getContextName();
- const caseInfo = this.pConn$.getCaseInfo();
- const caseName = caseInfo.getName();
- const ID = caseInfo.getID();
-
- this.itemKey = contextName;
- this.heading$ = 'Delete ' + caseName + ' (' + ID + ')';
- this.body1$ = 'Are you sure you want to delete ' + caseName + ' (' + ID + ')?';
- this.body2$ = 'Alternatively, you can continue working or save your work for later.';
-
- //this.onAlertState$.emit(true);
- }
- }
-
- ngOnDestroy() {}
-
- dismissAlert() {
- this.bShowAlert$ = false;
- this.onAlertState$.emit(false);
- }
-
- dismissAlertOnly() {
- this.bShowAlert$ = false;
- this.onAlertState$.emit(true);
- }
-
- sendMessage(sMessage: string) {
- //this.snackBarRef = this.snackBar.open(sMessage,"Ok", { duration: 3000});
- //this.erService.sendMessage("show", sMessage);
- alert(sMessage);
- }
-
- buttonClick(sAction) {
- const dispatchInfo = {
- context: this.itemKey,
- semanticURL: ''
- };
-
- const actionsAPI = this.pConn$.getActionsApi();
-
- switch (sAction) {
- case 'save':
- this.psService.sendMessage(true);
- // eslint-disable-next-line no-case-declarations
- const savePromise = actionsAPI.saveAndClose(this.itemKey);
- savePromise
- .then(() => {
- this.psService.sendMessage(false);
- this.dismissAlert();
-
- this.PCore$.getPubSubUtils().publish(this.PCore$.getConstants().PUB_SUB_EVENTS.CASE_EVENTS.CASE_CREATED);
- })
- .catch(() => {
- this.psService.sendMessage(false);
- this.sendMessage('Save failed');
- });
- break;
- case 'continue':
- this.dismissAlertOnly();
- break;
- case 'delete':
- this.psService.sendMessage(true);
-
- // eslint-disable-next-line no-case-declarations
- const deletePromise = actionsAPI.deleteCaseInCreateStage(this.itemKey);
-
- deletePromise
- .then(() => {
- this.psService.sendMessage(false);
- this.dismissAlert();
- this.PCore$.getPubSubUtils().publish(this.PCore$.getConstants().PUB_SUB_EVENTS.EVENT_CANCEL);
- })
- .catch(() => {
- this.psService.sendMessage(false);
- this.sendMessage('Delete failed.');
- });
- break;
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/check-box/check-box.component.html b/tests/assets/components/createAll/override-sdk/field/check-box/check-box.component.html
deleted file mode 100644
index a3fd5fde..00000000
--- a/tests/assets/components/createAll/override-sdk/field/check-box/check-box.component.html
+++ /dev/null
@@ -1,41 +0,0 @@
-
-
-
-
-
-
-
-
- {{ label$ }}
-
- {{ caption$ }}
-
-
- {{ caption$ }}
-
-
{{ helperText }}
-
{{ getErrorMessage() }}
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/field/check-box/check-box.component.scss b/tests/assets/components/createAll/override-sdk/field/check-box/check-box.component.scss
deleted file mode 100644
index 767c7526..00000000
--- a/tests/assets/components/createAll/override-sdk/field/check-box/check-box.component.scss
+++ /dev/null
@@ -1,24 +0,0 @@
-.psdk-full-width {
- min-width: 9.375rem;
- width: 100%;
- text-align: left;
-}
-
-.psdk-label-readonly {
- top: 0rem;
- margin-top: 0.625rem;
- font-size: 0.875rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/check-box/check-box.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/check-box/check-box.component.spec.ts
deleted file mode 100644
index 2f611342..00000000
--- a/tests/assets/components/createAll/override-sdk/field/check-box/check-box.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { CheckBoxComponent } from './check-box.component';
-
-describe('CheckBoxComponent', () => {
- let component: CheckBoxComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ CheckBoxComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(CheckBoxComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/check-box/check-box.component.ts b/tests/assets/components/createAll/override-sdk/field/check-box/check-box.component.ts
deleted file mode 100644
index 04dbbc18..00000000
--- a/tests/assets/components/createAll/override-sdk/field/check-box/check-box.component.ts
+++ /dev/null
@@ -1,182 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatCheckboxModule } from '@angular/material/checkbox';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-check-box',
- templateUrl: './check-box.component.html',
- styleUrls: ['./check-box.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatCheckboxModule, MatFormFieldModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class CheckBoxComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: any = '';
- caption$: string = '';
- testId: string = '';
- showLabel$: boolean = false;
- checkboxLabelPos$ = 'after';
- isChecked$: boolean = false;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- helperText: string;
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
- this.testId = this.configProps$['testId'];
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
-
- this.caption$ = this.configProps$['caption'];
- this.helperText = this.configProps$['helperText'];
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- if (this.label$ != '') {
- this.showLabel$ = true;
- }
-
- if (this.value$ === 'true' || this.value$ == true) {
- this.isChecked$ = true;
- } else {
- this.isChecked$ = false;
- }
- }
-
- fieldOnChange(event: any) {
- event.value = event.checked;
-
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- event.value = event.checked;
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
-
diff --git a/tests/assets/components/createAll/override-sdk/field/check-box/config.json b/tests/assets/components/createAll/override-sdk/field/check-box/config.json
deleted file mode 100644
index 51f9c85f..00000000
--- a/tests/assets/components/createAll/override-sdk/field/check-box/config.json
+++ /dev/null
@@ -1,64 +0,0 @@
-{
- "name": "Checkbox",
- "description": "Boolean",
- "type": "Field",
- "subtype": "PICKERS",
- "icon": "images/pz-checkbox-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT"
- },
- {
- "name": "hideLabel",
- "label": "Hide Label",
- "format": "BOOLEAN"
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "caption",
- "label": "Caption",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/currency/config.json b/tests/assets/components/createAll/override-sdk/field/currency/config.json
deleted file mode 100644
index 7dbc20c5..00000000
--- a/tests/assets/components/createAll/override-sdk/field/currency/config.json
+++ /dev/null
@@ -1,102 +0,0 @@
-{
- "name": "Currency",
- "description": "Currency",
- "type": "Field",
- "subtype": "DATA_CAPTURE",
- "icon": "images/pz-currency-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Label value",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "format": "CASCADE",
- "source": {
- "format": "SELECT",
- "label": "ISO Code Selection",
- "name": "isoCodeSelection",
- "defaultValue": "constant",
- "source": [
- {
- "key": "constant",
- "value": "Constant"
- },
- {
- "key": "propertyRef",
- "value": "Property Reference"
- }
- ]
- },
- "cascadeElements": [
- {
- "key": "currencyISOCode",
- "format": "TEXT",
- "name": "currencyISOCode",
- "label": "Currency ISO Code",
- "defaultValue": "USD",
- "match": "constant"
- },
- {
- "key": "currencyISOCode",
- "format": "PROPERTY",
- "name": "currencyISOCode",
- "label": "Currency ISO Code",
- "match": "propertyRef"
- }
- ]
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "allowDecimals",
- "label": "Allow Decimals",
- "format": "BOOLEAN",
- "defaultValue": true
- },
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/currency/currency.component.html b/tests/assets/components/createAll/override-sdk/field/currency/currency.component.html
deleted file mode 100644
index 28750f01..00000000
--- a/tests/assets/components/createAll/override-sdk/field/currency/currency.component.html
+++ /dev/null
@@ -1,30 +0,0 @@
-
-
-
-
-
-
-
- {{ label$ }}
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/field/currency/currency.component.scss b/tests/assets/components/createAll/override-sdk/field/currency/currency.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/override-sdk/field/currency/currency.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/currency/currency.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/currency/currency.component.spec.ts
deleted file mode 100644
index 208cff63..00000000
--- a/tests/assets/components/createAll/override-sdk/field/currency/currency.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { CurrencyComponent } from './currency.component';
-
-describe('CurrencyComponent', () => {
- let component: CurrencyComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ CurrencyComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(CurrencyComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/currency/currency.component.ts b/tests/assets/components/createAll/override-sdk/field/currency/currency.component.ts
deleted file mode 100644
index 2173b851..00000000
--- a/tests/assets/components/createAll/override-sdk/field/currency/currency.component.ts
+++ /dev/null
@@ -1,175 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-currency',
- templateUrl: './currency.component.html',
- styleUrls: ['./currency.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class CurrencyComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: number;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- testId: string;
- helperText: string;
-
- fieldControl = new FormControl(null, null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // starting very simple...
-
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.testId = this.configProps$['testId'];
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
- let nValue = this.configProps$['value'];
- this.value$ = nValue && typeof nValue == 'string' ? parseFloat(nValue) : nValue;
- this.helperText = this.configProps$['helperText'];
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
-
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
-
diff --git a/tests/assets/components/createAll/override-sdk/field/date-time/config.json b/tests/assets/components/createAll/override-sdk/field/date-time/config.json
deleted file mode 100644
index 6d2e4c58..00000000
--- a/tests/assets/components/createAll/override-sdk/field/date-time/config.json
+++ /dev/null
@@ -1,181 +0,0 @@
-{
- "name": "DateTime",
- "description": "Date & time",
- "type": "Field",
- "subtype": "DATA_CAPTURE",
- "icon": "images/pz-date-time-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "format": "SELECT",
- "name": "clockFormat",
- "label": "Clock",
- "defaultValue": "use locale",
- "source": [
- {
- "key": 0,
- "value": "use locale"
- },
- {
- "key": 12,
- "value": "12 hours"
- },
- {
- "key": 24,
- "value": "24 hours"
- }
- ]
- },
- {
- "name": "withSeconds",
- "label": "Display Seconds",
- "format": "BOOLEAN"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "format": "LABEL",
- "label": "Year range",
- "variant": "secondary"
- },
- {
- "format": "INLINE",
- "elements": [
- {
- "key": "next",
- "format": "LABEL",
- "label": "Next",
- "variant": "secondary"
- },
- {
- "key": "nextYears",
- "format": "NUMBER",
- "label": "",
- "name": "nextYearRange",
- "min": 0
- },
- {
- "key": "year",
- "format": "LABEL",
- "label": "years",
- "variant": "secondary"
- }
- ]
- },
- {
- "format": "INLINE",
- "elements": [
- {
- "key": "previous",
- "format": "LABEL",
- "label": "Previous",
- "variant": "secondary"
- },
- {
- "key": "previousYears",
- "format": "NUMBER",
- "label": "",
- "name": "previousYearRange",
- "min": 0
- },
- {
- "key": "year",
- "format": "LABEL",
- "label": "years",
- "variant": "secondary"
- }
- ]
- },
- {
- "name": "showWeekNumber",
- "label": "Display week numbers on calendar",
- "format": "BOOLEAN"
- },
- {
- "format": "SELECT",
- "name": "pickerInterval",
- "label": "Time picker",
- "defaultValue": "30",
- "source": [
- {
- "key": "5",
- "value": "5 min"
- },
- {
- "key": "10",
- "value": "10 min"
- },
- {
- "key": "15",
- "value": "15 min"
- },
- {
- "key": "20",
- "value": "20 min"
- },
- {
- "key": "30",
- "value": "30 min"
- },
- {
- "key": "60",
- "value": "1 hr"
- }
- ]
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Read-only settings",
- "format": "GROUP",
- "properties": [
- {
- "name": "showAsFormattedText",
- "label": "Show as formatted text",
- "format": "BOOLEAN"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/date-time/date-time.component.html b/tests/assets/components/createAll/override-sdk/field/date-time/date-time.component.html
deleted file mode 100644
index 14e79a34..00000000
--- a/tests/assets/components/createAll/override-sdk/field/date-time/date-time.component.html
+++ /dev/null
@@ -1,28 +0,0 @@
-
-
-
-
-
-
-
- {{ label$ }}
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/field/date-time/date-time.component.scss b/tests/assets/components/createAll/override-sdk/field/date-time/date-time.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/override-sdk/field/date-time/date-time.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/date-time/date-time.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/date-time/date-time.component.spec.ts
deleted file mode 100644
index 0657768b..00000000
--- a/tests/assets/components/createAll/override-sdk/field/date-time/date-time.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed } from '@angular/core/testing';
-
-import { DateTimeComponent } from './date-time.component';
-
-describe('DateTimeComponent', () => {
- let component: DateTimeComponent;
- let fixture: ComponentFixture;
-
- beforeEach(async () => {
- await TestBed.configureTestingModule({
- declarations: [ DateTimeComponent ]
- })
- .compileComponents();
- });
-
- beforeEach(() => {
- fixture = TestBed.createComponent(DateTimeComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/date-time/date-time.component.ts b/tests/assets/components/createAll/override-sdk/field/date-time/date-time.component.ts
deleted file mode 100644
index 7b8f2608..00000000
--- a/tests/assets/components/createAll/override-sdk/field/date-time/date-time.component.ts
+++ /dev/null
@@ -1,177 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-date-time',
- templateUrl: './date-time.component.html',
- styleUrls: ['./date-time.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class DateTimeComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: any;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- testId: string = '';
- helperText: string;
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
- // Then, continue on with other initialization
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // starting very simple...
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
- this.testId = this.configProps$['testId'];
- if (this.configProps$['value'] != undefined) {
- const value = this.configProps$['value'];
- this.value$ = value ? value.replace('Z', '') : value;
- }
- this.helperText = this.configProps$['helperText'];
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- if (event.target.value) {
- event.value = event.target.value;
- }
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- if (event.target.value) event.value = event.target.value;
-
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
- return errMessage;
- }
-}
-
diff --git a/tests/assets/components/createAll/override-sdk/field/date/config.json b/tests/assets/components/createAll/override-sdk/field/date/config.json
deleted file mode 100644
index b16b42f8..00000000
--- a/tests/assets/components/createAll/override-sdk/field/date/config.json
+++ /dev/null
@@ -1,124 +0,0 @@
-{
- "name": "Date",
- "description": "Date only",
- "type": "Field",
- "subtype": "DATA_CAPTURE",
- "icon": "images/pz-date-time-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "format": "LABEL",
- "label": "Year range",
- "variant": "secondary"
- },
- {
- "format": "INLINE",
- "elements": [
- {
- "key": "next",
- "format": "LABEL",
- "label": "Next",
- "variant": "secondary"
- },
- {
- "key": "nextYears",
- "format": "NUMBER",
- "label": "",
- "name": "nextYearRange",
- "min": 0
- },
- {
- "key": "year",
- "format": "LABEL",
- "label": "years",
- "variant": "secondary"
- }
- ]
- },
- {
- "format": "INLINE",
- "elements": [
- {
- "key": "previous",
- "format": "LABEL",
- "label": "Previous",
- "variant": "secondary"
- },
- {
- "key": "previousYears",
- "format": "NUMBER",
- "label": "",
- "name": "previousYearRange",
- "min": 0
- },
- {
- "key": "year",
- "format": "LABEL",
- "label": "years",
- "variant": "secondary"
- }
- ]
- },
- {
- "name": "showWeekNumber",
- "label": "Display week numbers on calendar",
- "format": "BOOLEAN"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Read-only settings",
- "format": "GROUP",
- "properties": [
- {
- "name": "showAsFormattedText",
- "label": "Show as formatted text",
- "format": "BOOLEAN"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/date/date.component.html b/tests/assets/components/createAll/override-sdk/field/date/date.component.html
deleted file mode 100644
index 3bc3ec7c..00000000
--- a/tests/assets/components/createAll/override-sdk/field/date/date.component.html
+++ /dev/null
@@ -1,32 +0,0 @@
-
-
-
-
-
-
-
- {{ label$ }}
-
-
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/field/date/date.component.scss b/tests/assets/components/createAll/override-sdk/field/date/date.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/override-sdk/field/date/date.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/date/date.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/date/date.component.spec.ts
deleted file mode 100644
index 5e629e06..00000000
--- a/tests/assets/components/createAll/override-sdk/field/date/date.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { DateComponent } from './date.component';
-
-describe('DateComponent', () => {
- let component: DateComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ DateComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(DateComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/date/date.component.ts b/tests/assets/components/createAll/override-sdk/field/date/date.component.ts
deleted file mode 100644
index 89a61e19..00000000
--- a/tests/assets/components/createAll/override-sdk/field/date/date.component.ts
+++ /dev/null
@@ -1,208 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatDatepickerModule } from '@angular/material/datepicker';
-import { MatNativeDateModule } from '@angular/material/core';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-date',
- templateUrl: './date.component.html',
- styleUrls: ['./date.component.scss'],
- standalone: true,
- imports: [
- CommonModule,
- ReactiveFormsModule,
- MatFormFieldModule,
- MatInputModule,
- MatDatepickerModule,
- MatNativeDateModule,
- forwardRef(() => ComponentMapperComponent)
- ]
-})
-export class DateComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
- label$: string = '';
- value$: any;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- testId: string = '';
- helperText: string;
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // starting very simple...
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- if (this.configProps$['value'] != undefined) {
- let sDateValue: any = '';
- sDateValue = this.configProps$['value'];
-
- if (sDateValue != '') {
- if (typeof sDateValue == 'object') {
- sDateValue = sDateValue.toISOString();
- } else if (sDateValue.indexOf('/') < 0) {
- // if we have the "pega" format, then for display, convert to standard format (US)
- // sDateValue = this.formatDate(sDateValue);
- sDateValue = this.utils.generateDate(sDateValue, 'Date-Long-Custom-YYYY');
- }
- this.value$ = new Date(sDateValue);
- }
- }
- this.testId = this.configProps$['testId'];
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
- this.helperText = this.configProps$['helperText'];
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnDateChange(event: any, sValue: string) {
- // this comes from the date pop up
- if (typeof event.value == 'object') {
- // convert date to pega "date" format
- event.value = event.value.toISOString();
- }
- this.angularPConnectData.actions.onChange(this, { value: event.value });
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- if (typeof event.value == 'object') {
- event.value = event.value.toISOString();
- // convert date to pega "date" format
- event.value = event.value.toISOString();
- }
- this.angularPConnectData.actions.onBlur(this, { value: event.value });
- }
-
- hasErrors() {
- return this.fieldControl.status === 'INVALID';
- }
-
- getErrorMessage() {
- let errMessage: string = '';
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = `${this.fieldControl.errors.matDatepickerParse.text} is not a valid date value`;
- }
- return errMessage;
- }
-}
-
diff --git a/tests/assets/components/createAll/override-sdk/field/decimal/config.json b/tests/assets/components/createAll/override-sdk/field/decimal/config.json
deleted file mode 100644
index 1e3d50ec..00000000
--- a/tests/assets/components/createAll/override-sdk/field/decimal/config.json
+++ /dev/null
@@ -1,71 +0,0 @@
-{
- "name": "Decimal",
- "description": "Decimal",
- "type": "Field",
- "subtype": "DATA_CAPTURE",
- "icon": "images/pz-decimal-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "name": "decimalPrecision",
- "label": "Decimal places",
- "format": "NUMBER",
- "min": 0
- },
- {
- "name": "showGroupSeparators",
- "label": "Show thousands separator",
- "format": "BOOLEAN"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/decimal/decimal.component.html b/tests/assets/components/createAll/override-sdk/field/decimal/decimal.component.html
deleted file mode 100644
index be3f5022..00000000
--- a/tests/assets/components/createAll/override-sdk/field/decimal/decimal.component.html
+++ /dev/null
@@ -1,29 +0,0 @@
-
-
-
-
-
-
-
- {{ label$ }}
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/field/decimal/decimal.component.scss b/tests/assets/components/createAll/override-sdk/field/decimal/decimal.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/override-sdk/field/decimal/decimal.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/decimal/decimal.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/decimal/decimal.component.spec.ts
deleted file mode 100644
index 9ede1aee..00000000
--- a/tests/assets/components/createAll/override-sdk/field/decimal/decimal.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { DecimalComponent } from './decimal.component';
-
-describe('DecimalComponent', () => {
- let component: DecimalComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ DecimalComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(DecimalComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/decimal/decimal.component.ts b/tests/assets/components/createAll/override-sdk/field/decimal/decimal.component.ts
deleted file mode 100644
index 4218a71e..00000000
--- a/tests/assets/components/createAll/override-sdk/field/decimal/decimal.component.ts
+++ /dev/null
@@ -1,170 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-decimal',
- templateUrl: './decimal.component.html',
- styleUrls: ['./decimal.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class DecimalComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: number;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- testId: string;
- helperText: string;
-
- fieldControl = new FormControl(null, null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // starting very simple...
-
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.testId = this.configProps$['testId'];
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
- let nValue = this.configProps$['value'];
- if (nValue) {
- if (typeof nValue == 'string') {
- nValue = parseFloat(nValue);
- }
- this.value$ = nValue;
- }
- this.helperText = this.configProps$['helperText'];
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
- }
-
- fieldOnChange(event: any) {
- // this.angularPConnect.changeHandler( this, event );
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
-
diff --git a/tests/assets/components/createAll/override-sdk/field/dropdown/config.json b/tests/assets/components/createAll/override-sdk/field/dropdown/config.json
deleted file mode 100644
index 3e83be8c..00000000
--- a/tests/assets/components/createAll/override-sdk/field/dropdown/config.json
+++ /dev/null
@@ -1,60 +0,0 @@
-{
- "name": "Dropdown",
- "description": "Picklist",
- "type": "Field",
- "subtype": "PICKERS",
- "icon": "images/pz-dropdown-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/dropdown/dropdown.component.html b/tests/assets/components/createAll/override-sdk/field/dropdown/dropdown.component.html
deleted file mode 100644
index 462a39f3..00000000
--- a/tests/assets/components/createAll/override-sdk/field/dropdown/dropdown.component.html
+++ /dev/null
@@ -1,27 +0,0 @@
-
-
-
-
-
-
-
-
-
- {{ opt.value }}
-
-
- {{ label$ }}
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/field/dropdown/dropdown.component.scss b/tests/assets/components/createAll/override-sdk/field/dropdown/dropdown.component.scss
deleted file mode 100644
index 1f792ffe..00000000
--- a/tests/assets/components/createAll/override-sdk/field/dropdown/dropdown.component.scss
+++ /dev/null
@@ -1,25 +0,0 @@
-.psdk-form {
- min-width: 9.375rem;
- width: 100%;
-}
-
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/dropdown/dropdown.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/dropdown/dropdown.component.spec.ts
deleted file mode 100644
index 3e136498..00000000
--- a/tests/assets/components/createAll/override-sdk/field/dropdown/dropdown.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { DropdownComponent } from './dropdown.component';
-
-describe('DropdownComponent', () => {
- let component: DropdownComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ DropdownComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(DropdownComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/dropdown/dropdown.component.ts b/tests/assets/components/createAll/override-sdk/field/dropdown/dropdown.component.ts
deleted file mode 100644
index 2e026d27..00000000
--- a/tests/assets/components/createAll/override-sdk/field/dropdown/dropdown.component.ts
+++ /dev/null
@@ -1,202 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatOptionModule } from '@angular/material/core';
-import { MatSelectModule } from '@angular/material/select';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-import { handleEvent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-dropdown',
- templateUrl: './dropdown.component.html',
- styleUrls: ['./dropdown.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatSelectModule, MatOptionModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class DropdownComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: any;
-
- label$: string = '';
- value$: string = '';
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- options$: Array;
- componentReference: string = '';
- testId: string = '';
- helperText: string;
- hideLabel: any;
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
-
- this.testId = this.configProps$['testId'];
- this.displayMode$ = this.configProps$['displayMode'];
- this.label$ = this.configProps$['label'];
- this.helperText = this.configProps$['helperText'];
- this.hideLabel = this.configProps$['hideLabel'];
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- const optionsList = this.utils.getOptionList(this.configProps$, this.pConn$.getDataObject());
- optionsList?.unshift({ key: 'Select', value: 'Select...' });
- this.options$ = optionsList;
- if (this.value$ === '' && !this.bReadonly$) {
- this.value$ = 'Select';
- }
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- isSelected(buttonValue: string): boolean {
- if (this.value$ === buttonValue) {
- return true;
- }
-
- return false;
- }
-
- fieldOnChange(event: any) {
- if (event?.value === 'Select') {
- event.value = '';
- }
- const actionsApi = this.pConn$?.getActionsApi();
- const propName = this.pConn$?.getStateProps().value;
- handleEvent(actionsApi, 'changeNblur', propName, event.value);
- if (this.configProps$?.onRecordChange) {
- this.configProps$.onRecordChange(event);
- }
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
-
diff --git a/tests/assets/components/createAll/override-sdk/field/email/config.json b/tests/assets/components/createAll/override-sdk/field/email/config.json
deleted file mode 100644
index a7b82e6c..00000000
--- a/tests/assets/components/createAll/override-sdk/field/email/config.json
+++ /dev/null
@@ -1,60 +0,0 @@
-{
- "name": "Email",
- "description": "Email",
- "type": "Field",
- "subtype": "DATA_CAPTURE",
- "icon": "images/pz-email-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/email/email.component.html b/tests/assets/components/createAll/override-sdk/field/email/email.component.html
deleted file mode 100644
index 6971c175..00000000
--- a/tests/assets/components/createAll/override-sdk/field/email/email.component.html
+++ /dev/null
@@ -1,28 +0,0 @@
-
-
-
-
-
-
-
- {{ label$ }}
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/field/email/email.component.scss b/tests/assets/components/createAll/override-sdk/field/email/email.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/override-sdk/field/email/email.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/email/email.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/email/email.component.spec.ts
deleted file mode 100644
index 79393fbe..00000000
--- a/tests/assets/components/createAll/override-sdk/field/email/email.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { EmailComponent } from './email.component';
-
-describe('EmailComponent', () => {
- let component: EmailComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ EmailComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(EmailComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/email/email.component.ts b/tests/assets/components/createAll/override-sdk/field/email/email.component.ts
deleted file mode 100644
index fc942b78..00000000
--- a/tests/assets/components/createAll/override-sdk/field/email/email.component.ts
+++ /dev/null
@@ -1,175 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-email',
- templateUrl: './email.component.html',
- styleUrls: ['./email.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class EmailComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: string;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- testId: string;
- helperText: string;
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.testId = this.configProps$['testId'];
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
-
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
- this.helperText = this.configProps$['helperText'];
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
-
diff --git a/tests/assets/components/createAll/override-sdk/field/integer/config.json b/tests/assets/components/createAll/override-sdk/field/integer/config.json
deleted file mode 100644
index 5407b5c8..00000000
--- a/tests/assets/components/createAll/override-sdk/field/integer/config.json
+++ /dev/null
@@ -1,65 +0,0 @@
-{
- "name": "Integer",
- "description": "Integer",
- "type": "Field",
- "subtype": "DATA_CAPTURE",
- "icon": "images/pz-integer-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "name": "showGroupSeparators",
- "label": "Show thousands separator",
- "format": "BOOLEAN"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/integer/integer.component.html b/tests/assets/components/createAll/override-sdk/field/integer/integer.component.html
deleted file mode 100644
index 6560050c..00000000
--- a/tests/assets/components/createAll/override-sdk/field/integer/integer.component.html
+++ /dev/null
@@ -1,29 +0,0 @@
-
-
-
-
-
-
-
- {{ label$ }}
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/field/integer/integer.component.scss b/tests/assets/components/createAll/override-sdk/field/integer/integer.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/override-sdk/field/integer/integer.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/integer/integer.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/integer/integer.component.spec.ts
deleted file mode 100644
index 1477d360..00000000
--- a/tests/assets/components/createAll/override-sdk/field/integer/integer.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { IntegerComponent } from './integer.component';
-
-describe('IntegerComponent', () => {
- let component: IntegerComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ IntegerComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(IntegerComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/integer/integer.component.ts b/tests/assets/components/createAll/override-sdk/field/integer/integer.component.ts
deleted file mode 100644
index c22cc828..00000000
--- a/tests/assets/components/createAll/override-sdk/field/integer/integer.component.ts
+++ /dev/null
@@ -1,180 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-integer',
- templateUrl: './integer.component.html',
- styleUrls: ['./integer.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class IntegerComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: number;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- testId: string;
- helperText: string;
-
- fieldControl = new FormControl(null, null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.testId = this.configProps$['testId'];
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
- let nValue = this.configProps$['value'];
- if (nValue) {
- if (typeof nValue == 'string') {
- nValue = parseInt(nValue);
- }
- this.value$ = nValue;
- }
- this.helperText = this.configProps$['helperText'];
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- // field control gets error message from here
-
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
-
diff --git a/tests/assets/components/createAll/override-sdk/field/percentage/config.json b/tests/assets/components/createAll/override-sdk/field/percentage/config.json
deleted file mode 100644
index 625968d2..00000000
--- a/tests/assets/components/createAll/override-sdk/field/percentage/config.json
+++ /dev/null
@@ -1,71 +0,0 @@
-{
- "name": "Percentage",
- "description": "Percentage",
- "type": "Field",
- "subtype": "DATA_CAPTURE",
- "icon": "images/pz-text-input-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "name": "decimalPrecision",
- "label": "Decimal places",
- "format": "NUMBER",
- "min": 0
- },
- {
- "name": "showGroupSeparators",
- "label": "Show thousands separator",
- "format": "BOOLEAN"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/percentage/percentage.component.html b/tests/assets/components/createAll/override-sdk/field/percentage/percentage.component.html
deleted file mode 100644
index 95498666..00000000
--- a/tests/assets/components/createAll/override-sdk/field/percentage/percentage.component.html
+++ /dev/null
@@ -1,30 +0,0 @@
-
-
-
-
-
-
-
- {{ label$ }}
-
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/field/percentage/percentage.component.scss b/tests/assets/components/createAll/override-sdk/field/percentage/percentage.component.scss
deleted file mode 100644
index af04528b..00000000
--- a/tests/assets/components/createAll/override-sdk/field/percentage/percentage.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
- }
-
- .psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(.75) perspective(100px) translateZ(.001px);
- -ms-transform: translateY(-1.28125em) scale(.75);
- width: 133.33333%;
- }
-
- .psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
- }
-
- ::ng-deep .mat-mdc-form-field-infix {
- width: auto;
- }
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/field/percentage/percentage.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/percentage/percentage.component.spec.ts
deleted file mode 100644
index adaeef98..00000000
--- a/tests/assets/components/createAll/override-sdk/field/percentage/percentage.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed } from '@angular/core/testing';
-
-import { PercentageComponent } from './percentage.component';
-
-describe('PercentageComponent', () => {
- let component: PercentageComponent;
- let fixture: ComponentFixture;
-
- beforeEach(async () => {
- await TestBed.configureTestingModule({
- declarations: [ PercentageComponent ]
- })
- .compileComponents();
- });
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PercentageComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/percentage/percentage.component.ts b/tests/assets/components/createAll/override-sdk/field/percentage/percentage.component.ts
deleted file mode 100644
index 2c753a08..00000000
--- a/tests/assets/components/createAll/override-sdk/field/percentage/percentage.component.ts
+++ /dev/null
@@ -1,176 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-percentage',
- templateUrl: './percentage.component.html',
- styleUrls: ['./percentage.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class PercentageComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: number;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- testId: string;
- helperText: string;
-
- fieldControl = new FormControl(null, null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.testId = this.configProps$['testId'];
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
- let nValue = this.configProps$['value'];
- if (nValue) {
- if (typeof nValue == 'string') {
- nValue = parseInt(nValue);
- }
- this.value$ = nValue;
- }
- this.helperText = this.configProps$['helperText'];
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
-
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- // field control gets error message from here
- let errMessage: string = '';
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
- return errMessage;
- }
-}
-
diff --git a/tests/assets/components/createAll/override-sdk/field/phone/config.json b/tests/assets/components/createAll/override-sdk/field/phone/config.json
deleted file mode 100644
index 64277806..00000000
--- a/tests/assets/components/createAll/override-sdk/field/phone/config.json
+++ /dev/null
@@ -1,66 +0,0 @@
-{
- "name": "Phone",
- "description": "Phone",
- "type": "Field",
- "subtype": "DATA_CAPTURE",
- "icon": "images/pz-phone-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "name": "showCountryCode",
- "label": "Show Country Code",
- "format": "BOOLEAN",
- "defaultValue": true
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/phone/phone.component.html b/tests/assets/components/createAll/override-sdk/field/phone/phone.component.html
deleted file mode 100644
index dd46cb2f..00000000
--- a/tests/assets/components/createAll/override-sdk/field/phone/phone.component.html
+++ /dev/null
@@ -1,27 +0,0 @@
-
-
-
-
-
-
-
-
-
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/field/phone/phone.component.scss b/tests/assets/components/createAll/override-sdk/field/phone/phone.component.scss
deleted file mode 100644
index 40d8f616..00000000
--- a/tests/assets/components/createAll/override-sdk/field/phone/phone.component.scss
+++ /dev/null
@@ -1,81 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
-
-.phone-label-readonly {
- opacity: 54%;
- font-size: 0.7rem;
-}
-
-::ng-deep .iti {
- display: block !important;
- margin-bottom: 20px;
-
- .dropdown-menu.country-dropdown {
- border-top-left-radius: 0px;
- border-top-right-radius: 0px;
- border-color: #c7cace;
- margin-top: -1px;
- }
-
- .iti__country-list {
- box-shadow: none;
- font-size: 14px;
- margin-left: 0;
- width: 244px;
- max-height: 170px;
- }
-
- .search-container input {
- font-size: 14px;
- border-color: #c7cace;
- border-radius: 0;
- padding: 5px 10px;
- }
-
- .search-container input:focus {
- outline: none;
- }
-}
-
-::ng-deep .iti__flag-container.open + input {
- border-bottom-left-radius: 0px;
- border-bottom-right-radius: 0px;
-}
-
-::ng-deep ngx-mat-intl-tel-input {
- .country-selector {
- opacity: 1 !important;
- bottom: 8px !important;
- }
-
- input:not(.country-search) {
- bottom: 3px;
- left: 10px;
- }
-
- .country-list-button {
- font-size: 0.8rem !important;
- }
-
- .mat-menu-content:not(:empty) {
- max-height: 250px;
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/phone/phone.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/phone/phone.component.spec.ts
deleted file mode 100644
index 73355d45..00000000
--- a/tests/assets/components/createAll/override-sdk/field/phone/phone.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PhoneComponent } from './phone.component';
-
-describe('PhoneComponent', () => {
- let component: PhoneComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PhoneComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PhoneComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/phone/phone.component.ts b/tests/assets/components/createAll/override-sdk/field/phone/phone.component.ts
deleted file mode 100644
index a0ffc1a5..00000000
--- a/tests/assets/components/createAll/override-sdk/field/phone/phone.component.ts
+++ /dev/null
@@ -1,193 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { NgxMatIntlTelInputComponent } from 'ngx-mat-intl-tel-input';
-import { Utils } from '@pega/angular-sdk-library';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { handleEvent } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-@Component({
- selector: 'app-phone',
- templateUrl: './phone.component.html',
- styleUrls: ['./phone.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, NgxMatIntlTelInputComponent, forwardRef(() => ComponentMapperComponent)]
-})
-export class PhoneComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: string;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- testId: string;
- separateDialCode = false;
- afterBlur: boolean;
- helperText: string;
-
- fieldControl = new FormControl('', null);
-
- phoneForm = new FormGroup({
- phone: new FormControl(undefined)
- });
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
- this.testId = this.configProps$['testId'];
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
- this.helperText = this.configProps$['helperText'];
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- if (this.bReadonly$) {
- this.phoneForm.setValue({ phone: this.value$ });
- }
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- if (this.formGroup$.controls[this.controlName$].value) {
- const actionsApi = this.pConn$?.getActionsApi();
- const propName = this.pConn$?.getStateProps().value;
- const value = this.formGroup$.controls[this.controlName$].value;
- const eventObj = {
- target: {
- value
- }
- };
- this.afterBlur = true;
- this.angularPConnectData.actions.onChange(this, eventObj);
- handleEvent(actionsApi, 'blur', propName, value);
- }
- }
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = 'Invalid Phone';
- }
-
- return errMessage;
- }
-}
-
diff --git a/tests/assets/components/createAll/override-sdk/field/radio-buttons/config.json b/tests/assets/components/createAll/override-sdk/field/radio-buttons/config.json
deleted file mode 100644
index 07012db9..00000000
--- a/tests/assets/components/createAll/override-sdk/field/radio-buttons/config.json
+++ /dev/null
@@ -1,55 +0,0 @@
-{
- "name": "RadioButtons",
- "description": "Picklist",
- "type": "Field",
- "subtype": "PICKERS",
- "icon": "images/pz-radio-button-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/radio-buttons/radio-buttons.component.html b/tests/assets/components/createAll/override-sdk/field/radio-buttons/radio-buttons.component.html
deleted file mode 100644
index f3ad2f23..00000000
--- a/tests/assets/components/createAll/override-sdk/field/radio-buttons/radio-buttons.component.html
+++ /dev/null
@@ -1,32 +0,0 @@
-
-
-
-
-
-
-
-
- {{ label$ }}
-
-
-
-
-
- {{ opt.value }}
-
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/field/radio-buttons/radio-buttons.component.scss b/tests/assets/components/createAll/override-sdk/field/radio-buttons/radio-buttons.component.scss
deleted file mode 100644
index 9cc21ff9..00000000
--- a/tests/assets/components/createAll/override-sdk/field/radio-buttons/radio-buttons.component.scss
+++ /dev/null
@@ -1,39 +0,0 @@
-.psdk-label-readonly {
- opacity: 54%;
- font-size: 0.7rem;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
-
-.psdk-radio-horizontal {
- display: flex;
- flex-direction: row;
-}
-
-.psdk-radio-vertical {
- display: flex;
- flex-direction: column;
-}
-
-.psdk-radio-button {
- padding: 0.3125rem;
-}
-
-.psdk-radio-form {
- width: 100%;
-}
-
-.psdk-radio-form ::ng-deep .mat-form-field-underline {
- background-color: transparent;
-}
-
-.psdk-radio-form ::ng-deep .mat-form-field-label {
- top: 0em;
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/radio-buttons/radio-buttons.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/radio-buttons/radio-buttons.component.spec.ts
deleted file mode 100644
index d24ce926..00000000
--- a/tests/assets/components/createAll/override-sdk/field/radio-buttons/radio-buttons.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { RadioButtonsComponent } from './radio-buttons.component';
-
-describe('RadioButtonsComponent', () => {
- let component: RadioButtonsComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ RadioButtonsComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(RadioButtonsComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/radio-buttons/radio-buttons.component.ts b/tests/assets/components/createAll/override-sdk/field/radio-buttons/radio-buttons.component.ts
deleted file mode 100644
index 2005fe48..00000000
--- a/tests/assets/components/createAll/override-sdk/field/radio-buttons/radio-buttons.component.ts
+++ /dev/null
@@ -1,189 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatRadioModule } from '@angular/material/radio';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-radio-buttons',
- templateUrl: './radio-buttons.component.html',
- styleUrls: ['./radio-buttons.component.scss'],
- providers: [Utils],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, MatRadioModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class RadioButtonsComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: string = '';
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- options$: Array;
- componentReference: string = '';
- testId: string;
- helperText: string;
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
-
- this.testId = this.configProps$['testId'];
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
- this.helperText = this.configProps$['helperText'];
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- this.options$ = this.utils.getOptionList(this.configProps$, this.pConn$.getDataObject());
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- isSelected(buttonValue: string): boolean {
- if (this.value$ === buttonValue) {
- return true;
- }
-
- return false;
- }
-
- fieldOnChange(event: any) {
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
-
diff --git a/tests/assets/components/createAll/override-sdk/field/semantic-link/semantic-link.component.html b/tests/assets/components/createAll/override-sdk/field/semantic-link/semantic-link.component.html
deleted file mode 100644
index 8789ac97..00000000
--- a/tests/assets/components/createAll/override-sdk/field/semantic-link/semantic-link.component.html
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
-
-
-
{{ label$ }}
-
{{ value$ || "---" }}
-
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/field/semantic-link/semantic-link.component.scss b/tests/assets/components/createAll/override-sdk/field/semantic-link/semantic-link.component.scss
deleted file mode 100644
index 85364323..00000000
--- a/tests/assets/components/createAll/override-sdk/field/semantic-link/semantic-link.component.scss
+++ /dev/null
@@ -1,16 +0,0 @@
-.psdk-grid-filter {
- display: grid;
- grid-template-columns: repeat(2, minmax(0, 1fr));
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
-
-.psdk-label {
- color: rgba(0, 0, 0, 0.54);
- margin: 8px 0px;
-}
-
-.psdk-value {
- margin: 8px 0px;
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/semantic-link/semantic-link.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/semantic-link/semantic-link.component.spec.ts
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/field/semantic-link/semantic-link.component.ts b/tests/assets/components/createAll/override-sdk/field/semantic-link/semantic-link.component.ts
deleted file mode 100644
index c323a0dc..00000000
--- a/tests/assets/components/createAll/override-sdk/field/semantic-link/semantic-link.component.ts
+++ /dev/null
@@ -1,58 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-semantic-link',
- templateUrl: './semantic-link.component.html',
- styleUrls: ['./semantic-link.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class SemanticLinkComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: string = '';
- displayMode$: string = '';
-
- constructor(private angularPConnect: AngularPConnectService) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.updateSelf();
- }
-
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- onStateChange() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.value$ = this.configProps$['text'] || '---';
- this.displayMode$ = this.configProps$['displayMode'];
- this.label$ = this.configProps$['label'];
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/text-area/config.json b/tests/assets/components/createAll/override-sdk/field/text-area/config.json
deleted file mode 100644
index c543f34e..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text-area/config.json
+++ /dev/null
@@ -1,60 +0,0 @@
-{
- "name": "TextArea",
- "description": "Text (paragraph)",
- "type": "Field",
- "subtype": "DATA_CAPTURE",
- "icon": "images/pz-text-area-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/text-area/text-area.component.html b/tests/assets/components/createAll/override-sdk/field/text-area/text-area.component.html
deleted file mode 100644
index 7e2962bd..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text-area/text-area.component.html
+++ /dev/null
@@ -1,28 +0,0 @@
-
-
-
-
-
-
-
-
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/field/text-area/text-area.component.scss b/tests/assets/components/createAll/override-sdk/field/text-area/text-area.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text-area/text-area.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/text-area/text-area.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/text-area/text-area.component.spec.ts
deleted file mode 100644
index 81dc1912..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text-area/text-area.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { TextAreaComponent } from './text-area.component';
-
-describe('TextAreaComponent', () => {
- let component: TextAreaComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ TextAreaComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(TextAreaComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/text-area/text-area.component.ts b/tests/assets/components/createAll/override-sdk/field/text-area/text-area.component.ts
deleted file mode 100644
index e360c948..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text-area/text-area.component.ts
+++ /dev/null
@@ -1,178 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-text-area',
- templateUrl: './text-area.component.html',
- styleUrls: ['./text-area.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class TextAreaComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: string = '';
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- nMaxLength$: number;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- testId: string;
- helperText: string;
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
- this.nMaxLength$ = this.pConn$.getFieldMetadata(this.pConn$.getRawConfigProps()?.value)?.maxLength || 100;
- this.testId = this.configProps$['testId'];
- this.displayMode$ = this.configProps$['displayMode'];
- this.label$ = this.configProps$['label'];
- this.helperText = this.configProps$['helperText'];
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- // PConnect wants to use changeHandler for onChange
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- // field control gets error message from here
-
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
-
diff --git a/tests/assets/components/createAll/override-sdk/field/text-content/config.json b/tests/assets/components/createAll/override-sdk/field/text-content/config.json
deleted file mode 100644
index 310d7922..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text-content/config.json
+++ /dev/null
@@ -1,28 +0,0 @@
-{
- "name": "TextContent",
- "description": "Text",
- "type": "Field",
- "subtype": "DATA_DISPLAY",
- "icon": "images/text-content.svg",
- "properties": [
- {
- "format": "SELECT",
- "name": "displayAs",
- "label": "Component",
- "defaultValue": "Paragraph",
- "source": [
- { "key": "Paragraph", "value": "Paragraph" },
- { "key": "Heading 1", "value": "Heading 1" },
- { "key": "Heading 2", "value": "Heading 2" },
- { "key": "Heading 3", "value": "Heading 3" },
- { "key": "Heading 4", "value": "Heading 4" }
- ]
- },
- {
- "name": "content",
- "label": " ",
- "format": "TEXT",
- "multiline": true
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/text-content/text-content.component.html b/tests/assets/components/createAll/override-sdk/field/text-content/text-content.component.html
deleted file mode 100644
index 9f8fa2e3..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text-content/text-content.component.html
+++ /dev/null
@@ -1,7 +0,0 @@
-
-
{{ content$ }}
-
{{ content$ }}
-
{{ content$ }}
-
{{ content$ }}
-
{{ content$ }}
-
diff --git a/tests/assets/components/createAll/override-sdk/field/text-content/text-content.component.scss b/tests/assets/components/createAll/override-sdk/field/text-content/text-content.component.scss
deleted file mode 100644
index 6674e65d..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text-content/text-content.component.scss
+++ /dev/null
@@ -1,4 +0,0 @@
-.psdk-data-readonly {
- margin-top: 0.625rem;
- width: 100%;
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/text-content/text-content.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/text-content/text-content.component.spec.ts
deleted file mode 100644
index b092e685..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text-content/text-content.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { TextContentComponent } from './text-content.component';
-
-describe('TextContentComponent', () => {
- let component: TextContentComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ TextContentComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(TextContentComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/text-content/text-content.component.ts b/tests/assets/components/createAll/override-sdk/field/text-content/text-content.component.ts
deleted file mode 100644
index a6178399..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text-content/text-content.component.ts
+++ /dev/null
@@ -1,75 +0,0 @@
-import { Component, OnInit, Input } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-text-content',
- templateUrl: './text-content.component.html',
- styleUrls: ['./text-content.component.scss'],
- standalone: true,
- imports: [CommonModule]
-})
-export class TextContentComponent implements OnInit {
- @Input() pConn$: any;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- content$: string = '';
- displayAs$: string;
- displayMode$: string = '';
-
- constructor(private angularPConnect: AngularPConnectService) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
- }
-
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- if (this.configProps$['content'] != undefined) {
- this.content$ = this.configProps$['content'];
- }
- if (this.configProps$['displayAs'] != undefined) {
- this.displayAs$ = this.configProps$['displayAs'];
- }
- this.displayMode$ = this.configProps$['displayMode'];
-
- // Any update to content or displayAs will re-render this component.
- // All rendering logic is in the .html file.
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/text-input/config.json b/tests/assets/components/createAll/override-sdk/field/text-input/config.json
deleted file mode 100644
index 1e73ff8e..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text-input/config.json
+++ /dev/null
@@ -1,60 +0,0 @@
-{
- "name": "TextInput",
- "description": "Text (single line)",
- "type": "Field",
- "subtype": "DATA_CAPTURE",
- "icon": "images/pz-text-input-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/text-input/text-input.component.html b/tests/assets/components/createAll/override-sdk/field/text-input/text-input.component.html
deleted file mode 100644
index 3e8e022f..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text-input/text-input.component.html
+++ /dev/null
@@ -1,28 +0,0 @@
-
-
-
-
-
-
-
- {{ label$ }}
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/field/text-input/text-input.component.scss b/tests/assets/components/createAll/override-sdk/field/text-input/text-input.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text-input/text-input.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/text-input/text-input.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/text-input/text-input.component.spec.ts
deleted file mode 100644
index 6dd3bfb3..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text-input/text-input.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { TextInputComponent } from './text-input.component';
-
-describe('TextInputComponent', () => {
- let component: TextInputComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ TextInputComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(TextInputComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/text-input/text-input.component.ts b/tests/assets/components/createAll/override-sdk/field/text-input/text-input.component.ts
deleted file mode 100644
index 4210cd0d..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text-input/text-input.component.ts
+++ /dev/null
@@ -1,177 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-text-input',
- templateUrl: './text-input.component.html',
- styleUrls: ['./text-input.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class TextInputComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // For interaction with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: string = '';
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- testId: string = '';
- bHasForm$: boolean = true;
- componentReference: string = '';
- helperText: string;
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- // this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
-
- this.testId = this.configProps$['testId'];
-
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
- this.helperText = this.configProps$['helperText'];
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
-
diff --git a/tests/assets/components/createAll/override-sdk/field/text/text.component.html b/tests/assets/components/createAll/override-sdk/field/text/text.component.html
deleted file mode 100644
index 55ddf6b7..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text/text.component.html
+++ /dev/null
@@ -1,14 +0,0 @@
-
-
-
-
-
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/field/text/text.component.scss b/tests/assets/components/createAll/override-sdk/field/text/text.component.scss
deleted file mode 100644
index bee2b661..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text/text.component.scss
+++ /dev/null
@@ -1,30 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- opacity: 54%;
- font-size: 0.7rem;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
-
-.psdk-grid-filter {
- display: grid;
- grid-template-columns: repeat(2, minmax(0, 1fr));
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
-
-.psdk-details-fields-label {
- color: rgba(0, 0, 0, 0.54);
- margin: 8px 0px;
-}
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/field/text/text.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/text/text.component.spec.ts
deleted file mode 100644
index fa94e0e4..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text/text.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { TextComponent } from './text.component';
-
-describe('TextComponent', () => {
- let component: TextComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ TextComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(TextComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/text/text.component.ts b/tests/assets/components/createAll/override-sdk/field/text/text.component.ts
deleted file mode 100644
index 2f74487b..00000000
--- a/tests/assets/components/createAll/override-sdk/field/text/text.component.ts
+++ /dev/null
@@ -1,145 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-text',
- templateUrl: './text.component.html',
- styleUrls: ['./text.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class TextComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formatAs$: string;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: string = '';
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- componentReference: string = '';
- formattedValue$: string;
- format$: string = 'text';
- formattedUrl$: string = '';
-
- constructor(private angularPConnect: AngularPConnectService, private utils: Utils) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- this.checkAndUpdate();
- }
-
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
-
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
-
- // TDB - get formats
- switch (this.formatAs$) {
- case 'text':
- this.formattedValue$ = this.value$;
- break;
- case 'date':
- this.formattedValue$ = this.generateDate(this.value$);
- break;
- case 'date-time':
- this.formattedValue$ = this.generateDateTime(this.value$);
- break;
- case 'time':
- if (this.value$) {
- const timeParts = this.value$.split(':');
- this.formattedValue$ = `${timeParts[0]}:${timeParts[1]}`;
- } else {
- this.formattedValue$ = '';
- }
- break;
- case 'url':
- this.formattedUrl$ = this.generateUrl(this.value$);
- this.formattedValue$ = this.value$;
- break;
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- generateUrl(sVal): string {
- if (sVal.indexOf('https://') == 0 || sVal.indexOf('http://') == 0) {
- } else {
- // assume no http
- sVal = 'http://' + sVal;
- }
-
- return sVal;
- }
-
- generateDate(sVal): string {
- if (!sVal) return '';
- // const value = new Intl.DateTimeFormat('default', {
- // year: 'numeric',
- // month: 'numeric',
- // day: 'numeric'
- // }).format(new Date(sVal + "T00:00"));
-
- return this.utils.generateDate(sVal, 'Date-Long-Custom-YYYY');
- }
-
- generateDateTime(sVal): string {
- if (!sVal) return '';
- if (sVal.length === 10) return this.generateDate(sVal);
- let value = sVal.substring(0, sVal.length - 1);
- // value = new Intl.DateTimeFormat('default', {
- // year: 'numeric',
- // month: 'numeric',
- // day: 'numeric',
- // hour: 'numeric',
- // minute: 'numeric',
- // second: 'numeric',
- // hour12: true,
- // }).format(new Date(value))
-
- return this.utils.generateDateTime(value, 'DateTime-Long-YYYY-Custom');
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/time/config.json b/tests/assets/components/createAll/override-sdk/field/time/config.json
deleted file mode 100644
index 07cacb09..00000000
--- a/tests/assets/components/createAll/override-sdk/field/time/config.json
+++ /dev/null
@@ -1,112 +0,0 @@
-{
- "name": "Time",
- "description": "Time only",
- "type": "Field",
- "subtype": "DATA_CAPTURE",
- "icon": "images/pz-date-time-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "format": "SELECT",
- "name": "clockFormat",
- "label": "Clock",
- "defaultValue": "use locale",
- "source": [
- {
- "key": 0,
- "value": "use locale"
- },
- {
- "key": 12,
- "value": "12 hours"
- },
- {
- "key": 24,
- "value": "24 hours"
- }
- ]
- },
- {
- "name": "withSeconds",
- "label": "Display Seconds",
- "format": "BOOLEAN"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "format": "SELECT",
- "name": "pickerInterval",
- "label": "Time picker",
- "defaultValue": "30",
- "source": [
- {
- "key": "5",
- "value": "5 min"
- },
- {
- "key": "10",
- "value": "10 min"
- },
- {
- "key": "15",
- "value": "15 min"
- },
- {
- "key": "20",
- "value": "20 min"
- },
- {
- "key": "30",
- "value": "30 min"
- },
- {
- "key": "60",
- "value": "1 hr"
- }
- ]
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/time/time.component.html b/tests/assets/components/createAll/override-sdk/field/time/time.component.html
deleted file mode 100644
index f3c4798a..00000000
--- a/tests/assets/components/createAll/override-sdk/field/time/time.component.html
+++ /dev/null
@@ -1,27 +0,0 @@
-
-
-
-
-
-
-
- {{ label$ }}
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/field/time/time.component.scss b/tests/assets/components/createAll/override-sdk/field/time/time.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/override-sdk/field/time/time.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/time/time.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/time/time.component.spec.ts
deleted file mode 100644
index 0d748765..00000000
--- a/tests/assets/components/createAll/override-sdk/field/time/time.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed } from '@angular/core/testing';
-
-import { TimeComponent } from './time.component';
-
-describe('TimeComponent', () => {
- let component: TimeComponent;
- let fixture: ComponentFixture;
-
- beforeEach(async () => {
- await TestBed.configureTestingModule({
- declarations: [ TimeComponent ]
- })
- .compileComponents();
- });
-
- beforeEach(() => {
- fixture = TestBed.createComponent(TimeComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/time/time.component.ts b/tests/assets/components/createAll/override-sdk/field/time/time.component.ts
deleted file mode 100644
index 28329a63..00000000
--- a/tests/assets/components/createAll/override-sdk/field/time/time.component.ts
+++ /dev/null
@@ -1,172 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-time',
- templateUrl: './time.component.html',
- styleUrls: ['./time.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class TimeComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: string;
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- helperText: string;
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
-
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
- this.helperText = this.configProps$['helperText'];
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- event.value = event.target.value;
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- event.value = event.target.value;
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
- return errMessage;
- }
-}
-
diff --git a/tests/assets/components/createAll/override-sdk/field/url/config.json b/tests/assets/components/createAll/override-sdk/field/url/config.json
deleted file mode 100644
index d4d3e1f7..00000000
--- a/tests/assets/components/createAll/override-sdk/field/url/config.json
+++ /dev/null
@@ -1,60 +0,0 @@
-{
- "name": "URL",
- "description": "URL",
- "type": "Field",
- "subtype": "DATA_CAPTURE",
- "icon": "images/pz-url-active.svg",
- "properties": [
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/url/url.component.html b/tests/assets/components/createAll/override-sdk/field/url/url.component.html
deleted file mode 100644
index cbbec6ba..00000000
--- a/tests/assets/components/createAll/override-sdk/field/url/url.component.html
+++ /dev/null
@@ -1,27 +0,0 @@
-
-
-
-
-
-
-
- {{ label$ }}
-
- {{ getErrorMessage() }}
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/field/url/url.component.scss b/tests/assets/components/createAll/override-sdk/field/url/url.component.scss
deleted file mode 100644
index 2e3f5529..00000000
--- a/tests/assets/components/createAll/override-sdk/field/url/url.component.scss
+++ /dev/null
@@ -1,20 +0,0 @@
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/url/url.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/url/url.component.spec.ts
deleted file mode 100644
index c11fc489..00000000
--- a/tests/assets/components/createAll/override-sdk/field/url/url.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { UrlComponent } from './url.component';
-
-describe('UrlComponent', () => {
- let component: UrlComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ UrlComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(UrlComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/url/url.component.ts b/tests/assets/components/createAll/override-sdk/field/url/url.component.ts
deleted file mode 100644
index cb1d6538..00000000
--- a/tests/assets/components/createAll/override-sdk/field/url/url.component.ts
+++ /dev/null
@@ -1,174 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-url',
- templateUrl: './url.component.html',
- styleUrls: ['./url.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class UrlComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- label$: string = '';
- value$: string = '';
- bRequired$: boolean = false;
- bReadonly$: boolean = false;
- bDisabled$: boolean = false;
- bVisible$: boolean = true;
- displayMode$: string = '';
- controlName$: string;
- bHasForm$: boolean = true;
- componentReference: string = '';
- helperText: string;
-
- fieldControl = new FormControl('', null);
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private cdRef: ChangeDetectorRef,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- // Then, continue on with other initialization
-
- // call updateSelf when initializing
- //this.updateSelf();
- this.checkAndUpdate();
-
- if (this.formGroup$ != null) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- this.bHasForm$ = true;
- } else {
- this.bReadonly$ = true;
- this.bHasForm$ = false;
- }
- }
-
- ngOnDestroy(): void {
- if (this.formGroup$ != null) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- if (this.configProps$['value'] != undefined) {
- this.value$ = this.configProps$['value'];
- }
-
- this.label$ = this.configProps$['label'];
- this.displayMode$ = this.configProps$['displayMode'];
- this.helperText = this.configProps$['helperText'];
-
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
- setTimeout(() => {
- if (this.configProps$['required'] != null) {
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$['required']);
- }
- this.cdRef.detectChanges();
- });
-
- if (this.configProps$['visibility'] != null) {
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // disabled
- if (this.configProps$['disabled'] != undefined) {
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$['disabled']);
- }
-
- if (this.bDisabled$) {
- this.fieldControl.disable();
- } else {
- this.fieldControl.enable();
- }
-
- if (this.configProps$['readOnly'] != null) {
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$['readOnly']);
- }
-
- this.componentReference = this.pConn$.getStateProps().value;
-
- // trigger display of error message with field control
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
- let timer = interval(100).subscribe(() => {
- this.fieldControl.setErrors({ message: true });
- this.fieldControl.markAsTouched();
-
- timer.unsubscribe();
- });
- }
- }
-
- fieldOnChange(event: any) {
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnClick(event: any) {}
-
- fieldOnBlur(event: any) {
- // PConnect wants to use eventHandler for onBlur
- this.angularPConnectData.actions.onBlur(this, event);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
-
diff --git a/tests/assets/components/createAll/override-sdk/field/user-reference/config.json b/tests/assets/components/createAll/override-sdk/field/user-reference/config.json
deleted file mode 100644
index 0f6bcff6..00000000
--- a/tests/assets/components/createAll/override-sdk/field/user-reference/config.json
+++ /dev/null
@@ -1,77 +0,0 @@
-{
- "name": "UserReference",
- "description": "User reference",
- "type": "Field",
- "subtype": "DATA_CAPTURE",
- "icon": "images/pz-text-input-active.svg",
- "properties": [
- {
- "name": "displayAs",
- "label": "Display As",
- "format": "TEXT",
- "disabled": true
- },
- {
- "name": "label",
- "label": "Field label",
- "format": "TEXT",
- "required": true
- },
- {
- "name": "readOnly",
- "label": "Edit mode",
- "format": "READONLY"
- },
- {
- "label": "Input settings",
- "format": "GROUP",
- "visibility": "(!readOnly = true)",
- "properties": [
- {
- "name": "placeholder",
- "label": "Placeholder",
- "format": "TEXT"
- },
- {
- "name": "helperText",
- "label": "Helper text",
- "format": "TEXT"
- }
- ]
- },
- {
- "label": "Read-only settings",
- "format": "GROUP",
- "properties": [
- {
- "name": "showAsFormattedText",
- "label": "Show as formatted text",
- "format": "BOOLEAN"
- }
- ]
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "visibility": "(!readOnly = true)"
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/user-reference/user-reference.component.html b/tests/assets/components/createAll/override-sdk/field/user-reference/user-reference.component.html
deleted file mode 100644
index 85125fae..00000000
--- a/tests/assets/components/createAll/override-sdk/field/user-reference/user-reference.component.html
+++ /dev/null
@@ -1,49 +0,0 @@
-
-
- {{ label$ }}
-
-
-
-
-
-
- {{ opt.value }}
-
-
- {{ label$ }}
-
- {{ getErrorMessage() }}
-
-
-
-
-
- {{ label$ }}
-
-
-
- {{ opt.value }}
-
-
-
- {{ getErrorMessage() }}
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/field/user-reference/user-reference.component.scss b/tests/assets/components/createAll/override-sdk/field/user-reference/user-reference.component.scss
deleted file mode 100644
index d7803db3..00000000
--- a/tests/assets/components/createAll/override-sdk/field/user-reference/user-reference.component.scss
+++ /dev/null
@@ -1,30 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-.psdk-user-reference {
- font-size: 0.8rem;
- color: $app-neutral-color;
-}
-.psdk-single {
- flex: 1;
-}
-
-.psdk-double {
- flex: 2;
-}
-
-.psdk-top-pad {
- padding-top: 10px;
-}
-
-.psdk-full-width {
- width: 100%;
- padding-left: 0.625rem;
-}
-
-dt {
- flex: 1;
-}
-
-dd {
- flex: 2;
-}
diff --git a/tests/assets/components/createAll/override-sdk/field/user-reference/user-reference.component.spec.ts b/tests/assets/components/createAll/override-sdk/field/user-reference/user-reference.component.spec.ts
deleted file mode 100644
index 375bda7e..00000000
--- a/tests/assets/components/createAll/override-sdk/field/user-reference/user-reference.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { UserReferenceComponent } from './user-reference.component';
-
-describe('UserReferenceComponent', () => {
- let component: UserReferenceComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ UserReferenceComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(UserReferenceComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/field/user-reference/user-reference.component.ts b/tests/assets/components/createAll/override-sdk/field/user-reference/user-reference.component.ts
deleted file mode 100644
index c18d0283..00000000
--- a/tests/assets/components/createAll/override-sdk/field/user-reference/user-reference.component.ts
+++ /dev/null
@@ -1,207 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { MatAutocompleteModule } from '@angular/material/autocomplete';
-import { MatInputModule } from '@angular/material/input';
-import { MatOptionModule } from '@angular/material/core';
-import { MatSelectModule } from '@angular/material/select';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { OperatorComponent } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-const OPERATORS_DP = 'D_pyGetOperatorsForCurrentApplication';
-const DROPDOWN_LIST = 'Drop-down list';
-const SEARCH_BOX = 'Search box';
-
-@Component({
- selector: 'app-user-reference',
- templateUrl: './user-reference.component.html',
- styleUrls: ['./user-reference.component.scss'],
- standalone: true,
- imports: [
- CommonModule,
- OperatorComponent,
- ReactiveFormsModule,
- MatFormFieldModule,
- MatSelectModule,
- MatOptionModule,
- MatInputModule,
- MatAutocompleteModule,
- forwardRef(() => ComponentMapperComponent)
- ]
-})
-export class UserReferenceComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- PCore$: any;
- angularPConnectData: any = {};
- controlName$: string;
- value$;
- userName$: string;
- label$: string;
- userID$: string;
- options$: any;
- bReadonly$: boolean;
- bRequired$: boolean;
- showAsFormattedText$: boolean;
- displayAs$: string;
- testId: string;
- helperText: string;
-
- fieldControl = new FormControl('', null);
-
- constructor(private angularPConnect: AngularPConnectService, private utils: Utils) {}
-
- ngOnInit(): void {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
-
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- this.controlName$ = this.angularPConnect.getComponentID(this);
-
- this.checkAndUpdate();
-
- if (this.formGroup$) {
- // add control to formGroup
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
- this.fieldControl.setValue(this.value$);
- }
- }
-
- ngOnDestroy() {
- if (this.formGroup$) {
- this.formGroup$.removeControl(this.controlName$);
- }
-
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- get type(): string {
- if (this.bReadonly$ && this.showAsFormattedText$) {
- return 'operator';
- }
- if (this.displayAs$ === DROPDOWN_LIST) {
- return 'dropdown';
- }
- if (this.displayAs$ === SEARCH_BOX) {
- return 'searchbox';
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- let props = this.pConn$.getConfigProps();
- this.testId = props['testId'];
-
- const { label, displayAs, value, showAsFormattedText, helperText } = props;
-
- this.label$ = label;
- this.showAsFormattedText$ = showAsFormattedText;
- this.displayAs$ = displayAs;
- this.helperText = helperText;
-
- let { readOnly, required, disabled } = props;
- [this.bReadonly$, this.bRequired$, disabled] = [readOnly, required, disabled].map(
- (prop) => prop === true || (typeof prop === 'string' && prop === 'true')
- );
-
- const isUserNameAvailable = (user) => {
- return typeof user === 'object' && user !== null && user.userName;
- };
-
- this.userID$ = this.utils.getUserId(value);
-
- if (this.userID$ && this.bReadonly$ && this.showAsFormattedText$) {
- if (isUserNameAvailable(value)) {
- this.userName$ = value.userName;
- } else {
- // if same user ref field is referred in view as editable & readonly formatted text
- // referenced users won't be available, so get user details from dx api
- const { getOperatorDetails } = this.PCore$.getUserApi();
- getOperatorDetails(this.userID$).then((resp) => {
- if (resp.data && resp.data.pyOperatorInfo && resp.data.pyOperatorInfo.pyUserName) {
- this.userName$ = resp.data.pyOperatorInfo.pyUserName;
- }
- });
- }
- } else if (displayAs === DROPDOWN_LIST || displayAs === SEARCH_BOX) {
- const queryPayload = {
- dataViewName: OPERATORS_DP
- };
- this.PCore$.getRestClient()
- .invokeRestApi('getListData', { queryPayload })
- .then((resp) => {
- const ddDataSource = resp.data.data.map((listItem) => ({
- key: listItem.pyUserIdentifier,
- value: listItem.pyUserName
- }));
- this.options$ = ddDataSource;
- })
- .catch((err) => {
- console.log(err);
- });
- }
- }
-
- fieldOnChange(event: any) {
- if (event?.value === 'Select') {
- event.value = '';
- }
- this.angularPConnectData.actions.onChange(this, event);
- }
-
- fieldOnBlur(event: any) {
- let key = '';
- if (event?.target?.value) {
- const index = this.options$?.findIndex((element) => element.value === event.target.value);
- key = index > -1 ? (key = this.options$[index].key) : event.target.value;
- }
-
- const eve = {
- value: key
- };
- // PConnect wants to use eventHandler for onBlur
- this.angularPConnectData.actions.onChange(this, eve);
- }
-
- getErrorMessage() {
- let errMessage: string = '';
-
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
- if (this.fieldControl.hasError('message')) {
- errMessage = this.angularPConnectData.validateMessage;
- return errMessage;
- } else if (this.fieldControl.hasError('required')) {
- errMessage = 'You must enter a value';
- } else if (this.fieldControl.errors) {
- errMessage = this.fieldControl.errors.toString();
- }
-
- return errMessage;
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/infra/_infra.md b/tests/assets/components/createAll/override-sdk/infra/_infra.md
deleted file mode 100644
index 5d1cef65..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/_infra.md
+++ /dev/null
@@ -1,6 +0,0 @@
-# The **override-sdk/infra** directory
-
-The **src/components/override-sdk/infra** directory contains the code for **infrastructure** components for which you want to override the default implementation for use with the **Angular SDK**.
-
-When run the **npm run create** command to override the default implementation of an **infrastructure** component, the generated code that you can use as a
-starting point for your component development will be placed in type-specific and component-specific folders in **src/components/override-sdk/infra**.
diff --git a/tests/assets/components/createAll/override-sdk/infra/action-buttons/action-buttons.component.html b/tests/assets/components/createAll/override-sdk/infra/action-buttons/action-buttons.component.html
deleted file mode 100644
index 0204089a..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/action-buttons/action-buttons.component.html
+++ /dev/null
@@ -1,12 +0,0 @@
-
-
-
- {{ aButton.name }}
-
-
-
-
- {{ aButton.name }}
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/infra/action-buttons/action-buttons.component.scss b/tests/assets/components/createAll/override-sdk/infra/action-buttons/action-buttons.component.scss
deleted file mode 100644
index f1197474..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/action-buttons/action-buttons.component.scss
+++ /dev/null
@@ -1 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/infra/action-buttons/action-buttons.component.spec.ts b/tests/assets/components/createAll/override-sdk/infra/action-buttons/action-buttons.component.spec.ts
deleted file mode 100644
index dcdfb8d8..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/action-buttons/action-buttons.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { ActionButtonsComponent } from './action-buttons.component';
-
-describe('ActionButtonsComponent', () => {
- let component: ActionButtonsComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ ActionButtonsComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(ActionButtonsComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/infra/action-buttons/action-buttons.component.ts b/tests/assets/components/createAll/override-sdk/infra/action-buttons/action-buttons.component.ts
deleted file mode 100644
index 6f198ab7..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/action-buttons/action-buttons.component.ts
+++ /dev/null
@@ -1,26 +0,0 @@
-import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { MatButtonModule } from '@angular/material/button';
-import { MatGridListModule } from '@angular/material/grid-list';
-
-@Component({
- selector: 'app-action-buttons',
- templateUrl: './action-buttons.component.html',
- styleUrls: ['./action-buttons.component.scss'],
- standalone: true,
- imports: [CommonModule, MatGridListModule, MatButtonModule]
-})
-export class ActionButtonsComponent implements OnInit {
- @Input() arMainButtons$: Array;
- @Input() arSecondaryButtons$: Array;
-
- @Output() actionButtonClick: EventEmitter = new EventEmitter();
-
- constructor() {}
-
- ngOnInit(): void {}
-
- buttonClick(sAction, sButtonType) {
- this.actionButtonClick.emit({ action: sAction, buttonType: sButtonType });
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/infra/assignment-card/assignment-card.component.html b/tests/assets/components/createAll/override-sdk/infra/assignment-card/assignment-card.component.html
deleted file mode 100644
index 42f49bbd..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/assignment-card/assignment-card.component.html
+++ /dev/null
@@ -1,22 +0,0 @@
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/infra/assignment-card/assignment-card.component.scss b/tests/assets/components/createAll/override-sdk/infra/assignment-card/assignment-card.component.scss
deleted file mode 100644
index 99870edb..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/assignment-card/assignment-card.component.scss
+++ /dev/null
@@ -1,9 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-.psdk-case-view-divider {
- border-bottom: 0.0625rem solid $app-neutral-light-color;
-}
-
-.psdk-flow-container {
- padding: 0rem 1rem;
-}
diff --git a/tests/assets/components/createAll/override-sdk/infra/assignment-card/assignment-card.component.spec.ts b/tests/assets/components/createAll/override-sdk/infra/assignment-card/assignment-card.component.spec.ts
deleted file mode 100644
index 061b2307..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/assignment-card/assignment-card.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { AssignmentCardComponent } from './assignment-card.component';
-
-describe('AssignmentCardComponent', () => {
- let component: AssignmentCardComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ AssignmentCardComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(AssignmentCardComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/infra/assignment-card/assignment-card.component.ts b/tests/assets/components/createAll/override-sdk/infra/assignment-card/assignment-card.component.ts
deleted file mode 100644
index 0717a5f4..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/assignment-card/assignment-card.component.ts
+++ /dev/null
@@ -1,44 +0,0 @@
-import { Component, OnInit, Input, Output, EventEmitter, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup, ReactiveFormsModule } from '@angular/forms';
-import { ReferenceComponent } from '@pega/angular-sdk-library';
-import { RegionComponent } from '@pega/angular-sdk-library';
-import { CaseCreateStageComponent } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-assignment-card',
- templateUrl: './assignment-card.component.html',
- styleUrls: ['./assignment-card.component.scss'],
- standalone: true,
- imports: [CommonModule, ReactiveFormsModule, CaseCreateStageComponent, RegionComponent, forwardRef(() => ComponentMapperComponent)]
-})
-export class AssignmentCardComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
- @Input() arMainButtons$: Array;
- @Input() arSecondaryButtons$: Array;
- @Input() arChildren$: Array;
- @Input() updateToken$: number;
-
- @Output() actionButtonClick: EventEmitter = new EventEmitter();
-
- constructor() {}
-
- ngOnInit(): void {
- // Children may contain 'reference' component, so we need to
- // normalize them
- this.arChildren$ = ReferenceComponent.normalizePConnArray(this.arChildren$);
- }
-
- ngOnChanges(data: any) {
- // Children may contain 'reference' component, so we need to
- // normalize them
- this.arChildren$ = ReferenceComponent.normalizePConnArray(this.arChildren$);
- }
-
- onActionButtonClick(oData: any) {
- this.actionButtonClick.emit(oData);
- }
-}
-
diff --git a/tests/assets/components/createAll/override-sdk/infra/assignment/assignment.component.html b/tests/assets/components/createAll/override-sdk/infra/assignment/assignment.component.html
deleted file mode 100644
index 711b9df7..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/assignment/assignment.component.html
+++ /dev/null
@@ -1,28 +0,0 @@
-
diff --git a/tests/assets/components/createAll/override-sdk/infra/assignment/assignment.component.scss b/tests/assets/components/createAll/override-sdk/infra/assignment/assignment.component.scss
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/infra/assignment/assignment.component.spec.ts b/tests/assets/components/createAll/override-sdk/infra/assignment/assignment.component.spec.ts
deleted file mode 100644
index 7b8510c3..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/assignment/assignment.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { AssignmentComponent } from './assignment.component';
-
-describe('AssignmentComponent', () => {
- let component: AssignmentComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ AssignmentComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(AssignmentComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/infra/assignment/assignment.component.ts b/tests/assets/components/createAll/override-sdk/infra/assignment/assignment.component.ts
deleted file mode 100644
index 4f91acb2..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/assignment/assignment.component.ts
+++ /dev/null
@@ -1,437 +0,0 @@
-/* eslint-disable no-case-declarations */
-import { Component, OnInit, Input, SimpleChange, NgZone, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { ErrorMessagesService } from '@pega/angular-sdk-library';
-import { ProgressSpinnerService } from '@pega/angular-sdk-library';
-import { ReferenceComponent } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-declare const PCore: any;
-
-declare const window: any;
-
-@Component({
- selector: 'app-assignment',
- templateUrl: './assignment.component.html',
- styleUrls: ['./assignment.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class AssignmentComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
- @Input() arChildren$: Array;
- @Input() itemKey$: string;
- @Input() isCreateStage$: boolean;
- @Input() updateToken$: number;
- @Input() isInModal$: boolean = false;
- @Input() banners;
-
- // For interaction with AngularPConnect
- angularPConnectData: any = {};
- PCore$: any;
- configProps$: Object;
-
- newPConn$: any;
- containerName$: string;
-
- bIsRefComponent: boolean = false;
- bInitialized: boolean = false;
-
- templateName$: string;
-
- arMainButtons$: Array;
- arSecondaryButtons$: Array;
-
- actionsAPI: any;
-
- bHasNavigation$: boolean = false;
- bIsVertical$: boolean = false;
- arCurrentStepIndicies$: Array = new Array();
- arNavigationSteps$: Array = new Array();
-
- init: boolean;
- finishAssignment: any;
- navigateToStep: any;
- saveAssignment: any;
- cancelAssignment: any;
- cancelCreateStageAssignment: any;
- showPage: any;
-
- //itemKey: string = ""; // JA - this is what Nebula/Constellation uses to pass to finishAssignment, navigateToStep
-
- bReInit: boolean = false;
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private psService: ProgressSpinnerService,
- private erService: ErrorMessagesService,
- private ngZone: NgZone
- ) {}
-
- ngOnInit(): void {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
-
- // // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- this.initComponent();
-
- this.angularPConnect.shouldComponentUpdate(this);
-
- this.bInitialized = true;
- }
-
- ngOnDestroy() {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- // AND removing the "gate" that was put there since shouldComponentUpdate
- // should be the real "gate"
- if (bUpdateSelf) {
- let loadingInfo;
- try {
- //loadingInfo = this.pConn$.getLoadingStatus();
- loadingInfo = this.newPConn$.getLoadingStatus();
-
- this.psService.sendMessage(loadingInfo);
- } catch (ex) {}
- }
- }
-
- ngOnChanges(changes: { [propName: string]: SimpleChange }) {
- if (this.bInitialized) {
- this.updateChanges();
- }
- }
-
- updateChanges() {
- this.bIsRefComponent = this.checkIfRefComponent(this.pConn$);
-
- this.ngZone.run(() => {
- // pConn$ may be a 'reference' component, so normalize it
- //this.pConn$ = ReferenceComponent.normalizePConn(this.pConn$);
- this.newPConn$ = ReferenceComponent.normalizePConn(this.pConn$);
-
- // If 'reference' so we need to get the children of the normalized pConn
- if (this.bIsRefComponent) {
- //this.arChildren$ = ReferenceComponent.normalizePConnArray(this.pConn$.getChildren());
- this.arChildren$ = ReferenceComponent.normalizePConnArray(this.newPConn$.getChildren());
- }
- });
-
- this.createButtons();
- }
-
- checkIfRefComponent(thePConn: any): boolean {
- let bReturn = false;
- if (thePConn && thePConn.getComponentName() == 'reference') {
- bReturn = true;
- }
-
- return bReturn;
- }
-
- initComponent() {
- this.bIsRefComponent = this.checkIfRefComponent(this.pConn$);
-
- // pConn$ may be a 'reference' component, so normalize it
- //this.pConn$ = ReferenceComponent.normalizePConn(this.pConn$);
- this.newPConn$ = ReferenceComponent.normalizePConn(this.pConn$);
-
- // If 'reference' so we need to get the children of the normalized pConn
- if (this.bIsRefComponent) {
- //this.arChildren$ = ReferenceComponent.normalizePConnArray(this.pConn$.getChildren());
- this.arChildren$ = ReferenceComponent.normalizePConnArray(this.newPConn$.getChildren());
- }
-
- // prevent re-intializing with flowContainer update unless an action is taken
- this.bReInit = false;
- this.bHasNavigation$ = false;
-
- //this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.configProps$ = this.newPConn$.resolveConfigProps(this.newPConn$.getConfigProps());
-
- this.templateName$ = this.configProps$['template'];
-
- // create pointers to functions
- /*
- let containerMgr = this.pConn$.getContainerManager();
- let actionsAPI = this.pConn$.getActionsApi();
- let baseContext = this.pConn$.getContextName();
- let acName = this.pConn$.getContainerName();
- */
-
- let actionsAPI = this.newPConn$.getActionsApi();
- let baseContext = this.newPConn$.getContextName();
- let acName = this.newPConn$.getContainerName();
-
- // for now, in general this should be overridden by updateSelf(), and not be blank
- if (this.itemKey$ === '') {
- this.itemKey$ = baseContext.concat('/').concat(acName);
- }
-
- //this.pConn$.isBoundToState();
- this.newPConn$.isBoundToState();
-
- this.init = false;
-
- // store off bound functions to above pointers
- this.finishAssignment = actionsAPI.finishAssignment.bind(actionsAPI);
- this.navigateToStep = actionsAPI.navigateToStep.bind(actionsAPI);
- this.saveAssignment = actionsAPI.saveAssignment.bind(actionsAPI);
- this.cancelAssignment = actionsAPI.cancelAssignment.bind(actionsAPI);
- this.showPage = actionsAPI.showPage.bind(actionsAPI);
-
- this.cancelCreateStageAssignment = actionsAPI.cancelCreateStageAssignment.bind(actionsAPI);
-
- this.createButtons();
- }
-
- createButtons() {
- //let oData = this.pConn$.getDataObject();
- let oData = this.newPConn$.getDataObject();
-
- // inside
- // get fist kid, get the name and displa
- // pass first kid to a view container, which will disperse it to a view which will use one column, two column, etc.
- let oWorkItem = this.arChildren$[0].getPConnect();
- let oWorkData = oWorkItem.getDataObject();
-
- if (oWorkData) {
- this.actionsAPI = oWorkItem.getActionsApi();
-
- //this.containerName$ = oWorkMeta["name"];
-
- if (oWorkData.caseInfo && oWorkData.caseInfo.assignments !== null) {
- this.containerName$ = oWorkData.caseInfo.assignments?.[0].name;
-
- // get caseInfo
- let oCaseInfo = oData.caseInfo;
-
- if (oCaseInfo && oCaseInfo.actionButtons) {
- this.arMainButtons$ = oCaseInfo.actionButtons.main;
- this.arSecondaryButtons$ = oCaseInfo.actionButtons.secondary;
- }
-
- if (oCaseInfo.navigation != null) {
- this.bHasNavigation$ = true;
-
- if (oCaseInfo.navigation.template && oCaseInfo.navigation.template.toLowerCase() === 'standard') {
- this.bHasNavigation$ = false;
- } else if (oCaseInfo.navigation.template && oCaseInfo.navigation.template.toLowerCase() === 'vertical') {
- this.bIsVertical$ = true;
- } else {
- this.bIsVertical$ = false;
- }
-
- // iterate through steps to find current one(s)
- // immutable, so we want to change the local copy, so need to make a copy
- this.ngZone.run(() => {
- // what comes back now in configObject is the children of the flowContainer
- this.arNavigationSteps$ = JSON.parse(JSON.stringify(oCaseInfo.navigation.steps));
- this.arCurrentStepIndicies$ = new Array();
- this.arCurrentStepIndicies$ = this.findCurrentIndicies(this.arNavigationSteps$, this.arCurrentStepIndicies$, 0);
- });
- } else {
- this.bHasNavigation$ = false;
- }
- }
- }
- }
-
- findCurrentIndicies(arStepperSteps: Array, arIndicies: Array, depth: number): Array {
- let count = 0;
- arStepperSteps.forEach((step) => {
- if (step.visited_status == 'current') {
- arIndicies[depth] = count;
-
- // add in
- step['step_status'] = '';
- } else if (step.visited_status == 'success') {
- count++;
- step.step_status = 'completed';
- } else {
- count++;
- step.step_status = '';
- }
-
- if (step.steps) {
- arIndicies = this.findCurrentIndicies(step.steps, arIndicies, depth + 1);
- }
- });
-
- return arIndicies;
- }
-
- onSaveActionSuccess(data) {
- this.actionsAPI.cancelAssignment(this.itemKey$).then(() => {
- this.psService.sendMessage(false);
- this.PCore$.getPubSubUtils().publish(this.PCore$.getConstants().PUB_SUB_EVENTS.EVENT_CANCEL);
- });
- }
-
- onActionButtonClick(oData: any) {
- this.buttonClick(oData.action, oData.buttonType);
- }
-
- buttonClick(sAction, sButtonType) {
- // right now, done on an individual basis, setting bReInit to true
- // upon the next flow container state change, will cause the flow container
- // to re-initialize
- // this.bReInit =true;
-
- /*
- let baseContext = this.pConn$.getContextName();
- let acName = this.pConn$.getContainerName();
- let itemID = baseContext.concat("/").concat(acName);
- */
-
- let baseContext = this.newPConn$.getContextName();
- let acName = this.newPConn$.getContainerName();
- let itemID = baseContext.concat('/').concat(acName);
-
- if (sButtonType == 'secondary') {
- let stepID = ''; // ???
-
- // need to handle cancel as this.cancel(dispatchInfo)
- //this.actionsAPI[sAction](dispatchInfo);
- switch (sAction) {
- case 'navigateToStep':
- this.erService.sendMessage('publish', '');
- if (this.formValid()) {
- this.bReInit = true;
- this.psService.sendMessage(true);
-
- let navigatePromise = this.navigateToStep('previous', this.itemKey$);
- navigatePromise
- .then(() => {
- this.updateChanges();
- this.psService.sendMessage(false);
- })
- .catch(() => {
- this.psService.sendMessage(false);
- });
- }
- break;
-
- case 'saveAssignment': {
- const caseID = this.pConn$.getCaseInfo().getKey();
- const assignmentID = this.pConn$.getCaseInfo().getAssignmentID();
- const savePromise = this.saveAssignment(this.itemKey$);
-
- savePromise
- .then(() => {
- const caseType = this.pConn$.getCaseInfo().c11nEnv.getValue(PCore.getConstants().CASE_INFO.CASE_TYPE_ID);
- this.PCore$.getPubSubUtils().publish('cancelPressed');
- this.onSaveActionSuccess({ caseType, caseID, assignmentID });
- })
- .catch(() => {
- this.psService.sendMessage(false);
- });
-
- break;
- }
-
- case 'cancelAssignment':
- this.bReInit = true;
- this.erService.sendMessage('dismiss', '');
- const isAssignmentInCreateStage = this.pConn$.getCaseInfo().isAssignmentInCreateStage();
- const isLocalAction =
- this.pConn$.getCaseInfo().isLocalAction() ||
- (PCore.getConstants().CASE_INFO.IS_LOCAL_ACTION &&
- this.pConn$.getValue(PCore.getConstants().CASE_INFO.IS_LOCAL_ACTION));
- // check if create stage (modal)
- if (isAssignmentInCreateStage && this.isInModal$ && !isLocalAction) {
- const cancelPromise = this.cancelCreateStageAssignment(this.itemKey$);
- cancelPromise
- .then(() => {
- this.psService.sendMessage(false);
- // this.PCore$.getPubSubUtils().publish(
- // this.PCore$.getConstants().PUB_SUB_EVENTS.EVENT_CANCEL);
- })
- .catch(() => {
- this.psService.sendMessage(false);
- });
- } else {
- this.psService.sendMessage(true);
-
- // publish before cancel pressed, because
- // cancel assignment happens "after" cancel assignment happens
- this.PCore$.getPubSubUtils().publish('cancelPressed');
-
- const cancelPromise = this.cancelAssignment(this.itemKey$);
- cancelPromise
- .then(() => {
- this.psService.sendMessage(false);
- this.PCore$.getPubSubUtils().publish(this.PCore$.getConstants().PUB_SUB_EVENTS.EVENT_CANCEL);
- })
- .catch(() => {
- this.psService.sendMessage(false);
- });
- }
- break;
-
- default:
- break;
- }
- } else if (sButtonType == 'primary') {
- switch (sAction) {
- case 'finishAssignment':
- this.erService.sendMessage('publish', '');
- if (this.formValid()) {
- this.bReInit = true;
- this.psService.sendMessage(true);
- let finishPromise = this.finishAssignment(this.itemKey$); // JA - was itemID but Nebula/Constellation uses itemKey
- finishPromise
- .then(() => {
- this.psService.sendMessage(false);
- this.updateChanges();
- })
- .catch(() => {
- this.psService.sendMessage(false);
- });
- } else {
- //let snackBarRef = this.snackBar.open("Please fix errors on form.", "Ok");
- this.erService.sendMessage('show', 'Please fix errors on form.');
- }
- break;
- default:
- break;
- }
- }
- }
-
- formValid(): boolean {
- this.touchAll();
- return this.formGroup$.valid;
- }
-
- touchAll(): void {
- Object.values(this.formGroup$.controls).forEach((control: any) => {
- control.markAsTouched();
- });
- }
-
- topViewRefresh(): void {
- Object.values(this.formGroup$.controls).forEach((control: any) => {
- control.markAsTouched();
- });
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/infra/defer-load/defer-load.component.html b/tests/assets/components/createAll/override-sdk/infra/defer-load/defer-load.component.html
deleted file mode 100644
index 0ab77d12..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/defer-load/defer-load.component.html
+++ /dev/null
@@ -1,3 +0,0 @@
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/infra/defer-load/defer-load.component.scss b/tests/assets/components/createAll/override-sdk/infra/defer-load/defer-load.component.scss
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/infra/defer-load/defer-load.component.spec.ts b/tests/assets/components/createAll/override-sdk/infra/defer-load/defer-load.component.spec.ts
deleted file mode 100644
index cd9ca929..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/defer-load/defer-load.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { DeferLoadComponent } from './defer-load.component';
-
-describe('DeferLoadComponent', () => {
- let component: DeferLoadComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ DeferLoadComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(DeferLoadComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/infra/defer-load/defer-load.component.ts b/tests/assets/components/createAll/override-sdk/infra/defer-load/defer-load.component.ts
deleted file mode 100644
index 00c70639..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/defer-load/defer-load.component.ts
+++ /dev/null
@@ -1,177 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { ReferenceComponent } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-
-/**
- * WARNING: It is not expected that this file should be modified. It is part of infrastructure code that works with
- * Redux and creation/update of Redux containers and PConnect. Modifying this code could have undesireable results and
- * is totally at your own risk.
- */
-
-declare const window: any;
-
-@Component({
- selector: 'app-defer-load',
- templateUrl: './defer-load.component.html',
- styleUrls: ['./defer-load.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class DeferLoadComponent implements OnInit {
- @Input() pConn$: any;
- @Input() loadData$: any;
- @Input() name;
-
- PCore$: any;
-
- componentName$: string;
- loadedPConn$: any;
- bShowDefer$: boolean = false;
-
- angularPConnectData: any = {};
- constants: any;
- currentLoadedAssignment = "";
- isContainerPreview: boolean;
- loadViewCaseID: any;
- resourceType: any;
- deferLoadId: any;
- containerName: any;
- CASE: any;
- PAGE: any;
- DATA: any;
- constructor(private angularPConnect: AngularPConnectService) {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
- this.constants = this.PCore$.getConstants();
- }
-
- ngOnInit(): void {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- const { CASE, PAGE, DATA } = this.constants.RESOURCE_TYPES;
- this.CASE = CASE;
- this.PAGE = PAGE;
- this.DATA = DATA;
-
- this.loadActiveTab();
- }
-
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- onStateChange() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const theRequestedAssignment = this.pConn$.getValue(this.PCore$.getConstants().CASE_INFO.ASSIGNMENT_LABEL);
- if (theRequestedAssignment !== this.currentLoadedAssignment) {
- this.currentLoadedAssignment = theRequestedAssignment;
- this.loadActiveTab();
- }
- }
-
- ngOnChanges() {
-
- this.loadViewCaseID = this.pConn$.getValue(this.constants.PZINSKEY) || this.pConn$.getValue(this.constants.CASE_INFO.CASE_INFO_ID);
- let containerItemData;
- const targetName = this.pConn$.getTarget();
- if (targetName) {
- this.containerName = this.PCore$.getContainerUtils().getActiveContainerItemName(targetName);
- containerItemData = this.PCore$.getContainerUtils().getContainerItemData(targetName, this.containerName);
- }
- const { resourceType = this.CASE } = containerItemData || { resourceType: this.loadViewCaseID ? this.CASE : this.PAGE };
- this.resourceType = resourceType;
- this.isContainerPreview = /preview_[0-9]*/g.test(this.pConn$.getContextName());
-
- const theConfigProps = this.pConn$.getConfigProps();
- this.deferLoadId = theConfigProps.deferLoadId;
- this.name = this.name || theConfigProps.name;
-
- this.loadActiveTab();
- }
-
- getViewOptions = () => ({
- viewContext: this.resourceType,
- pageClass: this.loadViewCaseID ? '' : this.pConn$.getDataObject().pyPortal.classID,
- container: this.isContainerPreview ? 'preview' : null,
- containerName: this.isContainerPreview ? 'preview' : null,
- updateData: this.isContainerPreview
- });
-
- onResponse(data) {
- if (this.deferLoadId) {
- this.PCore$.getDeferLoadManager().start(
- this.name,
- this.pConn$.getCaseInfo().getKey(),
- this.pConn$.getPageReference().replace('caseInfo.content', ''),
- this.pConn$.getContextName(),
- this.deferLoadId
- );
- }
-
- if (data && !(data.type && data.type === 'error')) {
- const config = {
- meta: data,
- options: {
- context: this.pConn$.getContextName(),
- pageReference: this.pConn$.getPageReference()
- }
- };
- const configObject = this.PCore$.createPConnect(config);
- configObject.getPConnect().setInheritedProp('displayMode', 'LABELS_LEFT')
- this.loadedPConn$ = ReferenceComponent.normalizePConn(configObject.getPConnect());
- this.componentName$ = this.loadedPConn$.getComponentName();
- if (this.deferLoadId) {
- this.PCore$.getDeferLoadManager().stop(this.deferLoadId, this.pConn$.getContextName());
- }
- }
- // this.cdRef.detectChanges();
- };
-
- loadActiveTab() {
- if (this.resourceType === this.DATA) {
- // Rendering defer loaded tabs in data context
- if (this.containerName) {
- const dataContext = this.PCore$.getStoreValue('.dataContext', 'dataInfo', this.containerName);
- const dataContextParameters = this.PCore$.getStoreValue(
- '.dataContextParameters',
- 'dataInfo',
- this.containerName
- );
-
- this.pConn$
- .getActionsApi()
- .showData(this.name, dataContext, dataContextParameters, {
- skipSemanticUrl: true,
- isDeferLoaded: true
- })
- .then(data => {
- this.onResponse(data);
- });
- } else {
- console.error('Cannot load the defer loaded view without container information');
- }
- } else if (this.resourceType === this.PAGE) {
- // Rendering defer loaded tabs in case/ page context
- this.pConn$
- .getActionsApi()
- .loadView(encodeURI(this.loadViewCaseID), this.name, this.getViewOptions())
- .then(data => {
- this.onResponse(data);
- });
- } else {
- this.pConn$.getActionsApi().refreshCaseView(encodeURI(this.loadViewCaseID), this.name)
- .then(data => {
- this.onResponse(data.root);
- });
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/infra/error-boundary/error-boundary.component.html b/tests/assets/components/createAll/override-sdk/infra/error-boundary/error-boundary.component.html
deleted file mode 100644
index dcce0676..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/error-boundary/error-boundary.component.html
+++ /dev/null
@@ -1 +0,0 @@
-{{message}}
diff --git a/tests/assets/components/createAll/override-sdk/infra/error-boundary/error-boundary.component.scss b/tests/assets/components/createAll/override-sdk/infra/error-boundary/error-boundary.component.scss
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/infra/error-boundary/error-boundary.component.spec.ts b/tests/assets/components/createAll/override-sdk/infra/error-boundary/error-boundary.component.spec.ts
deleted file mode 100644
index 10d54bf9..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/error-boundary/error-boundary.component.spec.ts
+++ /dev/null
@@ -1,23 +0,0 @@
-import { ComponentFixture, TestBed } from '@angular/core/testing';
-
-import { ErrorBoundaryComponent } from './error-boundary.component';
-
-describe('ErrorBoundaryComponent', () => {
- let component: ErrorBoundaryComponent;
- let fixture: ComponentFixture;
-
- beforeEach(async () => {
- await TestBed.configureTestingModule({
- declarations: [ ErrorBoundaryComponent ]
- })
- .compileComponents();
-
- fixture = TestBed.createComponent(ErrorBoundaryComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/infra/error-boundary/error-boundary.component.ts b/tests/assets/components/createAll/override-sdk/infra/error-boundary/error-boundary.component.ts
deleted file mode 100644
index 0abc48e7..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/error-boundary/error-boundary.component.ts
+++ /dev/null
@@ -1,13 +0,0 @@
-import { Component, Input } from '@angular/core';
-import { CommonModule } from '@angular/common';
-
-@Component({
- selector: 'app-error-boundary',
- templateUrl: './error-boundary.component.html',
- styleUrls: ['./error-boundary.component.scss'],
- standalone: true,
- imports: [CommonModule]
-})
-export class ErrorBoundaryComponent {
- @Input('message') message: string;
-}
diff --git a/tests/assets/components/createAll/override-sdk/infra/multi-step/multi-step.component.html b/tests/assets/components/createAll/override-sdk/infra/multi-step/multi-step.component.html
deleted file mode 100644
index 1ff1365e..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/multi-step/multi-step.component.html
+++ /dev/null
@@ -1,98 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
{{ subStep.name }}
-
{{ subStep.name }}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
{{ subStep.name }}
-
{{ subStep.name }}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/infra/multi-step/multi-step.component.scss b/tests/assets/components/createAll/override-sdk/infra/multi-step/multi-step.component.scss
deleted file mode 100644
index fd823ae0..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/multi-step/multi-step.component.scss
+++ /dev/null
@@ -1,261 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-.psdk-case-view-divider {
- border-bottom: 0.0625rem solid $app-neutral-light-color;
-}
-
-.psdk-icon {
- padding: 0rem 0.125rem;
- min-width: unset;
-}
-
-.psdk-icon-current {
- color: $app-primary-color;
-}
-
-.psdk-icon-not-current {
- color: $app-neutral-color;
-}
-
-.psdk-current-svg-icon {
- width: 1rem;
- filter: $app-primary-color-filter;
-}
-
-.psdk-not-current-svg-icon {
- width: 1rem;
- filter: $app-neutral-color-filter;
-}
-
-mat-vertical-stepper {
- background-color: transparent;
-}
-mat-horizontal-stepper {
- background-color: transparent;
-}
-
-.psdk-sub-step-current {
- padding-left: 0.625rem;
- font-weight: bold;
- color: rgba(0, 0, 0, 0.87);
-}
-
-.psdk-sub-step-not-current {
- padding-left: 0.625rem;
- color: rgba(0, 0, 0, 0.54);
-}
-
-.psdk-flow-container-top {
- background-color: $app-form-color;
- padding: 0rem 0.625rem;
- border-radius: 0.3125rem;
-}
-.psdk-flow-container {
- padding-left: 2.1875rem;
-}
-
-.psdk-sub-step-list {
- list-style: none;
- padding-bottom: 0.625rem;
-}
-
-.psdk-vertical-stepper {
- background-color: transparent;
- display: block;
- text-align: left;
-}
-
-.psdk-vertical-step {
- display: block;
-}
-
-.psdk-vertical-step-header {
- overflow: hidden;
- outline: none;
- cursor: pointer;
- position: relative;
- box-sizing: content-box;
- display: flex;
- align-items: center;
- height: 24px;
- padding: 24px 24px;
-}
-
-.psdk-vertical-step-icon {
- margin-right: 12px;
- background-color: $app-neutral-color;
- color: #fff;
- border-radius: 50%;
- height: 24px;
- width: 24px;
- flex-shrink: 0;
- position: relative;
-}
-
-.psdk-vertical-step-icon-content {
- position: absolute;
- top: 50%;
- left: 50%;
- transform: translate(-50%, -50%);
- color: #fff;
-}
-
-.psdk-vertical-step-icon-selected {
- margin-right: 12px;
- background-color: $app-primary-color;
- color: #fff;
- border-radius: 50%;
- height: 24px;
- width: 24px;
- flex-shrink: 0;
- position: relative;
-}
-
-.psdk-vertical-step-label {
- color: rgba(0, 0, 0, 0.54);
- display: inline-block;
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
- min-width: 50px;
- vertical-align: middle;
- font-size: 14px;
- font-weight: 500;
-}
-
-.psdk-vertical-step-label-selected {
- color: rgba(0, 0, 0, 0.87);
- display: inline-block;
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
- min-width: 50px;
- vertical-align: middle;
- font-size: 14px;
- font-weight: 500;
-}
-
-.psdk-vertical-step-body {
- margin-left: 36px;
- border: 0;
- position: relative;
- display: block;
- text-align: left;
-}
-.psdk-vertical-step-line {
- display: block;
-}
-
-.psdk-vertical-step-line::before {
- content: '';
- position: absolute;
- left: 0;
- border-left-width: 1px;
- border-left-style: solid;
- top: -16px;
- bottom: -16px;
- border-left-color: rgba(0, 0, 0, 0.12);
-}
-
-.psdk-horizontal-stepper {
- background-color: transparent;
- display: block;
-}
-
-.psdk-horizontal-stepper-header-container {
- white-space: nowrap;
- display: flex;
- align-items: center;
- text-align: left;
-}
-
-.psdk-horizontal-step-header {
- overflow: hidden;
- outline: none;
- cursor: pointer;
- position: relative;
- box-sizing: content-box;
- display: flex;
- height: 72px;
- overflow: hidden;
- align-items: center;
- padding: 0 24px;
-}
-
-.psdk-horizontal-step-icon {
- background-color: $app-neutral-color;
- color: #fff;
- border-radius: 50%;
- height: 24px;
- width: 24px;
- flex-shrink: 0;
- position: relative;
- display: block;
- margin-right: 8px;
- flex: none;
-}
-
-.psdk-horizontal-step-icon-content {
- display: block;
- position: absolute;
- top: 50%;
- left: 50%;
- transform: translate(-50%, -50%);
-}
-
-.psdk-horizontal-step-icon-selected {
- background-color: $app-primary-color;
- color: #fff;
- border-radius: 50%;
- height: 24px;
- width: 24px;
- flex-shrink: 0;
- position: relative;
- display: block;
- margin-right: 8px;
- flex: none;
-}
-
-.psdk-horizontal-step-label {
- color: rgba(0, 0, 0, 0.54);
- display: inline-block;
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
- min-width: 50px;
- vertical-align: middle;
- font-size: 14px;
- font-weight: 500;
- text-overflow: ellipsis;
- overflow: hidden;
-}
-
-.psdk-horizontal-step-label-selected {
- color: rgba(0, 0, 0, 0.87);
- display: inline-block;
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
- min-width: 50px;
- vertical-align: middle;
- font-size: 14px;
- font-weight: 500;
- text-overflow: ellipsis;
- overflow: hidden;
-}
-
-.psdk-horizontal-step-text-label {
- text-overflow: ellipsis;
- overflow: hidden;
- display: block;
-}
-
-.psdk-horizontal-step-line {
- border-top-color: rgba(0, 0, 0, 0.12);
- border-top-width: 1px;
- border-top-style: solid;
- flex: auto;
- height: 0;
- margin: 0 -16px;
- min-width: 32px;
-}
diff --git a/tests/assets/components/createAll/override-sdk/infra/multi-step/multi-step.component.spec.ts b/tests/assets/components/createAll/override-sdk/infra/multi-step/multi-step.component.spec.ts
deleted file mode 100644
index 4e354473..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/multi-step/multi-step.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { MultiStepComponent } from './multi-step.component';
-
-describe('MultiStepComponent', () => {
- let component: MultiStepComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ MultiStepComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(MultiStepComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/infra/multi-step/multi-step.component.ts b/tests/assets/components/createAll/override-sdk/infra/multi-step/multi-step.component.ts
deleted file mode 100644
index 7c23127c..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/multi-step/multi-step.component.ts
+++ /dev/null
@@ -1,97 +0,0 @@
-import { Component, OnInit, Input, Output, EventEmitter, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-multi-step',
- templateUrl: './multi-step.component.html',
- styleUrls: ['./multi-step.component.scss'],
- providers: [Utils],
- standalone: true,
- imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class MultiStepComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
- @Input() arMainButtons$: Array;
- @Input() arSecondaryButtons$: Array;
- @Input() arChildren$: Array;
- @Input() bIsVertical$: boolean;
- @Input() arCurrentStepIndicies$: Array;
- @Input() arNavigationSteps$: Array;
- @Output() actionButtonClick: EventEmitter = new EventEmitter();
-
- PCore$: any;
-
- svgCurrent$: string;
- svgNotCurrent$: string;
- bShow$: boolean = true;
-
- constructor(private utils: Utils) {}
-
- ngOnInit(): void {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
-
- // svg icons
- this.svgCurrent$ = this.utils.getImageSrc('circle-solid', this.utils.getSDKStaticContentUrl());
- this.svgNotCurrent$ = this.utils.getImageSrc('circle-solid', this.utils.getSDKStaticContentUrl());
- }
-
- onActionButtonClick(oData: any) {
- this.actionButtonClick.emit(oData);
- }
-
- _getVIconClass(status): String {
- if (status == 'current') {
- return 'psdk-vertical-step-icon-selected';
- }
-
- return 'psdk-vertical-step-icon';
- }
-
- _getVLabelClass(status): string {
- if (status == 'current') {
- return 'psdk-vertical-step-label-selected';
- }
-
- return 'psdk-vertical-step-label';
- }
-
- _getVBodyClass(index: number): string {
- if (index < this.arNavigationSteps$.length - 1) {
- return 'psdk-vertical-step-body psdk-vertical-step-line';
- }
-
- return 'psdk-vertical-step-body';
- }
-
- _getHIconClass(status): string {
- if (status == 'current') {
- return 'psdk-horizontal-step-icon-selected';
- }
-
- return 'psdk-horizontal-step-icon';
- }
-
- _getHLabelClass(status): string {
- if (status == 'current') {
- return 'psdk-horizontal-step-label-selected';
- }
-
- return 'psdk-horizontal-step-label';
- }
-
- _showHLine(index: number): boolean {
- if (index < this.arNavigationSteps$.length - 1) {
- return true;
- }
-
- return false;
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/infra/navbar/navbar.component.html b/tests/assets/components/createAll/override-sdk/infra/navbar/navbar.component.html
deleted file mode 100644
index 9ab4286b..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/navbar/navbar.component.html
+++ /dev/null
@@ -1,55 +0,0 @@
-
-
-
-
-
-
-
-
-
Create
-
-
-
-
- {{ caseType.pyLabel }}
-
-
-
-
-
-
-
-
-
-
{{ page.pyLabel }}
-
-
-
-
-
-
-
-
-
-
{{ portalOperatorInitials$ }}
-
{{ portalOperator$ }}
-
-
-
- Profile
- Logoff
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/infra/navbar/navbar.component.scss b/tests/assets/components/createAll/override-sdk/infra/navbar/navbar.component.scss
deleted file mode 100644
index 9b1cf355..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/navbar/navbar.component.scss
+++ /dev/null
@@ -1,154 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-// Things related to movement
-$transition-slow: 0.5s !default;
-$transition-medium: 0.3s !default;
-$transition-fast: 0.1s !default;
-$natural-ease: cubic-bezier(0.4, 0.6, 0.1, 1) !default;
-
-.psdk-nav-divider {
- border-bottom: 0.0625rem solid invert($app-nav-bg, 15%);
- width: 100%;
- align-items: center;
-}
-
-.psdk-nav-header {
- display: flex;
- padding-top: 0.625rem;
-}
-
-.psdk-nav-logo {
- width: 3.75rem;
- padding: 0.625rem;
- margin-right: 1.25rem;
-}
-
-// background color white
-.psdk-nav-svg-icon {
- filter: $app-white-color-filter;
- width: 1.6rem;
- padding-right: 0.625rem;
-}
-
-.psdk-nav-portal-name {
- font-size: 0.875rem;
-}
-
-.psdk-nav-portal-app {
- font-size: 1.25rem;
-}
-
-.psdk-appshell-nav {
- z-index: 3;
- position: fixed;
- display: flex;
- flex-direction: column;
- justify-content: flex-start;
- background: $app-nav-bg;
- width: $app-nav-width;
- height: 100%;
- color: invert($app-nav-bg, 100%);
- overflow-y: auto;
- overflow-x: hidden;
- white-space: nowrap;
- transition: width $transition-medium $natural-ease;
- will-change: width;
-}
-
-.psdk-appshell-nav:hover {
- width: $app-nav-width-expanded;
-}
-
-.psdk-appshell-topnav {
- display: flex;
- flex-direction: column;
- justify-content: flex-start;
- background: $app-nav-bg;
- width: $app-nav-width;
- height: 15%;
- color: invert($app-nav-bg, 100%);
- overflow: hidden;
- white-space: nowrap;
- transition: width $transition-medium $natural-ease;
- will-change: width;
-}
-
-.psdk-appshell-middlenav {
- display: flex;
- flex-direction: column;
- justify-content: space-between;
- background: $app-nav-bg;
- width: $app-nav-width;
- height: 50%;
- color: invert($app-nav-bg, 100%);
- overflow: hidden;
- white-space: nowrap;
- transition: width $transition-medium $natural-ease;
- will-change: width;
-}
-
-.psdk-nav-ul-middle {
- display: block;
- list-style-type: none;
- margin: 0rem;
- padding-inline-start: 30px;
-}
-
-.psdk-nav-li-middle {
- box-sizing: border-box;
- text-align: left;
-}
-
-.psdk-icon {
- padding: 0rem 0.125rem;
- min-width: unset;
-}
-
-.psdk-nav-button-span {
- padding: 0 1rem;
- color: invert($app-nav-bg, 100%);
-}
-
-.psdk-nav-oper-avatar {
- margin: 0rem;
- padding: 0rem;
- min-width: 2.5rem;
- min-height: 2.5rem;
- max-width: 2.5rem;
- max-height: 2.5rem;
- border-radius: 50%;
- justify-content: center;
- align-items: center;
- text-align: center;
- display: inline-flex;
- background: $app-neutral-color;
- color: white;
- font-weight: normal;
- font-size: 1rem;
-}
-
-mat-list {
- padding: 0;
-}
-
-.psdk-profile-list-item {
- padding-left: 24px;
-}
-
-mat-list-item {
- padding: 20px 30px;
- padding-right: 0;
- cursor: pointer !important;
- height: auto !important;
-
- &:hover {
- background-color: rgba(0, 0, 0, 0.5);
- }
-
- .flex-box {
- display: flex;
- align-items: center;
- width: 100%;
- text-align: left;
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/infra/navbar/navbar.component.spec.ts b/tests/assets/components/createAll/override-sdk/infra/navbar/navbar.component.spec.ts
deleted file mode 100644
index cb0cff46..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/navbar/navbar.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { NavbarComponent } from './navbar.component';
-
-describe('NavbarComponent', () => {
- let component: NavbarComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ NavbarComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(NavbarComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/infra/navbar/navbar.component.ts b/tests/assets/components/createAll/override-sdk/infra/navbar/navbar.component.ts
deleted file mode 100644
index df2c5925..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/navbar/navbar.component.ts
+++ /dev/null
@@ -1,176 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, NgZone } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { MatMenuModule } from '@angular/material/menu';
-import { MatListModule } from '@angular/material/list';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { ProgressSpinnerService } from '@pega/angular-sdk-library';
-import { logout } from '@pega/auth/lib/sdk-auth-manager';
-import { Utils } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-navbar',
- templateUrl: './navbar.component.html',
- styleUrls: ['./navbar.component.scss'],
- providers: [Utils],
- standalone: true,
- imports: [CommonModule, MatListModule, MatMenuModule]
-})
-export class NavbarComponent implements OnInit {
- @Input() pConn$: any;
- @Input() appName$: string;
- @Input() pages$: Array;
- @Input() caseTypes$: Array;
-
- // For interaction with AngularPConnect
- angularPConnectData: any = {};
- PCore$: any;
-
- navPages$: Array;
- navExpandCollapse$: string;
- bShowCaseTypes$: boolean = false;
-
- portalApp$: string = '';
- portalLogoImage$: string;
- showAppName$: boolean = false;
-
- portalOperator$: string;
- portalOperatorInitials$: string;
-
- actionsAPI: any;
- createWork: any;
- showPage: any;
- logout: any;
-
- configProps: any;
- navIcon$: string;
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private chRef: ChangeDetectorRef,
- private psService: ProgressSpinnerService,
- private ngZone: NgZone,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
-
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- this.navIcon$ = this.utils.getSDKStaticContentUrl().concat('assets/pzpega-logo-mark.svg');
-
- // this is a dummy "get", because right now images are in http and the main screen is https
- // so the images don't load automatically. This call, makes an initial hit that allows the
- // rest of the images to show up
- this.loadImage(this.navIcon$);
-
- this.initComponent();
- }
-
- // ngOnDestroy
- // unsubscribe from Store
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- loadImage(src: string) {
- return new Promise((resolve, reject) => {
- resolve(src);
- });
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- // Should always check the bridge to see if the component should update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // NOTE: can call angularPConnect.getState with optional args for detailed logging: bLogMsg and component object
- this.angularPConnect.getState();
-
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf(): void {
- this.initComponent();
- }
-
- initComponent() {
- this.ngZone.run(() => {
- this.navIcon$ = this.utils.getSDKStaticContentUrl().concat('assets/pzpega-logo-mark.svg');
- this.navExpandCollapse$ = this.utils.getImageSrc('plus', this.utils.getSDKStaticContentUrl());
-
- // Then, continue on with other initialization
-
- // making a copy, so can add info
- this.navPages$ = JSON.parse(JSON.stringify(this.pages$));
-
- for (let page in this.navPages$) {
- this.navPages$[page]['iconName'] = this.utils.getImageSrc(
- this.navPages$[page]['pxPageViewIcon'],
- this.utils.getSDKStaticContentUrl()
- );
- }
-
- this.actionsAPI = this.pConn$.getActionsApi();
- this.createWork = this.actionsAPI.createWork.bind(this.actionsAPI);
- this.showPage = this.actionsAPI.showPage.bind(this.actionsAPI);
- this.configProps = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.logout = this.actionsAPI.logout.bind(this.actionsAPI);
-
- let oData = this.pConn$.getDataObject();
-
- this.portalLogoImage$ = this.utils.getSDKStaticContentUrl().concat('assets/pzpega-logo-mark.svg');
- this.portalOperator$ = this.PCore$.getEnvironmentInfo().getOperatorName();
- this.portalOperatorInitials$ = this.utils.getInitials(this.portalOperator$);
- this.showAppName$ = this.configProps['showAppName'];
-
- this.portalApp$ = this.PCore$.getEnvironmentInfo().getApplicationLabel();
- });
- }
-
- navPanelButtonClick(oPageData: any) {
- const { pyClassName, pyRuleName } = oPageData;
-
- this.showPage(pyRuleName, pyClassName);
- }
-
- navPanelCreateButtonClick() {
- if (this.navExpandCollapse$.indexOf('plus') > 0) {
- this.navExpandCollapse$ = this.utils.getImageSrc('times', this.utils.getSDKStaticContentUrl());
- this.bShowCaseTypes$ = true;
- } else {
- this.navExpandCollapse$ = this.utils.getImageSrc('plus', this.utils.getSDKStaticContentUrl());
- this.bShowCaseTypes$ = false;
- }
-
- this.chRef.detectChanges();
- }
-
- navPanelCreateCaseType(sCaseType: string, sFlowType: string) {
- this.psService.sendMessage(true);
- this.navPanelCreateButtonClick();
-
- const actionInfo = {
- containerName: 'primary',
- flowType: sFlowType ? sFlowType : 'pyStartCase'
- };
- this.createWork(sCaseType, actionInfo);
- }
-
- navPanelLogoutClick() {
- logout().then(() => {
- // Reload the page to kick off the login
- window.location.reload();
- });
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/infra/region/region.component.html b/tests/assets/components/createAll/override-sdk/infra/region/region.component.html
deleted file mode 100644
index 022e707f..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/region/region.component.html
+++ /dev/null
@@ -1,11 +0,0 @@
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/infra/region/region.component.scss b/tests/assets/components/createAll/override-sdk/infra/region/region.component.scss
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/infra/region/region.component.spec.ts b/tests/assets/components/createAll/override-sdk/infra/region/region.component.spec.ts
deleted file mode 100644
index aab871dc..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/region/region.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { RegionComponent } from './region.component';
-
-describe('RegionComponent', () => {
- let component: RegionComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ RegionComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(RegionComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/infra/region/region.component.ts b/tests/assets/components/createAll/override-sdk/infra/region/region.component.ts
deleted file mode 100644
index ea97cca0..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/region/region.component.ts
+++ /dev/null
@@ -1,43 +0,0 @@
-import { Component, OnInit, Input, forwardRef, OnChanges, SimpleChanges } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { ReferenceComponent } from '@pega/angular-sdk-library';
-// import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-region',
- templateUrl: './region.component.html',
- styleUrls: ['./region.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class RegionComponent implements OnInit, OnChanges {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- configProps$: Object;
- arChildren$: Array;
-
- constructor() {}
-
- ngOnInit() {
- // console.log(`ngOnInit (no registerAndSubscribe!): Region`);
- this.updateSelf();
- }
-
- ngOnChanges(changes: SimpleChanges): void {
- const { pConn$ } = changes;
-
- if (pConn$.previousValue && pConn$.previousValue !== pConn$.currentValue) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- // The children may contain 'reference' components, so normalize the children...
- this.arChildren$ = ReferenceComponent.normalizePConnArray(this.pConn$.getChildren());
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/infra/stages/stages.component.html b/tests/assets/components/createAll/override-sdk/infra/stages/stages.component.html
deleted file mode 100644
index 8f56fd09..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/stages/stages.component.html
+++ /dev/null
@@ -1,11 +0,0 @@
-
-
-
-
{{ stage.name }}
-
-
{{ stage.name }}
-
{{ stage.name }}
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/infra/stages/stages.component.scss b/tests/assets/components/createAll/override-sdk/infra/stages/stages.component.scss
deleted file mode 100644
index d67fae12..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/stages/stages.component.scss
+++ /dev/null
@@ -1,109 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-.psdk-stages {
- padding: 0.625rem 0rem;
-}
-
-.psdk-stages-span span {
- padding: 0.3125rem;
- font-weight: bold;
- font-size: 1.5rem;
-}
-
-.psdk-stages-div {
- display: inline-flex;
- padding: 0.3125rem;
- font-weight: bold;
- font-size: 1.3rem;
- color: $app-neutral-color;
-}
-
-.psdk-stages-past {
- color: $app-primary-color;
- padding-right: 0.3125rem;
-}
-
-.psdk-stages-present {
- color: $app-secondary-color;
- padding-right: 0.3125rem;
-}
-
-.psdk-stages-future {
- color: $app-neutral-color;
- padding-right: 0.3125rem;
-}
-
-.psdk-stages-full {
- display: block;
-}
-
-.psdk-stages-divider {
- border-bottom: 0.0625rem solid $app-neutral-light-color;
-}
-
-.psdk-stages-full {
- display: block;
-}
-
-.psdk-stages-divider {
- border-bottom: 0.0625rem solid $app-neutral-light-color;
-}
-
-.psdk-stages-icon {
- width: 1.4rem;
- display: inline-block;
- vertical-align: top;
-}
-
-.psdk-stages-bar {
- margin: 1rem 0rem;
- background-color: rgb(255, 255, 255);
- border-radius: 0.5rem;
- border: 0.0625rem solid $app-neutral-light-color;
- overflow: hidden;
- height: 2rem;
- display: flex;
-}
-
-.psdk-stages-chevron {
- position: relative;
- padding: calc(1rem);
- display: flex;
- justify-content: center;
- align-items: center;
- max-width: 100%;
- min-width: 0px;
- flex-grow: 1;
- flex-shrink: 1;
-}
-
-.psdk-stages-chevron:not(:last-child)::after {
- content: '';
- position: absolute;
- display: block;
- z-index: 2;
- width: calc(1.75rem);
- right: calc(-0.4375rem);
- background: inherit;
- border-style: solid;
- border-color: rgb(207, 207, 207);
- border-width: 0.0625rem 0.0625rem 0px 0px;
- border-radius: 0px calc(0.3125rem) 0px 0px;
- transform: rotateZ(45deg) skew(15deg, 15deg);
- height: 2rem;
-}
-
-.psdk-stages-inner-past {
- color: black;
- font-size: 1rem;
-}
-
-.psdk-stages-inner-present {
- color: $app-primary-color;
- font-weight: bold;
- font-size: 1rem;
-}
-.psdk-stages-inner-future {
- color: $app-neutral-color;
- font-size: 1rem;
-}
diff --git a/tests/assets/components/createAll/override-sdk/infra/stages/stages.component.spec.ts b/tests/assets/components/createAll/override-sdk/infra/stages/stages.component.spec.ts
deleted file mode 100644
index 3805f1fc..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/stages/stages.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { StagesComponent } from './stages.component';
-
-describe('StagesComponent', () => {
- let component: StagesComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ StagesComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(StagesComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/infra/stages/stages.component.ts b/tests/assets/components/createAll/override-sdk/infra/stages/stages.component.ts
deleted file mode 100644
index 64087f02..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/stages/stages.component.ts
+++ /dev/null
@@ -1,79 +0,0 @@
-import { Component, OnInit, Input } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-stages',
- templateUrl: './stages.component.html',
- styleUrls: ['./stages.component.scss'],
- standalone: true,
- imports: [CommonModule]
-})
-export class StagesComponent implements OnInit {
- @Input() pConn$: any;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- PCore$: any;
- configProps$: Object;
-
- arStageResults$: Array;
- lastStage$: any;
- checkSvgIcon$: string;
-
- constructor(private angularPConnect: AngularPConnectService, private utils: Utils) {}
-
- ngOnInit(): void {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
-
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- const imagePath = this.utils.getIconPath(this.utils.getSDKStaticContentUrl());
- this.checkSvgIcon$ = this.utils.getImageSrc('check', this.utils.getSDKStaticContentUrl());
- }
-
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- let timer = interval(50).subscribe(() => {
- timer.unsubscribe();
-
- let arStages = this.angularPConnect.getComponentProp(this, 'stages');
-
- //this.stageResults$ = this.configProps$["stages"];
- if (arStages != null) {
- this.arStageResults$ = arStages;
- this.lastStage$ = this.arStageResults$[this.arStageResults$.length - 1];
- }
- });
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/infra/view/view.component.html b/tests/assets/components/createAll/override-sdk/infra/view/view.component.html
deleted file mode 100644
index 0240f243..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/view/view.component.html
+++ /dev/null
@@ -1,38 +0,0 @@
-
-
- {{ label$ }}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/infra/view/view.component.scss b/tests/assets/components/createAll/override-sdk/infra/view/view.component.scss
deleted file mode 100644
index bcc13757..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/view/view.component.scss
+++ /dev/null
@@ -1,16 +0,0 @@
-h3 {
- margin-left: 0.8rem;
-}
-
-.ng-view-top {
- padding: 0;
-}
-
-.template-title-container{
- display: flex;
- justify-content: space-between;
- align-items: center;
- font-size: calc(0.9375rem);
- font-weight: 600;
- margin-bottom: 1rem;
-}
diff --git a/tests/assets/components/createAll/override-sdk/infra/view/view.component.spec.ts b/tests/assets/components/createAll/override-sdk/infra/view/view.component.spec.ts
deleted file mode 100644
index 28de8fba..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/view/view.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { ViewComponent } from './view.component';
-
-describe('ViewComponent', () => {
- let component: ViewComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ ViewComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(ViewComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/infra/view/view.component.ts b/tests/assets/components/createAll/override-sdk/infra/view/view.component.ts
deleted file mode 100644
index 82eb3a4e..00000000
--- a/tests/assets/components/createAll/override-sdk/infra/view/view.component.ts
+++ /dev/null
@@ -1,144 +0,0 @@
-import { Component, OnInit, Input, forwardRef, SimpleChanges } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { getAllFields } from '@pega/angular-sdk-library';
-import { ReferenceComponent } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-/**
- * WARNING: It is not expected that this file should be modified. It is part of infrastructure code that works with
- * Redux and creation/update of Redux containers and PConnect. Modifying this code could have undesireable results and
- * is totally at your own risk.
- */
-
-@Component({
- selector: 'app-view',
- templateUrl: './view.component.html',
- styleUrls: ['./view.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class ViewComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
- @Input() displayOnlyFA$: boolean;
- //@Input() updateToken$: number;
-
- angularPConnectData: any = {};
-
- configProps$: Object;
- inheritedProps$: Object;
- arChildren$: Array;
- templateName$: string;
- title$: string = '';
- label$: string = '';
- showLabel$: boolean = true;
-
- constructor(private angularPConnect: AngularPConnectService, private utils: Utils) {}
-
- ngOnInit() {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- this.checkAndUpdate();
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- ngOnChanges(changes: SimpleChanges) {
- const { pConn$ } = changes;
-
- if (pConn$.previousValue && pConn$.previousValue !== pConn$.currentValue) {
- this.checkAndUpdate();
- }
- }
-
- updateSelf() {
- if (this.angularPConnect.getComponentID(this) === undefined) {
- return;
- }
-
- //debugger;
-
- // normalize this.pConn$ in case it contains a 'reference'
- this.pConn$ = ReferenceComponent.normalizePConn(this.pConn$);
-
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.inheritedProps$ = this.pConn$.getInheritedProps();
-
- // NOTE: this.configProps$['visibility'] is used in view.component.ts such that
- // the View will only be rendered when this.configProps$['visibility'] is false.
- // It WILL render if true or undefined.
-
- this.templateName$ = 'template' in this.configProps$ ? (this.configProps$['template'] as string) : '';
- this.title$ = 'title' in this.configProps$ ? (this.configProps$['title'] as string) : '';
- this.label$ = 'label' in this.configProps$ ? (this.configProps$['label'] as string) : '';
- this.showLabel$ = 'showLabel' in this.configProps$ ? (this.configProps$['showLabel'] as boolean) : this.showLabel$;
- // label & showLabel within inheritedProps takes precedence over configProps
- this.label$ = 'label' in this.inheritedProps$ ? (this.inheritedProps$['label'] as string) : this.label$;
- this.showLabel$ = 'showLabel' in this.inheritedProps$ ? (this.inheritedProps$['showLabel'] as boolean) : this.showLabel$;
- // children may have a 'reference' so normalize the children array
- this.arChildren$ = ReferenceComponent.normalizePConnArray(this.pConn$.getChildren());
- // was: this.arChildren$ = this.pConn$.getChildren();
-
- // debug
- // let kidList: string = "";
- // for (let i in this.arChildren$) {
- // kidList = kidList.concat(this.arChildren$[i].getPConnect().getComponentName()).concat(",");
- // }
- //console.log("-->view update: " + this.angularPConnect.getComponentID(this) + ", template: " + this.templateName$ + ", kids: " + kidList);
- }
-
- // JA - adapting additionalProps from Nebula/Constellation version which uses static methods
- // on the component classes stored in PComponents (that Angular doesn't have)...
- additionalProps(state: any, getPConnect: any) {
- let propObj = {};
-
- // We already have the template name in this.templateName$
- if (this.templateName$ !== '') {
- let allFields = {};
-
- // These uses are adapted from Nebula/Constellation CaseSummary.additionalProps
- switch (this.templateName$) {
- case 'CaseSummary':
- allFields = getAllFields(getPConnect);
- // eslint-disable-next-line no-case-declarations
- const unresFields = {
- primaryFields: allFields[0],
- secondaryFields: allFields[1]
- };
- propObj = getPConnect.resolveConfigProps(unresFields);
- break;
-
- case 'Details':
- allFields = getAllFields(getPConnect);
- propObj = { fields: allFields[0] };
- break;
- }
- }
-
- return propObj;
- }
-
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/_template.md b/tests/assets/components/createAll/override-sdk/template/_template.md
deleted file mode 100644
index c77fa60b..00000000
--- a/tests/assets/components/createAll/override-sdk/template/_template.md
+++ /dev/null
@@ -1,6 +0,0 @@
-# The **override-sdk/template** directory
-
-The **src/components/override-sdk/template** directory contains the code for **template** components for which you want to override the default implementation for use with the **Angular SDK**.
-
-When you run the **npm run create** command to override the default implementation of a **template** component, the generated code that you can use as a
-starting point for your component development will be placed in type-specific and component-specific folders in **src/components/override-sdk/template**.
diff --git a/tests/assets/components/createAll/override-sdk/template/app-shell/app-shell.component.html b/tests/assets/components/createAll/override-sdk/template/app-shell/app-shell.component.html
deleted file mode 100644
index b4412787..00000000
--- a/tests/assets/components/createAll/override-sdk/template/app-shell/app-shell.component.html
+++ /dev/null
@@ -1,10 +0,0 @@
-
diff --git a/tests/assets/components/createAll/override-sdk/template/app-shell/app-shell.component.scss b/tests/assets/components/createAll/override-sdk/template/app-shell/app-shell.component.scss
deleted file mode 100644
index 05572782..00000000
--- a/tests/assets/components/createAll/override-sdk/template/app-shell/app-shell.component.scss
+++ /dev/null
@@ -1,42 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-.appshell-top {
- display: flex;
- background-color: $app-background-color;
-}
-
-.appshell-main {
- position: relative;
- margin-left: $app-nav-width;
- min-height: 100vh;
- display: block;
- width: 100%;
-}
-
-.psdk-icon {
- padding: 0rem 0.125rem;
- min-width: unset;
-}
-
-.progress-box {
- display: flex;
- flex-direction: column;
- justify-content: center;
- align-items: center;
- height: 100%;
- width: 100%;
- background-color: whitesmoke;
- position: fixed;
- z-index: 999;
- top: 0rem;
- left: 0rem;
- opacity: 0.5;
-}
-
-.progress-spinner {
- text-align: center;
-}
-
-::ng-deep snack-bar-container.snackbar-newline {
- white-space: pre-line;
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/app-shell/app-shell.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/app-shell/app-shell.component.spec.ts
deleted file mode 100644
index f9fbec3d..00000000
--- a/tests/assets/components/createAll/override-sdk/template/app-shell/app-shell.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { AppShellComponent } from './app-shell.component';
-
-describe('AppShellComponent', () => {
- let component: AppShellComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ AppShellComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(AppShellComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/app-shell/app-shell.component.ts b/tests/assets/components/createAll/override-sdk/template/app-shell/app-shell.component.ts
deleted file mode 100644
index e29f423b..00000000
--- a/tests/assets/components/createAll/override-sdk/template/app-shell/app-shell.component.ts
+++ /dev/null
@@ -1,163 +0,0 @@
-import { Component, OnInit, Input, NgZone, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { MatSnackBarModule, MatSnackBar } from '@angular/material/snack-bar';
-import { Subscription } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { ErrorMessagesService } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-app-shell',
- templateUrl: './app-shell.component.html',
- styleUrls: ['./app-shell.component.scss'],
- standalone: true,
- imports: [CommonModule, MatSnackBarModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class AppShellComponent implements OnInit {
- @Input() pConn$: any;
-
- // For interaction with AngularPConnect
- angularPConnectData: any = {};
- configProps$: Object;
-
- pages$: Array;
- caseTypes$: Array;
- arChildren$: Array;
- bShowAppShell$: boolean = false;
- appName$: string = 'PEGA';
- errorMessage: any;
- errorMessagesSubscription: Subscription;
- sErrorMessages: string = '';
- snackBarRef: any;
- bOkDisplayError: boolean = false;
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private erService: ErrorMessagesService,
- private snackBar: MatSnackBar,
- private ngZone: NgZone
- ) {}
-
- ngOnInit() {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- // Then, continue on with other initialization
-
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- // making a copy, so can add info
- this.pages$ = this.configProps$['pages'];
-
- if (this.pages$) {
- this.bShowAppShell$ = true;
- }
- this.caseTypes$ = this.configProps$['caseTypes'];
-
- this.arChildren$ = this.pConn$.getChildren();
-
- // handle showing and hiding the progress spinner
- this.errorMessagesSubscription = this.erService.getMessage().subscribe((message) => {
- this.errorMessage = message;
-
- this.showDismissErrorMessages(this.errorMessage);
- });
-
- // cannot call checkAndUpdate becasue first time through, will call updateSelf and that is incorrect (causes issues).
- // however, need angularPConnect to be initialized with currentProps for future updates, so calling shouldComponentUpdate directly
- // without checking to update here in init, will initialize and this is correct
- this.angularPConnect.shouldComponentUpdate(this);
- }
-
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- this.ngZone.run(() => {
- // making a copy, so can add info
- this.pages$ = this.configProps$['pages'];
-
- if (this.pages$) {
- this.bShowAppShell$ = true;
- }
-
- this.caseTypes$ = this.configProps$['caseTypes'];
- this.arChildren$ = this.pConn$.getChildren();
- });
- }
-
- // fpr show/hiding error messages in the SnackBar component
- showDismissErrorMessages(errorMessages: any) {
- switch (errorMessages.action) {
- case 'update':
- // won't show unless publish is turned on
- // eslint-disable-next-line @typescript-eslint/prefer-includes
- if (this.sErrorMessages.indexOf(errorMessages.actionMessage) < 0) {
- this.sErrorMessages = this.sErrorMessages.concat(errorMessages.actionMessage).concat('\n');
-
- if (this.bOkDisplayError) {
- let config = { panelClass: ['snackbar-newline'] };
- this.snackBarRef = this.snackBar.open(this.sErrorMessages, 'Ok', config);
- }
- }
- break;
- case 'show':
- // add error message if not in the list
- // won't show unless publish is turned on
- // eslint-disable-next-line @typescript-eslint/prefer-includes
- if (this.sErrorMessages.indexOf(errorMessages.actionMessage) < 0) {
- this.sErrorMessages = this.sErrorMessages.concat(errorMessages.actionMessage).concat('\n');
- }
-
- if (this.bOkDisplayError) {
- let config = { panelClass: ['snackbar-newline'] };
- this.snackBarRef = this.snackBar.open(this.sErrorMessages, 'Ok', config);
- }
- // this.snackBarRef.afterDismissed().subscribe( info => {
- // this.sErrorMessages = "";
- // }
- // )
- break;
- case 'dismiss':
- // closes snack bar
- // turns publish off
- // clears out errors
- // should be called to dimiss and at "cancel"
- if (this.snackBarRef != null) {
- this.snackBarRef.dismiss();
- this.sErrorMessages = '';
- this.bOkDisplayError = false;
- }
- break;
- case 'publish':
- // allows errors to be shown, clears out existing ones
- // should be turned on at "submit" (finishAssignment, nextAssignment, etc.)
-
- this.bOkDisplayError = true;
- this.sErrorMessages = '';
-
- break;
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/case-summary/case-summary.component.html b/tests/assets/components/createAll/override-sdk/template/case-summary/case-summary.component.html
deleted file mode 100644
index 74d8b307..00000000
--- a/tests/assets/components/createAll/override-sdk/template/case-summary/case-summary.component.html
+++ /dev/null
@@ -1 +0,0 @@
-
diff --git a/tests/assets/components/createAll/override-sdk/template/case-summary/case-summary.component.scss b/tests/assets/components/createAll/override-sdk/template/case-summary/case-summary.component.scss
deleted file mode 100644
index 95949b12..00000000
--- a/tests/assets/components/createAll/override-sdk/template/case-summary/case-summary.component.scss
+++ /dev/null
@@ -1,44 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-.psdk-case-summary-info-box {
- display: flex;
- flex-direction: row;
- justify-content: space-evenly;
-}
-
-.psdk-case-summary-data {
- flex: 1;
-}
-
-.psdk-case-view-label {
- font-size: 1rem;
- display: block;
- transform: translateY(0.2em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(0.2em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-label-readonly {
- font-size: 1rem;
- display: block;
- transform: translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(-1.28125em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-data-readonly {
- padding-top: 0.625rem;
- width: 100%;
-}
-
-.psdk-status {
- background-color: $app-primary-color;
- color: white;
- padding: 0;
- margin-top: 0.625rem;
- width: fit-content;
-}
-
-::ng-deep .mat-mdc-form-field-infix {
- width: auto;
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/case-summary/case-summary.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/case-summary/case-summary.component.spec.ts
deleted file mode 100644
index 5ae846ce..00000000
--- a/tests/assets/components/createAll/override-sdk/template/case-summary/case-summary.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { CaseSummaryComponent } from './case-summary.component';
-
-describe('CaseSummaryComponent', () => {
- let component: CaseSummaryComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ CaseSummaryComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(CaseSummaryComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/case-summary/case-summary.component.ts b/tests/assets/components/createAll/override-sdk/template/case-summary/case-summary.component.ts
deleted file mode 100644
index d60f9b9c..00000000
--- a/tests/assets/components/createAll/override-sdk/template/case-summary/case-summary.component.ts
+++ /dev/null
@@ -1,92 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { FormGroup } from '@angular/forms';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { ReferenceComponent } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-case-summary',
- templateUrl: './case-summary.component.html',
- styleUrls: ['./case-summary.component.scss'],
- standalone: true,
- imports: [forwardRef(() => ComponentMapperComponent)]
-})
-export class CaseSummaryComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- angularPConnectData: any = {};
-
- configProps$: Object;
- arChildren$: Array;
-
- status$: string;
- bShowStatus$: boolean;
- primaryFields$: Array = [];
- secondaryFields$: Array = [];
-
- constructor(private angularPConnect: AngularPConnectService) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- this.initComponent();
- }
-
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- initComponent() {
- // dereference the View in case the incoming pConn$ is a 'reference'
- this.pConn$ = ReferenceComponent.normalizePConn(this.pConn$);
-
- // Then, continue on with other initialization
-
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.arChildren$ = this.pConn$.getChildren();
-
- this.generatePrimaryAndSecondaryFields();
-
- this.status$ = this.configProps$['status'];
- this.bShowStatus$ = this.configProps$['showStatus'];
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- this.generatePrimaryAndSecondaryFields();
- }
-
- ngOnChanges() {
- this.initComponent();
- }
-
- generatePrimaryAndSecondaryFields() {
- this.primaryFields$ = [];
- this.secondaryFields$ = [];
-
- for (let oField of this.arChildren$[0].getPConnect().getChildren()) {
- let kid = oField.getPConnect();
- this.primaryFields$.push(kid.resolveConfigProps(kid.getRawMetadata()));
- }
-
- for (let oField of this.arChildren$[1].getPConnect().getChildren()) {
- let kid = oField.getPConnect();
- this.secondaryFields$.push(kid.resolveConfigProps(kid.getRawMetadata()));
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/case-summary/config.json b/tests/assets/components/createAll/override-sdk/template/case-summary/config.json
deleted file mode 100644
index d8a7d75c..00000000
--- a/tests/assets/components/createAll/override-sdk/template/case-summary/config.json
+++ /dev/null
@@ -1,24 +0,0 @@
-{
- "name": "CaseSummary",
- "label": "Summary data",
- "description": "Case summary template",
- "type": "Template",
- "subtype": "SUMMARY",
- "icon": "Summary.svg",
- "hideViewName": true,
- "hideTemplateEdit": true,
- "properties": [
- {
- "name": "Primary fields",
- "label": "Primary fields",
- "format": "CONTENTPICKER",
- "addTypeList": ["Fields"]
- },
- {
- "name": "Secondary fields",
- "label": "Secondary fields",
- "format": "CONTENTPICKER",
- "addTypeList": ["Widgets", "Fields"]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/case-view/case-view.component.html b/tests/assets/components/createAll/override-sdk/template/case-view/case-view.component.html
deleted file mode 100644
index d0fb2c07..00000000
--- a/tests/assets/components/createAll/override-sdk/template/case-view/case-view.component.html
+++ /dev/null
@@ -1,89 +0,0 @@
-
-
-
-
-
-
-
-
-
{{ currentCaseID }}
-
{{ id$ }}
-
-
{{ heading$ }}
-
-
-
-
-
-
- Edit
- Actions...
-
-
-
- {{ action.name }}
-
-
-
-
- {{ process.name }}
-
-
-
-
-
-
-
-
-
-
-
-
1"
- name="VerticalTabs"
- [props]="{ tabConfig$: caseTabs$ }"
- [parent]="this"
- [outputEvents]="{ tabClick: onTabClick }"
- >
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/template/case-view/case-view.component.scss b/tests/assets/components/createAll/override-sdk/template/case-view/case-view.component.scss
deleted file mode 100644
index 05dd426d..00000000
--- a/tests/assets/components/createAll/override-sdk/template/case-view/case-view.component.scss
+++ /dev/null
@@ -1,106 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-h1 {
- font-size: 1.1rem;
- line-height: 1.3rem;
-}
-
-::ng-deep .mat-mdc-menu-panel {
- overflow: unset;
- max-width: unset;
-}
-
-.psdk-case-view-label {
- font-size: 1rem;
- display: block;
- transform: translateY(0.2em) scale(0.75) perspective(100px) translateZ(0.001px);
- -ms-transform: translateY(0.2em) scale(0.75);
- width: 133.33333%;
-}
-
-.psdk-case-view {
- box-sizing: border-box;
- display: flex;
-}
-
-.ng-case-view-toolbar {
- padding: 0.625rem 0.625rem;
-}
-
-.psdk-case-icon-div {
- background-color: $app-primary-dark-color;
- border-radius: 1rem;
- padding: 0.5rem 0.3rem 0.3rem 0.3rem;
-}
-.psdk-case-svg-icon {
- width: 2rem;
- padding: 0rem 0.3125rem;
- filter: $app-white-color-filter;
-}
-
-.psdk-case-view-info-box {
- display: flex;
- flex-direction: row;
- padding: 0rem 0.3125rem 0rem 0rem;
-}
-
-.psdk-case-view-info {
- flex: 0 0 auto;
- width: 25rem;
- float: left;
- padding: 0rem 0.3125rem 0rem 0rem;
- height: 100%; /* Should be removed. Only for demonstration */
- background-color: $app-form-color;
-}
-
-.psdk-case-view-main {
- flex-grow: 2;
- float: left;
- padding: 0rem 0.3125rem;
- height: 100%; /* Should be removed. Only for demonstration */
-}
-
-.psdk-case-view-summary {
- padding-left: 0.75rem;
-}
-
-.psdk-case-view-heading {
- display: block;
- text-align: left;
- padding-left: 0.5rem;
- padding-bottom: 0;
- padding-top: 5px;
-}
-.psdk-case-view-heading-id {
- font-size: 0.9rem;
- font-weight: normal;
-}
-
-.psdk-case-view-buttons {
- display: flex;
- justify-content: flex-start;
- padding: 0.3125rem;
-}
-
-.psdk-case-view-utilities {
- width: 21.875rem;
- float: left;
- padding: 0rem 0.3125rem;
- height: 100%; /* Should be removed. Only for demonstration */
-}
-
-.psdk-case-view-divider {
- border-bottom: 0.0625rem solid $app-neutral-light-color;
-}
-
-.psdk-status {
- padding: 0.3125rem 0.3125rem;
- background-color: $app-primary-color;
- color: white;
- width: fit-content;
- margin: 0.625rem;
-}
-
-button {
- margin: 0rem 0.3125rem;
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/case-view/case-view.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/case-view/case-view.component.spec.ts
deleted file mode 100644
index cf55d267..00000000
--- a/tests/assets/components/createAll/override-sdk/template/case-view/case-view.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { CaseViewComponent } from './case-view.component';
-
-describe('CaseViewComponent', () => {
- let component: CaseViewComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ CaseViewComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(CaseViewComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/case-view/case-view.component.ts b/tests/assets/components/createAll/override-sdk/template/case-view/case-view.component.ts
deleted file mode 100644
index db424e2e..00000000
--- a/tests/assets/components/createAll/override-sdk/template/case-view/case-view.component.ts
+++ /dev/null
@@ -1,229 +0,0 @@
-import { Component, OnInit, Input, ChangeDetectorRef, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { MatToolbarModule } from '@angular/material/toolbar';
-import { MatButtonModule } from '@angular/material/button';
-import { MatMenuModule } from '@angular/material/menu';
-import { interval } from 'rxjs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { RegionComponent } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-case-view',
- templateUrl: './case-view.component.html',
- styleUrls: ['./case-view.component.scss'],
- providers: [Utils],
- standalone: true,
- imports: [CommonModule, MatToolbarModule, MatButtonModule, MatMenuModule, ComponentMapperComponent, forwardRef(() => RegionComponent)]
-})
-export class CaseViewComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
- @Input() displayOnlyFA$: boolean;
-
- PCore$: any;
-
- configProps$: Object;
- arChildren$: Array;
-
- heading$: string = '';
- id$: string = '';
- status$: string = '';
- caseTabs$: Array = [];
- svgCase$: string;
- tabData$: any;
-
- mainTabs: any;
- mainTabData: any;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
-
- arAvailableActions$: Array = [];
- arAvailabeProcesses$: Array = [];
-
- caseSummaryPConn$: any;
- currentCaseID: string = '';
- editAction: boolean;
- bHasNewAttachments: boolean = false;
-
- constructor(
- private cdRef: ChangeDetectorRef,
- private angularPConnect: AngularPConnectService,
- private utils: Utils
- ) {}
-
- ngOnInit(): void {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
-
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- // this.updateSelf();
- this.checkAndUpdate();
- }
-
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- const bLogging = false;
-
- // Should always check the bridge to see if the component should update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- // AND removing the "gate" that was put there since shouldComponentUpdate
- // should be the real "gate"
- if (bUpdateSelf) {
- // generally, don't want to refresh everything when data changes in caseView, it is usually the
- // case summary. But check if the case ID changes, this means a different case and we should
- // update all.
- if (this.hasCaseIDChanged()) {
- this.fullUpdate();
-
- // update okToInitFlowContainer, because case view was drawn, flow container will need to be init
- // to match Nebula/Constellation
- sessionStorage.setItem('okToInitFlowContainer', 'true');
- } else {
- this.updateHeaderAndSummary();
- }
- }
- }
-
- hasCaseIDChanged(): boolean {
- if (this.currentCaseID !== this.pConn$.getDataObject().caseInfo.ID) {
- this.currentCaseID = this.pConn$.getDataObject().caseInfo.ID;
- return true;
- } else {
- return false;
- }
- }
-
- updateHeaderAndSummary() {
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- let hasNewAttachments = this.pConn$.getDataObject().caseInfo?.hasNewAttachments;
-
- if(hasNewAttachments !== this.bHasNewAttachments){
- this.bHasNewAttachments = hasNewAttachments;
- if(this.bHasNewAttachments){
- this.PCore$.getPubSubUtils().publish(
- this.PCore$.getEvents().getCaseEvent().CASE_ATTACHMENTS_UPDATED_FROM_CASEVIEW,
- true
- );
- }
- }
-
- let kids = this.pConn$.getChildren();
- for (let kid of kids) {
- let meta = kid.getPConnect().getRawMetadata();
- if (meta.type.toLowerCase() == 'region' && meta.name.toLowerCase() == 'summary') {
- this.caseSummaryPConn$ = kid.getPConnect().getChildren()[0].getPConnect();
- }
- }
-
- // have to put in a timeout, otherwise get an angular change event error
- let timer = interval(100).subscribe(() => {
- timer.unsubscribe();
-
- this.heading$ = this.configProps$['header'];
- this.id$ = this.configProps$['subheader'];
- this.status$ = this.pConn$.getValue('.pyStatusWork');
- });
- }
-
- fullUpdate() {
- this.caseTabs$ = [];
- this.updateHeaderAndSummary();
-
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.arChildren$ = this.pConn$.getChildren();
-
- let caseInfo = this.pConn$.getDataObject().caseInfo;
- this.currentCaseID = caseInfo.ID;
- this.arAvailableActions$ = caseInfo?.availableActions ? caseInfo.availableActions : [];
- this.editAction = this.arAvailableActions$.find((action) => action.ID === 'pyUpdateCaseDetails');
- this.arAvailabeProcesses$ = caseInfo?.availableProcesses ? caseInfo.availableProcesses : [];
-
- this.svgCase$ = this.utils.getImageSrc(this.configProps$['icon'], this.utils.getSDKStaticContentUrl());
-
- //this.utils.consoleKidDump(this.pConn$);
-
- if (!this.displayOnlyFA$) {
- for (let kid of this.arChildren$) {
- let kidPConn = kid.getPConnect();
- if (kidPConn.getRawMetadata().name == 'Tabs') {
- this.mainTabs = kid;
- this.mainTabData = this.mainTabs.getPConnect().getChildren();
- }
- }
-
- this.mainTabs
- .getPConnect()
- .getChildren()
- ?.forEach((child, i) => {
- const config = child.getPConnect().resolveConfigProps(child.getPConnect().getRawMetadata()).config;
- let { label, inheritedProps, visibility } = config;
- //For some tabs, "label" property is not avaialable in theTabCompConfig, so will get them from inheritedProps
- if (!label) {
- inheritedProps.forEach((inheritedProp: any) => {
- if (inheritedProp.prop === 'label') {
- label = inheritedProp.value;
- }
- });
- }
- // We'll display the tabs when either visibility property doesn't exist or is true(if exists)
- if (visibility === undefined || visibility === true) {
- this.caseTabs$.push({ name: label, id: i });
- // To make first visible tab display at the beginning
- if (!this.tabData$) {
- this.tabData$ = { type: 'DeferLoad', config: child.getPConnect().getRawMetadata().config };
- }
- }
- });
- }
- }
-
- updateSelf() {
- this.fullUpdate();
- }
-
- onTabClick(tab: any) {
- this.tabData$ = this.mainTabData[tab].getPConnect().getRawMetadata();
- this.cdRef.detectChanges();
- }
-
- _editClick() {
- const editAction = this.arAvailableActions$.find((action) => action.ID === 'pyUpdateCaseDetails');
- const actionsAPI = this.pConn$.getActionsApi();
- const openLocalAction = actionsAPI.openLocalAction.bind(actionsAPI);
-
- openLocalAction(editAction.ID, { ...editAction });
- }
-
- _menuActionClick(data) {
- const actionsAPI = this.pConn$.getActionsApi();
- const openLocalAction = actionsAPI.openLocalAction.bind(actionsAPI);
-
- openLocalAction(data.ID, { ...data, containerName: 'modal', type: 'express' });
- }
-
- _menuProcessClick(data) {
- const actionsAPI = this.pConn$.getActionsApi();
- const openProcessAction = actionsAPI.openProcessAction.bind(actionsAPI);
-
- openProcessAction(data.ID, { ...data });
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/case-view/config.json b/tests/assets/components/createAll/override-sdk/template/case-view/config.json
deleted file mode 100644
index b1f47a0f..00000000
--- a/tests/assets/components/createAll/override-sdk/template/case-view/config.json
+++ /dev/null
@@ -1,40 +0,0 @@
-{
- "name": "CaseView",
- "label": "Case page",
- "description": "Standard case page",
- "type": "Template",
- "subtype": "CASEVIEW",
- "icon": "CasePage.svg",
- "hideTemplateEdit": true,
- "hideViewName": true,
- "properties": [
- {
- "name": "header",
- "label": "Header",
- "format": "PROPERTY"
- },
- {
- "name": "subheader",
- "label": "Subheader",
- "format": "PROPERTY"
- },
- {
- "name": "showIconInHeader",
- "label": "Show icon in header",
- "format": "BOOLEAN"
- },
- {
- "name": "Tabs",
- "label": "Tabs",
- "format": "CONTENTPICKER",
- "modifyPanelOverride": "DeferLoad",
- "addTypeList": ["Tabs"]
- },
- {
- "name": "Utilities",
- "label": "Utilities",
- "format": "CONTENTPICKER",
- "addTypeList": ["Widgets"]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/confirmation/confirmation.component.html b/tests/assets/components/createAll/override-sdk/template/confirmation/confirmation.component.html
deleted file mode 100644
index 81ffcddc..00000000
--- a/tests/assets/components/createAll/override-sdk/template/confirmation/confirmation.component.html
+++ /dev/null
@@ -1,23 +0,0 @@
-
-
-
{{ label }}
-
-
-
-
0">
-
-
-
- Done
-
-
-
0">
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/template/confirmation/confirmation.component.scss b/tests/assets/components/createAll/override-sdk/template/confirmation/confirmation.component.scss
deleted file mode 100644
index 65c3587c..00000000
--- a/tests/assets/components/createAll/override-sdk/template/confirmation/confirmation.component.scss
+++ /dev/null
@@ -1,10 +0,0 @@
-.done-button {
- justify-content: flex-end;
- display: flex;
- padding-bottom: 1rem;
-}
-
-.confirm-label {
- padding: 0px 16px;
- margin: 0px;
-}
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/template/confirmation/confirmation.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/confirmation/confirmation.component.spec.ts
deleted file mode 100644
index 845c91b0..00000000
--- a/tests/assets/components/createAll/override-sdk/template/confirmation/confirmation.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed } from '@angular/core/testing';
-import { ConfirmationComponent } from './confirmation.component';
-
-
-describe('ConfirmationComponent', () => {
- let component: ConfirmationComponent;
- let fixture: ComponentFixture;
-
- beforeEach(async () => {
- await TestBed.configureTestingModule({
- declarations: [ ConfirmationComponent ]
- })
- .compileComponents();
- });
-
- beforeEach(() => {
- fixture = TestBed.createComponent(ConfirmationComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/confirmation/confirmation.component.ts b/tests/assets/components/createAll/override-sdk/template/confirmation/confirmation.component.ts
deleted file mode 100644
index dcaf6291..00000000
--- a/tests/assets/components/createAll/override-sdk/template/confirmation/confirmation.component.ts
+++ /dev/null
@@ -1,87 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { MatButtonModule } from '@angular/material/button';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { getToDoAssignments } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-confirmation',
- templateUrl: './confirmation.component.html',
- styleUrls: ['./confirmation.component.scss'],
- standalone: true,
- imports: [CommonModule, MatButtonModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class ConfirmationComponent implements OnInit {
- rootInfo: any;
- datasource: any;
- showTasks: any;
- detailProps: any;
- toDoList: any;
- label: any;
- CONSTS: any;
- showDetails: boolean;
- constructor(private angularPConnect: AngularPConnectService) {}
-
- @Input() pConn$: any;
-
- angularPConnectData: any = {};
- PCore$: any;
- configProps$: any;
- showConfirmView = true;
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
- this.CONSTS = this.PCore$.getConstants();
- const activeContainerItemID = this.PCore$.getContainerUtils().getActiveContainerItemName(this.pConn$.getTarget());
- this.rootInfo = this.PCore$.getContainerUtils().getContainerItemData(this.pConn$.getTarget(), activeContainerItemID);
- this.checkAndUpdate();
- }
-
- ngOnDestroy() {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- const theConfigProps = this.pConn$.getConfigProps();
- this.datasource = theConfigProps?.datasource;
- this.showTasks = theConfigProps?.showTasks;
- this.label = theConfigProps?.label;
- // Get the inherited props from the parent to determine label settings
- // Not using whatsNext at the moment, need to figure out the use of it
- const whatsNext = this.datasource?.source;
- const items = whatsNext?.length > 0 ? whatsNext.map((item) => item.label) : '';
- const todoProps = { ...theConfigProps, renderTodoInConfirm: true };
- this.toDoList = getToDoAssignments(this.pConn$);
- this.detailProps = { ...theConfigProps, showLabel: false };
- this.showDetails = this.pConn$?.getChildren()?.[0]?.getPConnect()?.getChildren()?.length > 0;
- }
-
- onConfirmViewClose() {
- this.showConfirmView = false;
- this.PCore$.getPubSubUtils().publish(this.PCore$.getConstants().PUB_SUB_EVENTS.CASE_EVENTS.CLOSE_CONFIRM_VIEW, this.rootInfo);
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/data-reference/data-reference.component.html b/tests/assets/components/createAll/override-sdk/template/data-reference/data-reference.component.html
deleted file mode 100644
index 1436efea..00000000
--- a/tests/assets/components/createAll/override-sdk/template/data-reference/data-reference.component.html
+++ /dev/null
@@ -1,13 +0,0 @@
-
diff --git a/tests/assets/components/createAll/override-sdk/template/data-reference/data-reference.component.scss b/tests/assets/components/createAll/override-sdk/template/data-reference/data-reference.component.scss
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/template/data-reference/data-reference.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/data-reference/data-reference.component.spec.ts
deleted file mode 100644
index 66f0b7b9..00000000
--- a/tests/assets/components/createAll/override-sdk/template/data-reference/data-reference.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { DataReferenceComponent } from './data-reference.component';
-
-describe('DataReferenceComponent', () => {
- let component: DataReferenceComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ DataReferenceComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(DataReferenceComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/data-reference/data-reference.component.ts b/tests/assets/components/createAll/override-sdk/template/data-reference/data-reference.component.ts
deleted file mode 100644
index a168d9a0..00000000
--- a/tests/assets/components/createAll/override-sdk/template/data-reference/data-reference.component.ts
+++ /dev/null
@@ -1,251 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { MultiReferenceReadonlyComponent } from '@pega/angular-sdk-library';
-import { SingleReferenceReadonlyComponent } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-const SELECTION_MODE = { SINGLE: 'single', MULTI: 'multi' };
-
-@Component({
- selector: 'app-data-reference',
- templateUrl: './data-reference.component.html',
- styleUrls: ['./data-reference.component.scss'],
- standalone: true,
- imports: [
- CommonModule,
- SingleReferenceReadonlyComponent,
- MultiReferenceReadonlyComponent,
- forwardRef(() => ComponentMapperComponent)
- ]
-})
-export class DataReferenceComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- PCore$: any;
-
- arFields$: Array = [];
- referenceType = '';
- selectionMode = '';
- parameters;
- hideLabel = false;
- childrenToRender: Array = [];
- dropDownDataSource: String = '';
- isDisplayModeEnabled: Boolean = false;
- propsToUse: any = {};
- rawViewMetadata: any = {};
- viewName: String = '';
- firstChildMeta: any = {};
- canBeChangedInReviewMode: Boolean = false;
- propName: String = '';
- firstChildPConnect;
- children;
- displaySingleRef: boolean;
- displayMultiRef: boolean;
-
- constructor(private angularPConnect: AngularPConnectService) {}
-
- ngOnInit(): void {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
-
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.children = this.pConn$.getChildren();
- this.updateSelf();
- }
-
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- // Update properties based on configProps
- const theConfigProps = this.pConn$.getConfigProps();
- const label = theConfigProps.label;
- const showLabel = theConfigProps.showLabel;
- const displayMode = theConfigProps.displayMode;
- const allowAndPersistChangesInReviewMode = theConfigProps.allowAndPersistChangesInReviewMode;
- this.referenceType = theConfigProps.referenceType;
- this.selectionMode = theConfigProps.selectionMode;
- const displayAs = theConfigProps.displayAs;
- this.parameters = theConfigProps.parameters;
- this.hideLabel = theConfigProps.hideLabel;
-
- this.propsToUse = { label, showLabel, ...this.pConn$.getInheritedProps() };
- if (this.propsToUse.showLabel === false) {
- this.propsToUse.label = '';
- }
- this.rawViewMetadata = this.pConn$.getRawMetadata();
- this.viewName = this.rawViewMetadata.name;
- this.firstChildMeta = this.rawViewMetadata.children[0];
- const refList = this.rawViewMetadata.config.referenceList;
- this.canBeChangedInReviewMode =
- allowAndPersistChangesInReviewMode && (displayAs === 'autocomplete' || displayAs === 'dropdown');
- // this.childrenToRender = this.children;
- this.isDisplayModeEnabled = ['LABELS_LEFT', 'STACKED_LARGE_VAL'].includes(displayMode);
-
- if (this.firstChildMeta?.type !== 'Region') {
- this.firstChildPConnect = this.pConn$.getChildren()[0].getPConnect;
-
- /* remove refresh When condition from those old view so that it will not be used for runtime */
- if (this.firstChildMeta.config?.readOnly) {
- delete this.firstChildMeta.config.readOnly;
- }
- if (this.firstChildMeta?.type === 'Dropdown') {
- this.firstChildMeta.config.datasource.source = this.rawViewMetadata.config?.parameters
- ? this.dropDownDataSource
- : '@DATASOURCE '.concat(refList).concat('.pxResults');
- } else if (this.firstChildMeta?.type === 'AutoComplete') {
- this.firstChildMeta.config.datasource = refList;
-
- /* Insert the parameters to the component only if present */
- if (this.rawViewMetadata.config?.parameters) {
- this.firstChildMeta.config.parameters = this.parameters;
- }
- }
- // set displayMode conditionally
- if (!this.canBeChangedInReviewMode) {
- this.firstChildMeta.config.displayMode = displayMode;
- }
- if (this.firstChildMeta.type === 'SimpleTableSelect' && this.selectionMode === SELECTION_MODE.MULTI) {
- this.propName = this.PCore$.getAnnotationUtils().getPropertyName(this.firstChildMeta.config.selectionList);
- } else {
- this.propName = this.PCore$.getAnnotationUtils().getPropertyName(this.firstChildMeta.config.value);
- }
-
- const theRecreatedFirstChild = this.recreatedFirstChild();
- const viewsRegion = this.rawViewMetadata.children[1];
- if (viewsRegion?.name === 'Views' && viewsRegion.children.length) {
- this.childrenToRender = [theRecreatedFirstChild, ...this.children.slice(1)];
- } else {
- this.childrenToRender = [theRecreatedFirstChild];
- }
- }
- }
-
- handleSelection(event) {
- const caseKey = this.pConn$.getCaseInfo().getKey();
- const refreshOptions = { autoDetectRefresh: true };
- if (this.canBeChangedInReviewMode && this.pConn$.getValue('__currentPageTabViewName')) {
- this.pConn$
- .getActionsApi()
- .refreshCaseView(caseKey, this.pConn$.getValue('__currentPageTabViewName'), null, refreshOptions);
- this.PCore$.getDeferLoadManager().refreshActiveComponents(this.pConn$.getContextName());
- } else {
- const pgRef = this.pConn$.getPageReference().replace('caseInfo.content', '');
- this.pConn$.getActionsApi().refreshCaseView(caseKey, this.viewName, pgRef, refreshOptions);
- }
-
- // AutoComplete sets value on event.id whereas Dropdown sets it on event.target.value
- const propValue = event?.id || event?.target?.value;
- if (propValue && this.canBeChangedInReviewMode && this.isDisplayModeEnabled) {
- this.PCore$.getDataApiUtils()
- .getCaseEditLock(caseKey)
- .then((caseResponse) => {
- const pageTokens = this.pConn$.getPageReference().replace('caseInfo.content', '').split('.');
- let curr = {};
- const commitData = curr;
-
- pageTokens.forEach((el) => {
- if (el !== '') {
- curr[el] = {};
- curr = curr[el];
- }
- });
-
- // expecting format like {Customer: {pyID:"C-100"}}
- const propArr = this.propName.split('.');
- propArr.forEach((element, idx) => {
- if (idx + 1 === propArr.length) {
- curr[element] = propValue;
- } else {
- curr[element] = {};
- curr = curr[element];
- }
- });
-
- this.PCore$.getDataApiUtils()
- .updateCaseEditFieldsData(
- caseKey,
- { [caseKey]: commitData },
- caseResponse.headers.etag,
- this.pConn$.getContextName()
- )
- .then((response) => {
- this.PCore$.getContainerUtils().updateChildContainersEtag(
- this.pConn$.getContextName(),
- response.headers.etag
- );
- });
- });
- }
- }
-
- // Re-create first child with overridden props
- // Memoized child in order to stop unmount and remount of the child component when data reference
- // rerenders without any actual change
- recreatedFirstChild() {
- const { type, config } = this.firstChildMeta;
- if (this.firstChildMeta?.type !== 'Region') {
- this.pConn$.clearErrorMessages({
- property: this.propName
- });
- if (!this.canBeChangedInReviewMode && this.isDisplayModeEnabled && this.selectionMode === SELECTION_MODE.SINGLE) {
- this.displaySingleRef = true;
- }
-
- if (this.isDisplayModeEnabled && this.selectionMode === SELECTION_MODE.MULTI) {
- this.displayMultiRef = true;
- }
-
- // In the case of a datasource with parameters you cannot load the dropdown before the parameters
- if (type === 'Dropdown' && this.rawViewMetadata.config?.parameters && this.dropDownDataSource === null) {
- return null;
- }
-
- return this.firstChildPConnect().createComponent({
- type,
- config: {
- ...config,
- required: this.propsToUse.required,
- visibility: this.propsToUse.visibility,
- disabled: this.propsToUse.disabled,
- label: this.propsToUse.label,
- viewName: this.pConn$.getCurrentView(),
- parameters: this.rawViewMetadata.config.parameters,
- readOnly: false,
- localeReference: this.rawViewMetadata.config.localeReference,
- ...(this.selectionMode === SELECTION_MODE.SINGLE ? { referenceType: this.referenceType } : ''),
- dataRelationshipContext:
- this.rawViewMetadata.config.contextClass && this.rawViewMetadata.config.name
- ? this.rawViewMetadata.config.name
- : null,
- hideLabel: this.hideLabel,
- onRecordChange: this.handleSelection.bind(this)
- }
- });
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/default-form/default-form.component.html b/tests/assets/components/createAll/override-sdk/template/default-form/default-form.component.html
deleted file mode 100644
index 90023929..00000000
--- a/tests/assets/components/createAll/override-sdk/template/default-form/default-form.component.html
+++ /dev/null
@@ -1,20 +0,0 @@
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/template/default-form/default-form.component.scss b/tests/assets/components/createAll/override-sdk/template/default-form/default-form.component.scss
deleted file mode 100644
index d135e488..00000000
--- a/tests/assets/components/createAll/override-sdk/template/default-form/default-form.component.scss
+++ /dev/null
@@ -1,38 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-.psdk-default-form-one-column {
- display: grid;
- grid-template-columns: repeat(1, minmax(0, 1fr));
- gap: calc(1rem);
-}
-
-.psdk-default-form-two-column {
- display: grid;
- grid-template-columns: repeat(2, 1fr);
- gap: calc(1rem);
-}
-
-.psdk-default-form-three-column {
- display: grid;
- grid-template-columns: repeat(3, 1fr);
- gap: calc(1rem);
-}
-
-.psdk-default-form-two-column .grid-column {
- grid-column: 1 / span 2;
-}
-
-.psdk-default-form-three-column .grid-column {
- grid-column: 1 / span 3;
-}
-
-.template-title-container {
- font-size: calc(0.9375rem);
- font-weight: 600;
- margin: 10px 0px;
-}
-
-.psdk-default-form-instruction-text{
- padding-top: 0.625rem;
- padding-bottom: 0.625rem;
-}
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/template/default-form/default-form.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/default-form/default-form.component.spec.ts
deleted file mode 100644
index 0908ba7e..00000000
--- a/tests/assets/components/createAll/override-sdk/template/default-form/default-form.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { DefaultFormComponent } from './default-form.component';
-
-describe('DefaultFormComponent', () => {
- let component: DefaultFormComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ DefaultFormComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(DefaultFormComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/default-form/default-form.component.ts b/tests/assets/components/createAll/override-sdk/template/default-form/default-form.component.ts
deleted file mode 100644
index 17f89230..00000000
--- a/tests/assets/components/createAll/override-sdk/template/default-form/default-form.component.ts
+++ /dev/null
@@ -1,71 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { ReferenceComponent } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-import { TemplateUtils } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-default-form',
- templateUrl: './default-form.component.html',
- styleUrls: ['./default-form.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class DefaultFormComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- configProps$: Object;
- arChildren$: Array;
- divClass$: string;
- template: any;
- showLabel: any;
- label: any;
- instructions: string;
-
- NO_HEADER_TEMPLATES = [
- 'SubTabs',
- 'SimpleTable',
- 'Details',
- 'DetailsTwoColumn',
- 'DetailsThreeColumn',
- 'NarrowWideDetails',
- 'WideNarrowDetails',
- 'Confirmation'
- ];
-
- constructor(private templateUtils: TemplateUtils) {}
-
- ngOnInit(): void {
- let configProps = this.pConn$.getConfigProps();
- this.template = configProps?.template;
- const propToUse = { ...this.pConn$.getInheritedProps() };
- this.showLabel = propToUse?.showLabel;
- this.label = propToUse?.label;
- let kids = this.pConn$.getChildren();
- this.instructions = this.templateUtils.getInstructions(this.pConn$, configProps?.instructions);
- console.log("instructions" + this.instructions);
-
- let numCols = configProps.NumCols ? configProps.NumCols : '1';
- switch (numCols) {
- case '1':
- this.divClass$ = 'psdk-default-form-one-column';
- break;
- case '2':
- this.divClass$ = 'psdk-default-form-two-column';
- break;
- case '3':
- this.divClass$ = 'psdk-default-form-three-column';
- break;
- default:
- this.divClass$ = 'psdk-default-form-one-column';
- break;
- }
-
- // repoint children before getting templateArray
- // Children may contain 'reference' component, so we need to
- // normalize them
- this.arChildren$ = ReferenceComponent.normalizePConnArray(kids[0].getPConnect().getChildren());
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/details-narrow-wide/details-narrow-wide.component.html b/tests/assets/components/createAll/override-sdk/template/details-narrow-wide/details-narrow-wide.component.html
deleted file mode 100644
index e22f590a..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-narrow-wide/details-narrow-wide.component.html
+++ /dev/null
@@ -1,6 +0,0 @@
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/template/details-narrow-wide/details-narrow-wide.component.scss b/tests/assets/components/createAll/override-sdk/template/details-narrow-wide/details-narrow-wide.component.scss
deleted file mode 100644
index deee7559..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-narrow-wide/details-narrow-wide.component.scss
+++ /dev/null
@@ -1,8 +0,0 @@
-.psdk-grid-filter {
- display: grid;
- grid-template-columns: 3fr 7fr;
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/template/details-narrow-wide/details-narrow-wide.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/details-narrow-wide/details-narrow-wide.component.spec.ts
deleted file mode 100644
index e22b4472..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-narrow-wide/details-narrow-wide.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed } from '@angular/core/testing';
-
-import { DetailsNarrowWideComponent } from './details-narrow-wide.component';
-
-describe('DetailsNarrowWideComponent', () => {
- let component: DetailsNarrowWideComponent;
- let fixture: ComponentFixture;
-
- beforeEach(async () => {
- await TestBed.configureTestingModule({
- declarations: [ DetailsNarrowWideComponent ]
- })
- .compileComponents();
- });
-
- beforeEach(() => {
- fixture = TestBed.createComponent(DetailsNarrowWideComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/details-narrow-wide/details-narrow-wide.component.ts b/tests/assets/components/createAll/override-sdk/template/details-narrow-wide/details-narrow-wide.component.ts
deleted file mode 100644
index ef387e17..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-narrow-wide/details-narrow-wide.component.ts
+++ /dev/null
@@ -1,82 +0,0 @@
-import { Component, OnInit, Input } from '@angular/core';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { MaterialDetailsComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-details-narrow-wide',
- templateUrl: './details-narrow-wide.component.html',
- styleUrls: ['./details-narrow-wide.component.scss'],
- standalone: true,
- imports: [MaterialDetailsComponent]
-})
-export class DetailsNarrowWideComponent implements OnInit {
- constructor(private angularPConnect: AngularPConnectService) {}
-
- @Input() pConn$: any;
-
- arFields$: Array = [];
- arFields2$: Array = [];
- highlightedDataArr: Array = [];
- showHighlightedData: boolean;
- // Used with AngularPConnect
- angularPConnectData: any = {};
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- //this.updateSelf();
- this.checkAndUpdate();
- }
-
- ngOnDestroy() {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- const rawMetaData = this.pConn$.resolveConfigProps(this.pConn$.getRawMetadata().config);
- this.showHighlightedData = rawMetaData?.showHighlightedData;
-
- if( this.showHighlightedData ){
- const highlightedData = rawMetaData?.highlightedData;
- this.highlightedDataArr = highlightedData.map(field => {
- field.config.displayMode = 'STACKED_LARGE_VAL';
-
- if (field.config.value === '@P .pyStatusWork') {
- field.type = 'TextInput';
- field.config.displayAsStatus = true;
- }
-
- return field;
- });
- }
-
- let kids = this.pConn$.getChildren();
- for (let kid of kids) {
- let pKid = kid.getPConnect();
- let pKidData = pKid.resolveConfigProps(pKid.getRawMetadata());
- if (kids.indexOf(kid) == 0) {
- this.arFields$ = pKidData.children;
- } else {
- this.arFields2$ = pKidData.children;
- }
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/details-one-column/config.json b/tests/assets/components/createAll/override-sdk/template/details-one-column/config.json
deleted file mode 100644
index 6a2a3506..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-one-column/config.json
+++ /dev/null
@@ -1,16 +0,0 @@
-{
- "name": "Details",
- "label": "Details (One column)",
- "description": "Details (One column)",
- "type": "Template",
- "subtype": "DETAILS",
- "icon": "OneColumnDetails.svg",
- "properties": [
- {
- "name": "A",
- "label": "Region A",
- "format": "CONTENTPICKER",
- "addTypeList": ["Fields", "Views", "UIComponents"]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/details-one-column/details-one-column.component.html b/tests/assets/components/createAll/override-sdk/template/details-one-column/details-one-column.component.html
deleted file mode 100644
index 978798d1..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-one-column/details-one-column.component.html
+++ /dev/null
@@ -1,5 +0,0 @@
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/template/details-one-column/details-one-column.component.scss b/tests/assets/components/createAll/override-sdk/template/details-one-column/details-one-column.component.scss
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/template/details-one-column/details-one-column.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/details-one-column/details-one-column.component.spec.ts
deleted file mode 100644
index f7573b8a..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-one-column/details-one-column.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed } from '@angular/core/testing';
-
-import { DetailsOneColumnComponent } from './details-one-column.component';
-
-describe('DetailsOneColumnComponent', () => {
- let component: DetailsOneColumnComponent;
- let fixture: ComponentFixture;
-
- beforeEach(async () => {
- await TestBed.configureTestingModule({
- declarations: [ DetailsOneColumnComponent ]
- })
- .compileComponents();
- });
-
- beforeEach(() => {
- fixture = TestBed.createComponent(DetailsOneColumnComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/details-one-column/details-one-column.component.ts b/tests/assets/components/createAll/override-sdk/template/details-one-column/details-one-column.component.ts
deleted file mode 100644
index 8dd71deb..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-one-column/details-one-column.component.ts
+++ /dev/null
@@ -1,85 +0,0 @@
-import { Component, OnInit, Input } from '@angular/core';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { FormGroup } from '@angular/forms';
-import { MaterialDetailsComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-details-one-column',
- templateUrl: './details-one-column.component.html',
- styleUrls: ['./details-one-column.component.scss'],
- standalone: true,
- imports: [MaterialDetailsComponent]
-})
-export class DetailsOneColumnComponent implements OnInit {
- constructor(private angularPConnect: AngularPConnectService) {}
-
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
- showHighlightedData: boolean;
- highlightedDataArr: any;
-
- arFields$: Array = [];
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- //this.updateSelf();
- this.checkAndUpdate();
- }
-
- ngOnDestroy() {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- const rawMetaData = this.pConn$.resolveConfigProps(this.pConn$.getRawMetadata().config);
- this.showHighlightedData = rawMetaData?.showHighlightedData;
-
- if( this.showHighlightedData ){
- const highlightedData = rawMetaData?.highlightedData;
- this.highlightedDataArr = highlightedData.map(field => {
- field.config.displayMode = 'STACKED_LARGE_VAL';
-
- if (field.config.value === '@P .pyStatusWork') {
- field.type = 'TextInput';
- field.config.displayAsStatus = true;
- }
-
- return field;
- });
- }
-
- this.pConn$.setInheritedProp('displayMode', 'LABELS_LEFT');
- this.pConn$.setInheritedProp('readOnly', true);
-
- let kids = this.pConn$.getChildren();
- for (let kid of kids) {
- let pKid = kid.getPConnect();
- let pKidData = pKid.resolveConfigProps(pKid.getRawMetadata());
- if (kids.indexOf(kid) == 0) {
- this.arFields$ = pKidData.children;
- }
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/details-sub-tabs/details-sub-tabs.component.html b/tests/assets/components/createAll/override-sdk/template/details-sub-tabs/details-sub-tabs.component.html
deleted file mode 100644
index c6094126..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-sub-tabs/details-sub-tabs.component.html
+++ /dev/null
@@ -1,15 +0,0 @@
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/template/details-sub-tabs/details-sub-tabs.component.scss b/tests/assets/components/createAll/override-sdk/template/details-sub-tabs/details-sub-tabs.component.scss
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/template/details-sub-tabs/details-sub-tabs.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/details-sub-tabs/details-sub-tabs.component.spec.ts
deleted file mode 100644
index b8d341a6..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-sub-tabs/details-sub-tabs.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { DetailsSubTabsComponent } from './details-sub-tabs.component';
-
-describe('DetailsSubTabsComponent', () => {
- let component: DetailsSubTabsComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ DetailsSubTabsComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(DetailsSubTabsComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/template/details-sub-tabs/details-sub-tabs.component.ts b/tests/assets/components/createAll/override-sdk/template/details-sub-tabs/details-sub-tabs.component.ts
deleted file mode 100644
index 50a5d430..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-sub-tabs/details-sub-tabs.component.ts
+++ /dev/null
@@ -1,81 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { MatTabsModule } from '@angular/material/tabs';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { getTransientTabs, getVisibleTabs, tabClick } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-details-sub-tabs',
- templateUrl: './details-sub-tabs.component.html',
- styleUrls: ['./details-sub-tabs.component.scss'],
- standalone: true,
- imports: [MatTabsModule, CommonModule, forwardRef(() => ComponentMapperComponent)]
-})
-export class DetailsSubTabsComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- configProps$: Object;
- arChildren$: Array;
- angularPConnectData: any = {};
- PCore$: any;
- defaultTabIndex = 0;
- currentTabId = this.defaultTabIndex.toString();
- tabItems: Array;
- availableTabs: any;
- constructor(private angularPConnect: AngularPConnectService) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
- this.checkAndUpdate();
- }
-
- ngOnDestroy() {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- const children = this.pConn$?.getChildren();
- const deferLoadedTabs = children[0];
- this.availableTabs = getVisibleTabs(deferLoadedTabs, 'tabsSubs');
- this.updateTabContent();
- }
-
- updateTabContent() {
- const tempTabItems = getTransientTabs(this.availableTabs, this.currentTabId, this.tabItems);
- this.tabItems = tempTabItems;
- }
-
- handleTabClick(event) {
- const { index } = event;
- this.currentTabId = index.toString();
- tabClick(index, this.availableTabs, this.currentTabId, this.tabItems);
- const tempTabItems = getTransientTabs(this.availableTabs, this.currentTabId, this.tabItems);
- this.tabItems[index].content = tempTabItems[index].content;
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/details-three-column/config.json b/tests/assets/components/createAll/override-sdk/template/details-three-column/config.json
deleted file mode 100644
index e3da8894..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-three-column/config.json
+++ /dev/null
@@ -1,28 +0,0 @@
-{
- "name": "DetailsThreeColumn",
- "label": "Details (Three column)",
- "description": "Details (Three column)",
- "type": "Template",
- "subtype": "DETAILS",
- "icon": "ThreeColumnDetails.svg",
- "properties": [
- {
- "name": "A",
- "label": "Region A",
- "format": "CONTENTPICKER",
- "addTypeList": ["Fields", "Views", "UIComponents"]
- },
- {
- "name": "B",
- "label": "Region B",
- "format": "CONTENTPICKER",
- "addTypeList": ["Fields", "Views", "UIComponents"]
- },
- {
- "name": "C",
- "label": "Region C",
- "format": "CONTENTPICKER",
- "addTypeList": ["Fields", "Views", "UIComponents"]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/details-three-column/details-three-column.component.html b/tests/assets/components/createAll/override-sdk/template/details-three-column/details-three-column.component.html
deleted file mode 100644
index 0fa1434c..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-three-column/details-three-column.component.html
+++ /dev/null
@@ -1,7 +0,0 @@
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/template/details-three-column/details-three-column.component.scss b/tests/assets/components/createAll/override-sdk/template/details-three-column/details-three-column.component.scss
deleted file mode 100644
index e847157b..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-three-column/details-three-column.component.scss
+++ /dev/null
@@ -1,7 +0,0 @@
-.psdk-grid-filter {
- display: grid;
- grid-template-columns: repeat(3,minmax(0,1fr));
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/template/details-three-column/details-three-column.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/details-three-column/details-three-column.component.spec.ts
deleted file mode 100644
index 1bb920f1..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-three-column/details-three-column.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed } from '@angular/core/testing';
-
-import { DetailsThreeColumnComponent } from './details-three-column.component';
-
-describe('DetailsThreeColumnComponent', () => {
- let component: DetailsThreeColumnComponent;
- let fixture: ComponentFixture;
-
- beforeEach(async () => {
- await TestBed.configureTestingModule({
- declarations: [ DetailsThreeColumnComponent ]
- })
- .compileComponents();
- });
-
- beforeEach(() => {
- fixture = TestBed.createComponent(DetailsThreeColumnComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/details-three-column/details-three-column.component.ts b/tests/assets/components/createAll/override-sdk/template/details-three-column/details-three-column.component.ts
deleted file mode 100644
index e2241f89..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-three-column/details-three-column.component.ts
+++ /dev/null
@@ -1,97 +0,0 @@
-import { Component, OnInit, Input } from '@angular/core';
-import { FormGroup } from '@angular/forms';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { MaterialDetailsComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-details-three-column',
- templateUrl: './details-three-column.component.html',
- styleUrls: ['./details-three-column.component.scss'],
- standalone: true,
- imports: [MaterialDetailsComponent]
-})
-export class DetailsThreeColumnComponent implements OnInit {
- constructor(private angularPConnect: AngularPConnectService) {}
-
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- showHighlightedData: boolean;
- highlightedDataArr: any;
- PCore$: any;
-
- arFields$: Array = [];
- arFields2$: Array = [];
- arFields3$: Array = [];
-
- propsToUse: any = {};
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- //this.updateSelf();
- this.checkAndUpdate();
- }
-
- ngOnDestroy() {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- const rawMetaData = this.pConn$.resolveConfigProps(this.pConn$.getRawMetadata().config);
- this.showHighlightedData = rawMetaData?.showHighlightedData;
-
- if( this.showHighlightedData ){
- const highlightedData = rawMetaData?.highlightedData;
- this.highlightedDataArr = highlightedData.map(field => {
- field.config.displayMode = 'STACKED_LARGE_VAL';
-
- if (field.config.value === '@P .pyStatusWork') {
- field.type = 'TextInput';
- field.config.displayAsStatus = true;
- }
-
- return field;
- });
- }
-
- this.pConn$.setInheritedProp('displayMode', 'LABELS_LEFT');
- this.pConn$.setInheritedProp('readOnly', true);
-
- let kids = this.pConn$.getChildren();
- for (let kid of kids) {
- let pKid = kid.getPConnect();
- let pKidData = pKid.resolveConfigProps(pKid.getRawMetadata());
- if (kids.indexOf(kid) == 0) {
- this.arFields$ = pKidData.children;
- } else if (kids.indexOf(kid) == 1) {
- this.arFields2$ = pKidData.children;
- } else {
- this.arFields3$ = pKidData.children;
- }
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/details-two-column/config.json b/tests/assets/components/createAll/override-sdk/template/details-two-column/config.json
deleted file mode 100644
index 60823c6e..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-two-column/config.json
+++ /dev/null
@@ -1,22 +0,0 @@
-{
- "name": "DetailsTwoColumn",
- "label": "Details (Two column)",
- "description": "Details (Two column)",
- "type": "Template",
- "subtype": "DETAILS",
- "icon": "TwoColumnDetails.svg",
- "properties": [
- {
- "name": "A",
- "label": "Region A",
- "format": "CONTENTPICKER",
- "addTypeList": ["Fields", "Views", "UIComponents"]
- },
- {
- "name": "B",
- "label": "Region B",
- "format": "CONTENTPICKER",
- "addTypeList": ["Fields", "Views", "UIComponents"]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/details-two-column/details-two-column.component.html b/tests/assets/components/createAll/override-sdk/template/details-two-column/details-two-column.component.html
deleted file mode 100644
index 1c73cc38..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-two-column/details-two-column.component.html
+++ /dev/null
@@ -1,6 +0,0 @@
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/template/details-two-column/details-two-column.component.scss b/tests/assets/components/createAll/override-sdk/template/details-two-column/details-two-column.component.scss
deleted file mode 100644
index be9bb2d2..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-two-column/details-two-column.component.scss
+++ /dev/null
@@ -1,7 +0,0 @@
-.psdk-grid-filter {
- display: grid;
- grid-template-columns: repeat(2, minmax(0, 1fr));
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/details-two-column/details-two-column.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/details-two-column/details-two-column.component.spec.ts
deleted file mode 100644
index a89c8096..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-two-column/details-two-column.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed } from '@angular/core/testing';
-
-import { DetailsTwoColumnComponent } from './details-two-column.component';
-
-describe('DetailsTwoColumnComponent', () => {
- let component: DetailsTwoColumnComponent;
- let fixture: ComponentFixture;
-
- beforeEach(async () => {
- await TestBed.configureTestingModule({
- declarations: [ DetailsTwoColumnComponent ]
- })
- .compileComponents();
- });
-
- beforeEach(() => {
- fixture = TestBed.createComponent(DetailsTwoColumnComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/details-two-column/details-two-column.component.ts b/tests/assets/components/createAll/override-sdk/template/details-two-column/details-two-column.component.ts
deleted file mode 100644
index a8ba17c2..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-two-column/details-two-column.component.ts
+++ /dev/null
@@ -1,92 +0,0 @@
-import { Component, OnInit, Input } from '@angular/core';
-import { FormGroup } from '@angular/forms';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { MaterialDetailsComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-details-two-column',
- templateUrl: './details-two-column.component.html',
- styleUrls: ['./details-two-column.component.scss'],
- standalone: true,
- imports: [MaterialDetailsComponent]
-})
-export class DetailsTwoColumnComponent implements OnInit {
- constructor(private angularPConnect: AngularPConnectService) {}
-
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- showHighlightedData: boolean;
- highlightedDataArr: any;
-
- arFields$: Array = [];
- arFields2$: Array = [];
- arFields3$: Array = [];
-
- propsToUse: any = {};
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- //this.updateSelf();
- this.checkAndUpdate();
- }
-
- ngOnDestroy() {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- const rawMetaData = this.pConn$.resolveConfigProps(this.pConn$.getRawMetadata().config);
- this.showHighlightedData = rawMetaData?.showHighlightedData;
-
- if( this.showHighlightedData ){
- const highlightedData = rawMetaData?.highlightedData;
- this.highlightedDataArr = highlightedData.map(field => {
- field.config.displayMode = 'STACKED_LARGE_VAL';
-
- if (field.config.value === '@P .pyStatusWork') {
- field.type = 'TextInput';
- field.config.displayAsStatus = true;
- }
-
- return field;
- });
- }
-
- this.pConn$.setInheritedProp('displayMode', 'LABELS_LEFT');
- this.pConn$.setInheritedProp('readOnly', true);
-
- let kids = this.pConn$.getChildren();
- for (let kid of kids) {
- let pKid = kid.getPConnect();
- let pKidData = pKid.resolveConfigProps(pKid.getRawMetadata());
- if (kids.indexOf(kid) == 0) {
- this.arFields$ = pKidData.children;
- } else {
- this.arFields2$ = pKidData.children;
- }
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/details-wide-narrow/details-wide-narrow.component.html b/tests/assets/components/createAll/override-sdk/template/details-wide-narrow/details-wide-narrow.component.html
deleted file mode 100644
index 8ce282ba..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-wide-narrow/details-wide-narrow.component.html
+++ /dev/null
@@ -1,6 +0,0 @@
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/template/details-wide-narrow/details-wide-narrow.component.scss b/tests/assets/components/createAll/override-sdk/template/details-wide-narrow/details-wide-narrow.component.scss
deleted file mode 100644
index 6c30835f..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-wide-narrow/details-wide-narrow.component.scss
+++ /dev/null
@@ -1,8 +0,0 @@
-.psdk-grid-filter {
- display: grid;
- grid-template-columns: 7fr 3fr;
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/template/details-wide-narrow/details-wide-narrow.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/details-wide-narrow/details-wide-narrow.component.spec.ts
deleted file mode 100644
index b8de9da8..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-wide-narrow/details-wide-narrow.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed } from '@angular/core/testing';
-
-import { DetailsWideNarrowComponent } from './details-wide-narrow.component';
-
-describe('DetailsWideNarrowComponent', () => {
- let component: DetailsWideNarrowComponent;
- let fixture: ComponentFixture;
-
- beforeEach(async () => {
- await TestBed.configureTestingModule({
- declarations: [ DetailsWideNarrowComponent ]
- })
- .compileComponents();
- });
-
- beforeEach(() => {
- fixture = TestBed.createComponent(DetailsWideNarrowComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/details-wide-narrow/details-wide-narrow.component.ts b/tests/assets/components/createAll/override-sdk/template/details-wide-narrow/details-wide-narrow.component.ts
deleted file mode 100644
index b91ddeca..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details-wide-narrow/details-wide-narrow.component.ts
+++ /dev/null
@@ -1,88 +0,0 @@
-import { Component, OnInit, Input } from '@angular/core';
-import { FormGroup } from '@angular/forms';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { MaterialDetailsComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-details-wide-narrow',
- templateUrl: './details-wide-narrow.component.html',
- styleUrls: ['./details-wide-narrow.component.scss'],
- standalone: true,
- imports: [MaterialDetailsComponent]
-})
-export class DetailsWideNarrowComponent implements OnInit {
- constructor(private angularPConnect: AngularPConnectService) {}
-
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- highlightedDataArr: Array = [];
- showHighlightedData: boolean;
- arFields$: Array = [];
- arFields2$: Array = [];
- propsToUse: any = {};
- // Used with AngularPConnect
- angularPConnectData: any = {};
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- //this.updateSelf();
- this.checkAndUpdate();
- }
-
- ngOnDestroy() {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- const rawMetaData = this.pConn$.resolveConfigProps(this.pConn$.getRawMetadata().config);
- this.showHighlightedData = rawMetaData?.showHighlightedData;
-
- if( this.showHighlightedData ){
- const highlightedData = rawMetaData?.highlightedData;
- this.highlightedDataArr = highlightedData.map(field => {
- field.config.displayMode = 'STACKED_LARGE_VAL';
-
- if (field.config.value === '@P .pyStatusWork') {
- field.type = 'TextInput';
- field.config.displayAsStatus = true;
- }
-
- return field;
- });
- }
-
- this.pConn$.setInheritedProp('displayMode', 'LABELS_LEFT');
- this.pConn$.setInheritedProp('readOnly', true);
-
- let kids = this.pConn$.getChildren();
- for (let kid of kids) {
- let pKid = kid.getPConnect();
- let pKidData = pKid.resolveConfigProps(pKid.getRawMetadata());
- if (kids.indexOf(kid) == 0) {
- this.arFields$ = pKidData.children;
- } else {
- this.arFields2$ = pKidData.children;
- }
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/details/config.json b/tests/assets/components/createAll/override-sdk/template/details/config.json
deleted file mode 100644
index 6a2a3506..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details/config.json
+++ /dev/null
@@ -1,16 +0,0 @@
-{
- "name": "Details",
- "label": "Details (One column)",
- "description": "Details (One column)",
- "type": "Template",
- "subtype": "DETAILS",
- "icon": "OneColumnDetails.svg",
- "properties": [
- {
- "name": "A",
- "label": "Region A",
- "format": "CONTENTPICKER",
- "addTypeList": ["Fields", "Views", "UIComponents"]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/details/details.component.html b/tests/assets/components/createAll/override-sdk/template/details/details.component.html
deleted file mode 100644
index 9bab94e3..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details/details.component.html
+++ /dev/null
@@ -1,7 +0,0 @@
-
diff --git a/tests/assets/components/createAll/override-sdk/template/details/details.component.scss b/tests/assets/components/createAll/override-sdk/template/details/details.component.scss
deleted file mode 100644
index be9bb2d2..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details/details.component.scss
+++ /dev/null
@@ -1,7 +0,0 @@
-.psdk-grid-filter {
- display: grid;
- grid-template-columns: repeat(2, minmax(0, 1fr));
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/details/details.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/details/details.component.spec.ts
deleted file mode 100644
index 3505e504..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details/details.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed } from '@angular/core/testing';
-
-import { DetailsComponent } from './details.component';
-
-describe('DetailsComponent', () => {
- let component: DetailsComponent;
- let fixture: ComponentFixture;
-
- beforeEach(async () => {
- await TestBed.configureTestingModule({
- declarations: [ DetailsComponent ]
- })
- .compileComponents();
- });
-
- beforeEach(() => {
- fixture = TestBed.createComponent(DetailsComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/details/details.component.ts b/tests/assets/components/createAll/override-sdk/template/details/details.component.ts
deleted file mode 100644
index 029fe253..00000000
--- a/tests/assets/components/createAll/override-sdk/template/details/details.component.ts
+++ /dev/null
@@ -1,121 +0,0 @@
-import { Component, OnInit, Input } from '@angular/core';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { MaterialDetailsComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-details',
- templateUrl: './details.component.html',
- styleUrls: ['./details.component.scss'],
- standalone: true,
- imports: [MaterialDetailsComponent]
-})
-export class DetailsComponent implements OnInit {
- constructor(private angularPConnect: AngularPConnectService) {}
-
- @Input() pConn$: any;
-
- PCore$: any;
-
- highlightedDataArr: Array = [];
- showHighlightedData: boolean;
- arFields$: Array = [];
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
-
- ngOnInit(): void {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
-
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- //this.updateSelf();
- this.checkAndUpdate();
- }
-
- ngOnDestroy() {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- onStateChange() {
- this.checkAndUpdate();
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- const rawMetaData = this.pConn$.resolveConfigProps(this.pConn$.getRawMetadata().config);
- this.showHighlightedData = rawMetaData?.showHighlightedData;
-
- if( this.showHighlightedData ){
- const highlightedData = rawMetaData?.highlightedData;
- this.highlightedDataArr = highlightedData.map(field => {
- field.config.displayMode = 'STACKED_LARGE_VAL';
-
- if (field.config.value === '@P .pyStatusWork') {
- field.type = 'TextInput';
- field.config.displayAsStatus = true;
- }
-
- return field;
- });
- }
-
- let kids = this.pConn$.getChildren();
- for (let kid of kids) {
- this.arFields$ = [];
- let pKid = kid.getPConnect();
- const fields = pKid.getChildren();
- fields?.forEach((field) => {
- const thePConn = field.getPConnect();
- const theCompType = thePConn.getComponentName().toLowerCase();
- if (theCompType === 'reference') {
- const configProps = thePConn.getConfigProps();
- configProps.readOnly = true;
- configProps.displayMode = 'LABELS_LEFT';
- const propToUse = { ...thePConn.getInheritedProps() };
- configProps.label = propToUse?.label;
- const options = {
- context: thePConn.getContextName(),
- pageReference: thePConn.getPageReference(),
- referenceList: thePConn.getReferenceList()
- };
- const viewContConfig = {
- meta: {
- type: theCompType,
- config: configProps
- },
- options
- };
- const theViewCont = this.PCore$.createPConnect(viewContConfig);
- const data = {
- type: theCompType,
- pConn: theViewCont?.getPConnect()
- };
- this.arFields$.push(data);
- } else {
- const data = {
- type: theCompType,
- config: thePConn.getConfigProps()
- };
- this.arFields$.push(data);
- }
- });
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/field-group-list/field-group-list.component.html b/tests/assets/components/createAll/override-sdk/template/field-group-list/field-group-list.component.html
deleted file mode 100644
index 1607186e..00000000
--- a/tests/assets/components/createAll/override-sdk/template/field-group-list/field-group-list.component.html
+++ /dev/null
@@ -1,8 +0,0 @@
-
diff --git a/tests/assets/components/createAll/override-sdk/template/field-group-list/field-group-list.component.scss b/tests/assets/components/createAll/override-sdk/template/field-group-list/field-group-list.component.scss
deleted file mode 100644
index b630a267..00000000
--- a/tests/assets/components/createAll/override-sdk/template/field-group-list/field-group-list.component.scss
+++ /dev/null
@@ -1,12 +0,0 @@
-.psdk-details-fields-label {
- color: rgba(0, 0, 0, 0.54);
- margin: 8px 0px;
-}
-
-.psdk-grid-filter {
- display: grid;
- grid-template-columns: repeat(2, minmax(0, 1fr));
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/field-group-list/field-group-list.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/field-group-list/field-group-list.component.spec.ts
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/template/field-group-list/field-group-list.component.ts b/tests/assets/components/createAll/override-sdk/template/field-group-list/field-group-list.component.ts
deleted file mode 100644
index 01313b8f..00000000
--- a/tests/assets/components/createAll/override-sdk/template/field-group-list/field-group-list.component.ts
+++ /dev/null
@@ -1,22 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { RegionComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-field-group-list',
- templateUrl: './field-group-list.component.html',
- styleUrls: ['./field-group-list.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => RegionComponent)]
-})
-export class FieldGroupListComponent implements OnInit {
- @Input() item;
- @Input() heading;
- @Input() formGroup$;
-
- fields: any = [];
-
- ngOnInit(): void {}
-
- ngOnChanges() {}
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/field-group-template/field-group-template.component.html b/tests/assets/components/createAll/override-sdk/template/field-group-template/field-group-template.component.html
deleted file mode 100644
index e808504a..00000000
--- a/tests/assets/components/createAll/override-sdk/template/field-group-template/field-group-template.component.html
+++ /dev/null
@@ -1,33 +0,0 @@
-
-
- {{ label$ }}
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/template/field-group-template/field-group-template.component.scss b/tests/assets/components/createAll/override-sdk/template/field-group-template/field-group-template.component.scss
deleted file mode 100644
index 840c1a37..00000000
--- a/tests/assets/components/createAll/override-sdk/template/field-group-template/field-group-template.component.scss
+++ /dev/null
@@ -1,8 +0,0 @@
-.psdk-utility-card-action-svg-icon {
- width: 1.4rem;
-}
-
-.header-div {
- display: flex;
- align-items: center;
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/field-group-template/field-group-template.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/field-group-template/field-group-template.component.spec.ts
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/template/field-group-template/field-group-template.component.ts b/tests/assets/components/createAll/override-sdk/template/field-group-template/field-group-template.component.ts
deleted file mode 100644
index 7ce096a2..00000000
--- a/tests/assets/components/createAll/override-sdk/template/field-group-template/field-group-template.component.ts
+++ /dev/null
@@ -1,157 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { MatButtonModule } from '@angular/material/button';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { FieldGroupUtils } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { RegionComponent } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-@Component({
- selector: 'app-field-group-template',
- templateUrl: './field-group-template.component.html',
- styleUrls: ['./field-group-template.component.scss'],
- standalone: true,
- imports: [CommonModule, MatButtonModule, ComponentMapperComponent, forwardRef(() => RegionComponent)]
-})
-export class FieldGroupTemplateComponent implements OnInit {
- @Input() configProps$: any;
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- PCore$: any;
-
- angularPConnectData: any = {};
- inheritedProps$: Object;
- showLabel$: boolean = true;
- label$: string;
- readonlyMode: boolean;
- contextClass: any;
- referenceList: any;
- pageReference: any;
- heading: any;
- children: any;
- menuIconOverride$: any;
- prevRefLength: number;
- allowAddEdit: boolean;
- fieldHeader: any;
-
- constructor(private angularPConnect: AngularPConnectService, private utils: Utils, private fieldGroupUtils: FieldGroupUtils) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.updateSelf();
-
- let menuIconOverride$ = 'trash';
- if (menuIconOverride$) {
- this.menuIconOverride$ = this.utils.getImageSrc(menuIconOverride$, this.utils.getSDKStaticContentUrl());
- }
- }
-
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- onStateChange() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- ngOnChanges(changes) {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
-
- if (changes && changes.configProps$) {
- const props = changes.configProps$;
- if (props.currentValue !== props.previousValue) {
- this.configProps$ = props.currentValue;
- if (changes?.pConn$?.currentValue) {
- this.pConn$ = changes?.pConn$?.currentValue;
- }
- this.updateSelf();
- }
- }
- }
-
- updateSelf() {
- this.inheritedProps$ = this.pConn$.getInheritedProps();
- this.label$ = this.configProps$['label'];
- this.showLabel$ = this.configProps$['showLabel'];
- // label & showLabel within inheritedProps takes precedence over configProps
- this.label$ = this.inheritedProps$['label'] || this.label$;
- this.showLabel$ = this.inheritedProps$['showLabel'] || this.showLabel$;
-
- this.allowAddEdit = this.configProps$['allowTableEdit'];
-
- const renderMode = this.configProps$['renderMode'];
- const displayMode = this.configProps$['displayMode'];
- this.readonlyMode = renderMode === 'ReadOnly' || displayMode === 'LABELS_LEFT';
- this.contextClass = this.configProps$['contextClass'];
- const lookForChildInConfig = this.configProps$['lookForChildInConfig'];
- this.heading = this.configProps$['heading'] ?? 'Row';
- this.fieldHeader = this.configProps$['fieldHeader'];
- const resolvedList = this.fieldGroupUtils.getReferenceList(this.pConn$);
- this.pageReference = `${this.pConn$.getPageReference()}${resolvedList}`;
- this.pConn$.setReferenceList(resolvedList);
- if (this.readonlyMode) {
- this.pConn$.setInheritedProp('displayMode', 'LABELS_LEFT');
- }
- this.referenceList = this.configProps$['referenceList'];
- if (this.prevRefLength != this.referenceList.length) {
- if (!this.readonlyMode) {
- if (this.referenceList?.length === 0 && this.allowAddEdit !== false) {
- this.addFieldGroupItem();
- }
- }
- let children: any = [];
- this.referenceList?.map((item, index) => {
- children.push({
- id: index,
- name: this.fieldHeader === 'propertyRef' ? this.getDynamicHeader(item, index) : this.getStaticHeader(this.heading, index),
- children: this.fieldGroupUtils.buildView(this.pConn$, index, lookForChildInConfig)
- });
- });
- this.children = children;
- }
- this.prevRefLength = this.referenceList.length;
- }
-
- getStaticHeader = (heading, index) => {
- return `${heading} ${index + 1}`;
- };
-
- getDynamicHeader = (item, index) => {
- if (this.fieldHeader === 'propertyRef' && this.heading && item[this.heading.substring(1)]) {
- return item[this.heading.substring(1)];
- }
- return `Row ${index + 1}`;
- };
-
- addFieldGroupItem() {
- if (this.PCore$?.getPCoreVersion()?.includes('8.7')) {
- this.pConn$.getListActions().insert({ classID: this.contextClass }, this.referenceList.length, this.pageReference);
- } else {
- this.pConn$.getListActions().insert({ classID: this.contextClass }, this.referenceList.length);
- }
- }
-
- deleteFieldGroupItem(index) {
- if (this.PCore$?.getPCoreVersion()?.includes('8.7')) {
- this.pConn$.getListActions().deleteEntry(index, this.pageReference);
- } else {
- this.pConn$.getListActions().deleteEntry(index);
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/field-value-list/field-value-list.component.html b/tests/assets/components/createAll/override-sdk/template/field-value-list/field-value-list.component.html
deleted file mode 100644
index bfd80b82..00000000
--- a/tests/assets/components/createAll/override-sdk/template/field-value-list/field-value-list.component.html
+++ /dev/null
@@ -1,21 +0,0 @@
-
-
{{ label$ }}
-
- {{ value$ || "---" }}
-
-
-
-
-
-
{{ label$ }}
-
- {{ value$ || "---" }}
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/template/field-value-list/field-value-list.component.scss b/tests/assets/components/createAll/override-sdk/template/field-value-list/field-value-list.component.scss
deleted file mode 100644
index 09137f33..00000000
--- a/tests/assets/components/createAll/override-sdk/template/field-value-list/field-value-list.component.scss
+++ /dev/null
@@ -1,18 +0,0 @@
-.psdk-container-labels-left{
- display: grid;
- grid-template-columns: repeat(2, minmax(0, 1fr));
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
- }
- .psdk-value {
- margin: 8px 0px;
- }
- .psdk-value-hf {
- margin: 8px 0px;
- font-weight: 500;
- font-size: 1.25rem;
- }
- .psdk-val-labels-left{
- margin: 8px 0px;
- }
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/template/field-value-list/field-value-list.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/field-value-list/field-value-list.component.spec.ts
deleted file mode 100644
index aa218a8a..00000000
--- a/tests/assets/components/createAll/override-sdk/template/field-value-list/field-value-list.component.spec.ts
+++ /dev/null
@@ -1,23 +0,0 @@
-import { ComponentFixture, TestBed } from '@angular/core/testing';
-
-import { FieldValueListComponent } from './field-value-list.component';
-
-describe('FieldValueListComponent', () => {
- let component: FieldValueListComponent;
- let fixture: ComponentFixture;
-
- beforeEach(async () => {
- await TestBed.configureTestingModule({
- declarations: [ FieldValueListComponent ]
- })
- .compileComponents();
-
- fixture = TestBed.createComponent(FieldValueListComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/field-value-list/field-value-list.component.ts b/tests/assets/components/createAll/override-sdk/template/field-value-list/field-value-list.component.ts
deleted file mode 100644
index 66101759..00000000
--- a/tests/assets/components/createAll/override-sdk/template/field-value-list/field-value-list.component.ts
+++ /dev/null
@@ -1,31 +0,0 @@
-import { CommonModule } from '@angular/common';
-import { Component, OnInit, Input } from '@angular/core';
-
-declare const window: any;
-
-@Component({
- selector: 'app-field-value-list',
- templateUrl: './field-value-list.component.html',
- styleUrls: ['./field-value-list.component.scss'],
- standalone: true,
- imports: [CommonModule]
-})
-export class FieldValueListComponent implements OnInit{
-
- @Input() label$: any;
- @Input() value$: any;
- @Input() displayMode$: any;
- PCore$: any;
-
- angularPConnectData: any = {};
- configProps$: any;
- pConn$: any;
-
- constructor() {}
-
- ngOnInit(): void {}
-
- ngOnChanges() {}
-
- updateSelf() {}
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/list-page/config.json b/tests/assets/components/createAll/override-sdk/template/list-page/config.json
deleted file mode 100644
index 2f288fb7..00000000
--- a/tests/assets/components/createAll/override-sdk/template/list-page/config.json
+++ /dev/null
@@ -1,134 +0,0 @@
-{
- "name": "ListPage",
- "type": "Template",
- "subtype": "PAGE",
- "label": "List page",
- "icon": "Table.svg",
- "hideTemplateEdit": true,
- "hideFromTemplatePicker": true,
- "viewNameLabel": "List page title",
- "properties": [
- {
- "name": "existingOrCustomListView",
- "format": "LISTPAGE",
- "properties": [
- {
- "name": "listviewPicker",
- "format": "LISTVIEWPICKER",
- "visibleFor": ["Existing"]
- },
- {
- "name": "customListPage",
- "format": "CUSTOMLISTPAGE",
- "visibleFor": ["Custom"],
- "properties": [
- {
- "name": "referenceList",
- "label": "Data page",
- "format": "CONTENTPICKERSOURCE"
- },
- {
- "name": "parameters",
- "label": "",
- "format": "PARAMETERS",
- "context": "global"
- },
- {
- "name": "presets",
- "label": "Presets",
- "format": "PRESETPICKER",
- "addTypeList": ["Presets"],
- "properties": [
- {
- "name": "label",
- "label": "Display name",
- "format": "DISPLAYNAME"
- },
- {
- "format": "COMPONENTPICKER",
- "componentsList": [
- { "name": "Table", "description": "Table" },
- { "name": "Gallery", "description": "Gallery" }
- ]
- },
- {
- "format": "CARDDETAILS",
- "visibleFor": ["Gallery"]
- },
- {
- "name": "Columns",
- "label": "Columns",
- "format": "CONTENTPICKER",
- "addTypeList": ["Fields", "Associations"],
- "modifyPanelOverride": "ListField"
- },
- {
- "name": "fillAvailableSpace",
- "label": "Column to take up remaining width",
- "format": "FILLCOLUMNWIDTH"
- },
- {
- "name": "columnFilter",
- "label": "Column filter",
- "format": "COLUMNFILTER"
- },
- {
- "name": "columnSort",
- "label": "Column sort",
- "format": "COLUMNSORT"
- },
- {
- "name": "groupBy",
- "label": "Group By",
- "format": "GROUPBY",
- "visibleFor": ["Table"]
- }
- ]
- },
- {
- "name": "editing",
- "label": "Editing",
- "format": "EDITING"
- },
- {
- "label": "User personalization",
- "format": "GROUP",
- "properties": [
- {
- "name": "personalization",
- "label": "Allow saving custom views",
- "format": "BOOLEAN"
- },
- {
- "name": "grouping",
- "label": "Allow grouping",
- "format": "BOOLEAN"
- },
- {
- "name": "reorderFields",
- "label": "Allow column reordering",
- "format": "BOOLEAN"
- },
- {
- "name": "globalSearch",
- "label": "Allow global search",
- "format": "BOOLEAN"
- },
- {
- "name": "toggleFieldVisibility",
- "label": "Allow user edit column visibility",
- "format": "BOOLEAN"
- },
- {
- "name": "showHeaderIcons",
- "label": "Show column header icons",
- "format": "BOOLEAN"
- }
- ]
- }
- ]
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/list-page/list-page.component.html b/tests/assets/components/createAll/override-sdk/template/list-page/list-page.component.html
deleted file mode 100644
index 2d5b85e5..00000000
--- a/tests/assets/components/createAll/override-sdk/template/list-page/list-page.component.html
+++ /dev/null
@@ -1 +0,0 @@
-
diff --git a/tests/assets/components/createAll/override-sdk/template/list-page/list-page.component.scss b/tests/assets/components/createAll/override-sdk/template/list-page/list-page.component.scss
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/template/list-page/list-page.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/list-page/list-page.component.spec.ts
deleted file mode 100644
index b5f33a0f..00000000
--- a/tests/assets/components/createAll/override-sdk/template/list-page/list-page.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { ListPageComponent } from './list-page.component';
-
-describe('ListPageComponent', () => {
- let component: ListPageComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ ListPageComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(ListPageComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/list-page/list-page.component.ts b/tests/assets/components/createAll/override-sdk/template/list-page/list-page.component.ts
deleted file mode 100644
index add5a125..00000000
--- a/tests/assets/components/createAll/override-sdk/template/list-page/list-page.component.ts
+++ /dev/null
@@ -1,17 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-list-page',
- templateUrl: './list-page.component.html',
- styleUrls: ['./list-page.component.scss'],
- standalone: true,
- imports: [forwardRef(() => ComponentMapperComponent)]
-})
-export class ListPageComponent implements OnInit {
- @Input() pConn$: any;
-
- constructor() {}
-
- ngOnInit(): void {}
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/list-view/config.json b/tests/assets/components/createAll/override-sdk/template/list-view/config.json
deleted file mode 100644
index 0ad63890..00000000
--- a/tests/assets/components/createAll/override-sdk/template/list-view/config.json
+++ /dev/null
@@ -1,117 +0,0 @@
-{
- "name": "ListView",
- "label": "Table",
- "description": "Table Template",
- "type": "Template",
- "subtype": "LIST",
- "icon": "Table.svg",
- "hideTemplatePicker": true,
- "hideFromTemplatePicker": true,
- "viewNameLabel": "View name",
- "properties": [
- {
- "name": "referenceList",
- "label": "Data page",
- "format": "CONTENTPICKERSOURCE"
- },
- {
- "name": "parameters",
- "label": "",
- "format": "PARAMETERS"
- },
- {
- "name": "presets",
- "label": "Presets",
- "format": "PRESETPICKER",
- "addTypeList": ["Presets"],
- "properties": [
- {
- "name": "label",
- "label": "Display name",
- "format": "DISPLAYNAME"
- },
- {
- "format": "COMPONENTPICKER",
- "componentsList": [
- { "name": "Table", "description": "Table" },
- { "name": "Gallery", "description": "Gallery" }
- ]
- },
- {
- "format": "CARDDETAILS",
- "visibleFor": ["Gallery"]
- },
- {
- "name": "Columns",
- "label": "Columns",
- "format": "CONTENTPICKER",
- "addTypeList": ["Fields", "Associations"],
- "hideModifyIcons": false,
- "modifyPanelOverride": "ListField"
- },
- {
- "name": "fillAvailableSpace",
- "label": "Column to take up remaining width",
- "format": "FILLCOLUMNWIDTH"
- },
- {
- "name": "columnFilter",
- "label": "Column filter",
- "format": "COLUMNFILTER"
- },
- {
- "name": "columnSort",
- "label": "Column sort",
- "format": "COLUMNSORT"
- },
- {
- "name": "groupBy",
- "label": "Group By",
- "format": "GROUPBY",
- "visibleFor": ["Table"]
- }
- ]
- },
- {
- "name": "editing",
- "label": "Editing",
- "format": "EDITING"
- },
- {
- "label": "User personalization",
- "format": "GROUP",
- "properties": [
- {
- "name": "personalization",
- "label": "Allow saving custom views",
- "format": "BOOLEAN"
- },
- {
- "name": "grouping",
- "label": "Allow grouping",
- "format": "BOOLEAN"
- },
- {
- "name": "reorderFields",
- "label": "Allow column reordering",
- "format": "BOOLEAN"
- },
- {
- "name": "globalSearch",
- "label": "Allow global search",
- "format": "BOOLEAN"
- },
- {
- "name": "toggleFieldVisibility",
- "label": "Allow user edit column visibility",
- "format": "BOOLEAN"
- },
- {
- "name": "showHeaderIcons",
- "label": "Show column header icons",
- "format": "BOOLEAN"
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/list-view/list-view.component.html b/tests/assets/components/createAll/override-sdk/template/list-view/list-view.component.html
deleted file mode 100644
index e31aa6d3..00000000
--- a/tests/assets/components/createAll/override-sdk/template/list-view/list-view.component.html
+++ /dev/null
@@ -1,244 +0,0 @@
-
-
- Search
-
-
-
-
-
-
-
-
0" mat-table [dataSource]="repeatList$" matSort>
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- {{ dCol.config.label }}
-
- {{ element[dCol.config.name] }}
-
-
-
-
-
-
-
-
- {{ dCol.config.label }}
-
-
-
-
-
No Records Found.
-
-
-
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/template/list-view/list-view.component.scss b/tests/assets/components/createAll/override-sdk/template/list-view/list-view.component.scss
deleted file mode 100644
index b4533dee..00000000
--- a/tests/assets/components/createAll/override-sdk/template/list-view/list-view.component.scss
+++ /dev/null
@@ -1,151 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-table {
- width: 100%;
-}
-
-::ng-deep .mat-sort-header-content {
- white-space: nowrap;
-}
-
-::ng-deep td.mat-mdc-cell {
- white-space: nowrap;
-}
-
-::ng-deep th.mat-mdc-header-cell,
-td.mat-mdc-cell,
-td.mat-mdc-footer-cell {
- padding: 0rem 0.188rem;
-}
-
-::ng-deep .mat-mdc-button {
- padding: 0px;
- text-align: left;
-}
-
-.mat-mdc-icon-button {
- width: fit-content;
-}
-
-.mat-mdc-row .mat-mdc-cell {
- text-align: left;
-}
-
-.psdk-mat-header {
- white-space: nowrap;
- padding-right: 5px;
-}
-
-.psdk-mat-header-button {
- display: inline-grid;
-}
-
-.psdk-mat-header-arrow {
- display: inline-grid;
- vertical-align: middle;
-}
-
-.psdk-mat-header-filter {
- display: inline-grid;
- vertical-align: middle;
-}
-
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-search {
- padding-left: 0.625rem;
-}
-
-.psdk-icon-search {
- vertical-align: sub;
- padding: 0rem 0.125rem;
- min-width: unset;
- width: 1.1rem;
-}
-
-.psdk-outer-div-in-form {
- display: inline-grid;
-}
-
-.psdk-inner-div-in-form {
- height: auto;
- position: relative;
- width: 100%;
- overflow: auto;
- max-height: 550px;
- min-height: auto;
-}
-
-.psdk-list-view-svg-icon {
- width: 1.4rem;
- display: inline-block;
- vertical-align: middle;
- filter: $app-primary-color-filter;
-}
-
-.psdk-filter-svg-icon {
- width: 1rem;
- display: inline-block;
- vertical-align: middle;
- filter: $app-neutral-color-filter;
-}
-
-.psdk-arrow-svg-icon {
- width: 1rem;
- display: inline-block;
- vertical-align: middle;
- filter: $app-neutral-color-filter;
-}
-
-.psdk-filter-popover {
- display: table;
- margin: auto;
- min-width: 100px;
- background-color: white;
- border: 1px solid black;
- border-radius: 10px;
- padding: 20px;
- box-shadow: 0 0 10px 3px #777;
- position: absolute;
- z-index: 99;
-}
-
-.psdk-dialog-background {
- display: flex;
- flex-direction: column;
- justify-content: center;
- align-items: center;
- height: 100%;
- width: 100%;
- background-color: rgba(100, 100, 100, 0.4);
- position: fixed;
- z-index: 999;
- top: 0px;
- left: 0px;
-}
-
-.psdk-modal-file-top {
- display: table;
- margin: auto;
- min-width: 150px;
- background-color: white;
- border: 1px solid black;
- border-radius: 10px;
- padding: 20px;
- box-shadow: 0 0 10px 3px #777;
-}
-
-tr.mat-mdc-row {
- cursor: pointer;
-}
-
-.psdk-no-records {
- height: 56px;
- justify-content: center;
- display: flex;
- align-items: center;
- border: 1px solid lightgray;
- border-top: none;
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/list-view/list-view.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/list-view/list-view.component.spec.ts
deleted file mode 100644
index b45338f0..00000000
--- a/tests/assets/components/createAll/override-sdk/template/list-view/list-view.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { ListViewComponent } from './list-view.component';
-
-describe('ListViewComponent', () => {
- let component: ListViewComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ ListViewComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(ListViewComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/list-view/list-view.component.ts b/tests/assets/components/createAll/override-sdk/template/list-view/list-view.component.ts
deleted file mode 100644
index f95d02b7..00000000
--- a/tests/assets/components/createAll/override-sdk/template/list-view/list-view.component.ts
+++ /dev/null
@@ -1,1013 +0,0 @@
-/* eslint-disable max-classes-per-file */
-import { Component, OnInit, Input, ViewChild, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { MatDatepickerModule } from '@angular/material/datepicker';
-import { MatOptionModule } from '@angular/material/core';
-import { MatSelectModule } from '@angular/material/select';
-import { MatCheckboxModule } from '@angular/material/checkbox';
-import { MatRadioModule } from '@angular/material/radio';
-import { MatIconModule } from '@angular/material/icon';
-import { MatMenuModule } from '@angular/material/menu';
-import { MatButtonModule } from '@angular/material/button';
-import { MatInputModule } from '@angular/material/input';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { MatPaginator, MatPaginatorModule } from '@angular/material/paginator';
-import { MatSort, MatSortModule } from '@angular/material/sort';
-import { MatTableDataSource, MatTableModule } from '@angular/material/table';
-import { DragDropModule, CdkDragDrop, moveItemInArray, CdkDropList, CdkDrag } from '@angular/cdk/drag-drop';
-import { ProgressSpinnerService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-const SELECTION_MODE = { SINGLE: 'single', MULTI: 'multi' };
-
-export class Group {
- level = 0;
- parent: Group;
- expanded = true;
- totalCounts = 0;
- get visible(): boolean {
- return !this.parent || (this.parent.visible && this.parent.expanded);
- }
-}
-
-@Component({
- selector: 'app-list-view',
- templateUrl: './list-view.component.html',
- styleUrls: ['./list-view.component.scss'],
- standalone: true,
- imports: [
- CommonModule,
- MatFormFieldModule,
- MatInputModule,
- MatTableModule,
- MatSortModule,
- DragDropModule,
- CdkDropList,
- CdkDrag,
- MatButtonModule,
- MatMenuModule,
- MatIconModule,
- MatRadioModule,
- MatCheckboxModule,
- MatPaginatorModule,
- MatSelectModule,
- MatOptionModule,
- MatDatepickerModule,
- forwardRef(() => ComponentMapperComponent)
- ]
-})
-export class ListViewComponent implements OnInit {
- @ViewChild(MatPaginator) paginator: MatPaginator;
- @ViewChild(MatSort) sort: MatSort;
-
- @Input() pConn$: any;
- @Input() bInForm$: boolean = false;
- @Input() payload;
-
- PCore$: any;
-
- repeatList$: MatTableDataSource;
- fields$: Array;
-
- displayedColumns$ = Array();
- groupByColumns$: Array = [];
-
- configProps: any;
-
- updatedRefList: any;
-
- repeatListData: Array;
-
- searchIcon$: string;
-
- bShowSearch$: boolean = false;
- bColumnReorder$: boolean = false;
- bGrouping$: boolean = false;
-
- perfFilter: string;
- searchFilter: string;
-
- menuSvgIcon$: string;
- arrowSvgIcon$: string = '';
- arrowDownSvgIcon$: string;
- arrowUpSvgIcon$: string;
-
- filterSvgIcon$: string;
- filterOnSvgIcon$: string;
- groupBySvgIcon$: string;
-
- compareType: string;
- compareRef: string;
- arrowDirection: string = 'down';
-
- filterByColumns: Array = [];
- bShowFilterPopover$: boolean = false;
- bContains$: boolean = true;
- bDateTime$: boolean = false;
-
- filterContainsLabel$: string = '';
- filterContainsType$: string = 'contains';
- filterContainsValue$: any;
-
- bIsDate$: boolean = false;
- bIsDateTime$: boolean = false;
- bIsTime$: boolean = false;
-
- currentFilterRefData: any;
- currentFilterImageEl: any;
-
- arFilterMainButtons$: Array = [];
- arFilterSecondaryButtons$: Array = [];
- selectionMode: string;
- singleSelectionMode: boolean;
- multiSelectionMode: boolean;
- rowID: any;
- response: any;
- compositeKeys: any;
-
- constructor(private psService: ProgressSpinnerService, private utils: Utils) {}
-
- ngOnInit(): void {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
-
- this.configProps = this.pConn$.getConfigProps();
- /** By default, pyGUID is used for Data classes and pyID is for Work classes as row-id/key */
- const defRowID = this.configProps?.referenceType === 'Case' ? 'pyID' : 'pyGUID';
- /** If compositeKeys is defined, use dynamic value, else fallback to pyID or pyGUID. */
- this.compositeKeys = this.configProps?.compositeKeys;
- this.rowID = this.compositeKeys && this.compositeKeys?.length === 1 ? this.compositeKeys[0] : defRowID;
- this.bShowSearch$ = this.utils.getBooleanValue(this.configProps.globalSearch);
- this.bColumnReorder$ = this.utils.getBooleanValue(this.configProps.reorderFields);
- this.bGrouping$ = this.utils.getBooleanValue(this.configProps.grouping);
-
- this.menuSvgIcon$ = this.utils.getImageSrc('more', this.utils.getSDKStaticContentUrl());
- this.arrowDownSvgIcon$ = this.utils.getImageSrc('arrow-down', this.utils.getSDKStaticContentUrl());
- this.arrowUpSvgIcon$ = this.utils.getImageSrc('arrow-up', this.utils.getSDKStaticContentUrl());
-
- this.filterSvgIcon$ = this.utils.getImageSrc('filter', this.utils.getSDKStaticContentUrl());
- this.filterOnSvgIcon$ = this.utils.getImageSrc('filter-on', this.utils.getSDKStaticContentUrl());
- this.groupBySvgIcon$ = this.utils.getImageSrc('row', this.utils.getSDKStaticContentUrl());
-
- this.selectionMode = this.configProps.selectionMode;
-
- this.arFilterMainButtons$.push({ actionID: 'submit', jsAction: 'submit', name: 'Submit' });
- this.arFilterSecondaryButtons$.push({ actionID: 'cancel', jsAction: 'cancel', name: 'Cancel' });
-
- this.searchIcon$ = this.utils.getImageSrc('search', this.utils.getSDKStaticContentUrl());
- this.getListData();
- }
-
- getListData() {
- const componentConfig = this.pConn$.getComponentConfig();
- if (this.configProps) {
- const refList = this.configProps?.referenceList;
-
- // returns a promise
- const workListData = this.PCore$.getDataApiUtils().getData(refList, this.payload);
-
- this.bShowFilterPopover$ = false;
-
- workListData.then((workListJSON: Object) => {
- // don't update these fields until we return from promise
- this.fields$ = this.configProps.presets[0].children[0].children;
- // this is an unresovled version of this.fields$, need unresolved, so can get the property reference
- let columnFields = componentConfig.presets[0].children[0].children;
-
- const tableDataResults = workListJSON['data'].data;
-
- this.displayedColumns$ = this.getDisplayColums(columnFields);
- this.fields$ = this.updateFields(this.fields$, this.displayedColumns$);
- this.response = tableDataResults;
- this.updatedRefList = this.updateData(tableDataResults, this.fields$);
- if (this.selectionMode === SELECTION_MODE.SINGLE && this.updatedRefList?.length > 0) {
- this.displayedColumns$?.unshift('select');
- this.singleSelectionMode = true;
- } else if (this.selectionMode === SELECTION_MODE.MULTI && this.updatedRefList?.length > 0) {
- this.displayedColumns$?.unshift('select');
- this.multiSelectionMode = true;
- }
-
- this.repeatList$ = new MatTableDataSource(this.updatedRefList);
- this.repeatList$.filterPredicate = this.customFilterPredicate.bind(this);
-
- // keeping an original copy to get back after possible sorts, filters and groupBy
- this.repeatListData = this.repeatList$.data.slice();
-
- this.repeatList$.paginator = this.paginator;
- this.repeatList$.sort = this.sort;
- });
- }
- }
-
- ngOnChanges(changes) {
- if (changes && changes.payload) {
- const currentPayloadVal = changes.payload?.currentValue;
- const previousPayloadVal = changes.payload?.previousValue;
- if (currentPayloadVal !== previousPayloadVal) {
- this.getListData();
- }
- }
- }
-
- ngOnDestroy() {}
-
- ngAfterViewInit() {
- // paginator has to exist for this to work,
- // so called after init (paginator drawn)
- // Calls are now in workListData promise
- // this.repeatList$.paginator = this.paginator;
- // this.repeatList$.sort = this.sort;
- }
-
- drop(event: CdkDragDrop>) {
- moveItemInArray(this.displayedColumns$, event.previousIndex, event.currentIndex);
- }
-
- updateFields(arFields, arColumns): Array {
- let arReturn = arFields;
- for (let i in arReturn) {
- arReturn[i].config.name = arColumns[i];
- }
-
- return arReturn;
- }
-
- applySearch(event: Event) {
- const filterValue = (event.target as HTMLInputElement).value;
- this.searchFilter = filterValue.trim().toLowerCase();
-
- if (this.groupByColumns$.length > 0) {
- this.repeatList$.data = this.repeatListData.slice();
- this.repeatList$.filter = this.searchFilter;
- let repeatData = this.repeatList$.sortData(this.repeatList$.filteredData, this.repeatList$.sort);
- this.repeatList$.data = this.addGroups(repeatData, this.groupByColumns$);
-
- this.perfFilter = performance.now().toString();
- this.repeatList$.filter = this.perfFilter;
- } else {
- this.repeatList$.filter = this.searchFilter;
- }
-
- if (this.repeatList$.paginator) {
- this.repeatList$.paginator.firstPage();
- }
- }
-
- fieldOnChange(row) {
- const value = row[this.rowID];
- const reqObj = {};
- if (this.compositeKeys?.length > 1) {
- const index = this.response.findIndex((element) => element[this.rowID] === value);
- const selectedRow = this.response[index];
- this.compositeKeys.forEach((element) => {
- reqObj[element] = selectedRow[element];
- });
- } else {
- reqObj[this.rowID] = value;
- }
- this.pConn$?.getListActions?.()?.setSelectedRows([reqObj]);
- }
-
- onCheckboxClick(row, event) {
- const value = row[this.rowID];
- const checked = event?.checked;
- const reqObj = {};
- if (this.compositeKeys?.length > 1) {
- const index = this.response.findIndex((element) => element[this.rowID] === value);
- const selectedRow = this.response[index];
- this.compositeKeys.forEach((element) => {
- reqObj[element] = selectedRow[element];
- });
- reqObj['$selected'] = checked;
- } else {
- reqObj[this.rowID] = value;
- reqObj['$selected'] = checked;
- }
- this.pConn$?.getListActions()?.setSelectedRows([reqObj]);
- }
-
- rowClick(row) {
- switch (this.configProps.rowClickAction) {
- case 'openAssignment':
- this.psService.sendMessage(true);
- this.openAssignment(row);
- break;
- }
- }
-
- _getIconStyle(level): string {
- let sReturn = '';
- let nLevel = parseInt(level);
- nLevel--;
- nLevel = nLevel * 15;
- sReturn = 'padding-left: ' + nLevel + 'px; vertical-align: middle';
-
- return sReturn;
- }
-
- _getGroupName(fieldName) {
- for (let i in this.fields$) {
- let field = this.fields$[i];
- if (field.config.name == fieldName) {
- return field.config.label;
- }
- }
-
- return '';
- }
-
- _showButton(name, row) {
- let bReturn = false;
- const { pxRefObjectClass, pzInsKey, pxRefObjectKey } = row;
- switch (name) {
- case 'pxTaskLabel':
- if (pxRefObjectClass != '' && pzInsKey != '') {
- bReturn = true;
- }
- break;
- case 'pxRefObjectInsName':
- if (pxRefObjectClass != '' && pxRefObjectKey != '') {
- bReturn = true;
- }
- break;
- }
-
- return bReturn;
- }
-
- _listViewClick(name, value, index) {
- switch (name) {
- case 'pxTaskLabel':
- this.openAssignment(this.repeatList$.data[index]);
- break;
- case 'pxRefObjectInsName':
- this.openWork(this.repeatList$.data[index]);
- break;
- }
- }
-
- compare(a: number | string, b: number | string, isAsc: boolean) {
- return (a < b ? -1 : 1) * (isAsc ? 1 : -1);
- }
-
- _headerSortClick(event, columnData) {
- // images 0 - filter, 1 - arrow, 2 - more
-
- /** Commenting this code for now as it is giving errors not sure if it ever worked */
- // let arrowImage = event.srcElement.getElementsByTagName('img')[1];
- // let arrowAttr = arrowImage.getAttribute('arrow');
-
- // this.clearOutArrows(event, columnData);
-
- // switch (arrowAttr) {
- // case 'up':
- // arrowImage.src = this.arrowDownSvgIcon$;
- // arrowImage.setAttribute('arrow', 'down');
- // break;
- // case 'down':
- // arrowImage.src = '';
- // arrowImage.setAttribute('arrow', 'none');
- // break;
- // default:
- // arrowImage.src = this.arrowUpSvgIcon$;
- // arrowImage.setAttribute('arrow', 'up');
- // break;
- // }
-
- this.compareType = columnData.type;
- this.compareRef = columnData.config.name;
- // this.arrowDirection = arrowImage.getAttribute('arrow');
- this.arrowDirection = this.arrowDirection === 'up' ? 'down' : 'up';
-
- this.filterSortGroupBy();
- }
-
- clearOutArrows(event, columnData) {
- let arImages = event.srcElement.parentElement.getElementsByTagName('img');
-
- for (let theImage of arImages) {
- //let theImage = arImages[i]
- let arrow = theImage.getAttribute('arrow');
- if (arrow) {
- let arrowId = theImage.getAttribute('arrowid');
- if (arrow != 'none' && arrowId != columnData.config.name) {
- theImage.setAttribute('arrow', 'none');
- theImage.src = '';
- }
- }
- }
- }
-
- sortCompare(a, b): number {
- let aValue = a[this.compareRef];
- let bValue = b[this.compareRef];
-
- if (this.compareType == 'Date' || this.compareType == 'DateTime') {
- aValue = this.utils.getSeconds(aValue);
- bValue = this.utils.getSeconds(bValue);
- }
-
- if (this.compareRef == 'pxRefObjectInsName') {
- const prefixX = aValue.split('-');
- const prefixY = bValue.split('-');
- switch (this.arrowDirection) {
- case 'up':
- if (prefixX[0] !== prefixY[0]) {
- if (prefixX[0] < prefixY[0]) return -1;
- if (prefixX[0] > prefixY[0]) return 1;
- return 0;
- }
- return prefixX[1] - prefixY[1];
- break;
- case 'down':
- if (prefixX[0] !== prefixY[0]) {
- if (prefixX[0] > prefixY[0]) return -1;
- if (prefixX[0] < prefixY[0]) return 1;
- return 0;
- }
- return prefixY[1] - prefixX[1];
- break;
- }
- }
-
- switch (this.arrowDirection) {
- case 'up':
- if (aValue < bValue) {
- return -1;
- } else if (aValue > bValue) {
- return 1;
- }
- break;
- case 'down':
- if (aValue > bValue) {
- return -1;
- } else if (aValue < bValue) {
- return 1;
- }
- break;
- }
-
- return 0;
- }
-
- updateFilterDisplay(type) {
- switch (type) {
- case 'Date':
- this.filterContainsType$ = 'notequal';
- this.bContains$ = false;
- this.bDateTime$ = true;
- this.bIsDate$ = true;
- this.bIsDateTime$ = false;
- this.bIsTime$ = false;
- break;
- case 'DateTime':
- this.filterContainsType$ = 'notequal';
- this.bContains$ = false;
- this.bDateTime$ = true;
- this.bIsDate$ = false;
- this.bIsDateTime$ = true;
- this.bIsTime$ = false;
- break;
- case 'Time':
- this.filterContainsType$ = 'notequal';
- this.bContains$ = false;
- this.bDateTime$ = true;
- this.bIsDate$ = false;
- this.bIsDateTime$ = false;
- this.bIsTime$ = true;
- break;
- default:
- this.filterContainsType$ = 'contains';
- this.bContains$ = true;
- this.bDateTime$ = false;
- this.bIsDate$ = false;
- this.bIsDateTime$ = false;
- this.bIsTime$ = false;
- break;
- }
- }
-
- _filter(event, columnData) {
- // add clickAway listener
- window.addEventListener('mouseup', this._clickAway.bind(this));
-
- this.currentFilterRefData = columnData;
- this.filterContainsLabel$ = columnData.config.label;
-
- setTimeout(() => {
- this.updateFilterDisplay(columnData.type);
-
- this.updateFilterVarsWithCurrent(columnData);
-
- this.bShowFilterPopover$ = true;
- });
- }
-
- _clickAway(event: any) {
- var bInPopUp = false;
-
- //run through list of elements in path, if menu not in th path, then want to
- // hide (toggle) the menu
- for (let i in event.path) {
- if (
- event.path[i].className == 'psdk-modal-file-top' ||
- event.path[i].tagName == 'BUTTON' ||
- event.path[i].tagName == 'MAT-OPTION' ||
- event.path[i].tagName == 'MAT-INPUT'
- ) {
- bInPopUp = true;
- break;
- }
- }
- if (!bInPopUp) {
- // this.bShowFilterPopover$ = false;
-
- window.removeEventListener('mouseup', this._clickAway.bind(this));
- }
- }
-
- _filterContainsType(event) {
- this.filterContainsType$ = event.value;
- }
-
- _filterContainsValue(event) {
- this.filterContainsValue$ = event.target.value;
- }
-
- _filterContainsDateValue(event, value) {
- this.filterContainsValue$ = value;
- }
-
- _filterContainsDateTimeValue(event) {
- this.filterContainsValue$ = event.target.value;
- }
-
- _filterContainsTimeValue(event) {
- this.filterContainsValue$ = event.target.value;
- }
-
- _onFilterActionButtonClick(event: any) {
- // modal buttons
- switch (event.action) {
- case 'cancel':
- this.currentFilterRefData = [];
- break;
- case 'submit':
- this.updateFilterWithInfo();
- this.filterSortGroupBy();
-
- break;
- }
-
- this.bShowFilterPopover$ = false;
-
- window.removeEventListener('mouseup', this._clickAway.bind(this));
- }
-
- updateFilterWithInfo() {
- let bFound = false;
- for (let filterObj of this.filterByColumns) {
- if (filterObj['ref'] === this.currentFilterRefData.config.name) {
- filterObj['type'] = this.currentFilterRefData.type;
- filterObj['containsFilter'] = this.filterContainsType$;
- filterObj['containsFilterValue'] = this.filterContainsValue$;
-
- bFound = true;
- break;
- }
- }
-
- if (!bFound) {
- // add in
- let filterObj: any = {};
- filterObj.ref = this.currentFilterRefData.config.name;
- filterObj.type = this.currentFilterRefData.type;
- filterObj.containsFilter = this.filterContainsType$;
- filterObj.containsFilterValue = this.filterContainsValue$;
-
- this.filterByColumns.push(filterObj);
- }
-
- // iterate through filters and update filterOn icon
- for (let filterObj of this.filterByColumns) {
- let containsFilterValue = filterObj['containsFilterValue'];
- let containsFilter = filterObj['containsFilter'];
- let filterRef = filterObj['ref'];
- let filterIndex = this.displayedColumns$.indexOf(filterRef);
- let arFilterImg = document.getElementsByName('filterOnIcon');
- let filterImg: any = arFilterImg[filterIndex];
- if (containsFilterValue == '' && containsFilter != 'null' && containsFilter != 'notnull') {
- // clear icon
- filterImg.src = '';
- } else {
- // show icon
- filterImg.src = this.filterOnSvgIcon$;
- }
- }
- }
-
- updateFilterVarsWithCurrent(columnData) {
- // find current ref, if exists, move data to variable to display
-
- let bFound = false;
- for (let filterObj of this.filterByColumns) {
- if (filterObj['ref'] === this.currentFilterRefData.config.name) {
- this.filterContainsType$ = filterObj['containsFilter'];
- this.filterContainsValue$ = filterObj['containsFilterValue'];
-
- bFound = true;
- break;
- }
- }
-
- if (!bFound) {
- switch (columnData.type) {
- case 'Date':
- case 'DateTime':
- case 'Time':
- this.filterContainsType$ = 'notequal';
- break;
- default:
- this.filterContainsType$ = 'contains';
- break;
- }
-
- this.filterContainsValue$ = '';
- }
- }
-
- filterData(item: any) {
- let bKeep = true;
- for (let filterObj of this.filterByColumns) {
- if (filterObj.containsFilterValue != '' || filterObj.containsFilter == 'null' || filterObj.containsFilter == 'notnull') {
- let value: any;
- let filterValue: any;
-
- switch (filterObj.type) {
- case 'Date':
- case 'DateTime':
- case 'Time':
- value = item[filterObj.ref] != null ?? item[filterObj.ref] != '' ? this.utils.getSeconds(item[filterObj.ref]) : null;
- filterValue =
- filterObj.containsFilterValue != null && filterObj.containsFilterValue != ''
- ? this.utils.getSeconds(filterObj.containsFilterValue)
- : null;
-
- switch (filterObj.containsFilter) {
- case 'notequal':
- // becasue filterValue is in minutes, need to have a range of less than 60 secons
-
- if (value != null && filterValue != null) {
- // get rid of millisecons
- value = value / 1000;
- filterValue = filterValue / 1000;
-
- let diff = value - filterValue;
- if (diff >= 0 && diff < 60) {
- bKeep = false;
- }
- }
-
- break;
- case 'after':
- if (value < filterValue) {
- bKeep = false;
- }
- break;
- case 'before':
- if (value > filterValue) {
- bKeep = false;
- }
- break;
- case 'null':
- if (value != null) {
- bKeep = false;
- }
- break;
- case 'notnull':
- if (value == null) {
- bKeep = false;
- }
- break;
- }
- break;
- default:
- value = item[filterObj.ref].toLowerCase();
- filterValue = filterObj.containsFilterValue.toLowerCase();
-
- switch (filterObj.containsFilter) {
- case 'contains':
- if (value.indexOf(filterValue) < 0) {
- bKeep = false;
- }
- break;
- case 'equals':
- if (value != filterValue) {
- bKeep = false;
- }
- break;
- case 'startswith':
- if (value.indexOf(filterValue) != 0) {
- bKeep = false;
- }
- break;
- }
-
- break;
- }
- }
-
- // if don't keep stop filtering
- if (!bKeep) {
- break;
- }
- }
-
- return bKeep;
- }
-
- filterSortGroupBy() {
- // get original data set
- let theData = this.repeatListData.slice();
-
- // last filter config data is global
- theData = theData.filter(this.filterData.bind(this));
-
- // last sort config data is global
- theData.sort(this.sortCompare.bind(this));
-
- let reGroupData = this.addGroups(theData, this.groupByColumns$);
-
- this.repeatList$.data = [];
- this.repeatList$.data.push(...reGroupData);
-
- if (this.searchFilter && this.searchFilter != '') {
- this.repeatList$.filter = this.searchFilter;
- } else {
- this.perfFilter = performance.now().toString();
- this.repeatList$.filter = this.perfFilter;
- }
- this.repeatList$.filter = '';
-
- if (this.repeatList$.paginator) {
- this.repeatList$.paginator.firstPage();
- }
- }
-
- //
- // Grouping code inspired by this example
- // https://stackblitz.com/edit/angular-material-table-row-grouping
- //
-
- _showUnGroupBy(columnData): boolean {
- for (let val of this.groupByColumns$) {
- if (val == columnData.config.name) {
- return true;
- }
- }
-
- return false;
- }
-
- _groupBy(event, columnData) {
- this.checkGroupByColumn(columnData.config.name, true);
-
- this.filterSortGroupBy();
- }
-
- _unGroupBy(event, columnData) {
- //event.stopPropagation();
- this.checkGroupByColumn(columnData.config.name, false);
-
- this.filterSortGroupBy();
- }
-
- checkGroupByColumn(field, add) {
- let found = null;
- for (const column of this.groupByColumns$) {
- if (column === field) {
- found = this.groupByColumns$.indexOf(column, 0);
- }
- }
- if (found != null && found >= 0) {
- if (!add) {
- this.groupByColumns$.splice(found, 1);
- }
- } else {
- if (add) {
- this.groupByColumns$.push(field);
- }
- }
- }
-
- addGroups(data: Array, groupByColumns: Array): Array {
- const rootGroup = new Group();
- rootGroup.expanded = true;
- return this.getSublevel(data, 0, groupByColumns, rootGroup);
- }
-
- getSublevel(data: Array, level: number, groupByColumns: Array, parent: Group): Array {
- if (level >= groupByColumns.length) {
- return data;
- }
- const groups = this.uniqueBy(
- data.map((row) => {
- const result = new Group();
- result.level = level + 1;
- result.parent = parent;
- for (let i = 0; i <= level; i++) {
- result[groupByColumns[i]] = row[groupByColumns[i]];
- }
- return result;
- }),
- JSON.stringify
- );
-
- const currentColumn = groupByColumns[level];
- let subGroups = [];
- groups.forEach((group) => {
- const rowsInGroup = data.filter((row) => group[currentColumn] === row[currentColumn]);
- group.totalCounts = rowsInGroup.length;
- const subGroup = this.getSublevel(rowsInGroup, level + 1, groupByColumns, group);
- subGroup.unshift(group);
- subGroups = subGroups.concat(subGroup);
- });
- return subGroups;
- }
-
- uniqueBy(a, key) {
- const seen = {};
- return a.filter((item) => {
- const k = key(item);
- // eslint-disable-next-line no-return-assign, no-prototype-builtins
- return seen.hasOwnProperty(k) ? false : (seen[k] = true);
- });
- }
-
- isGroup(index, item): boolean {
- return item.level;
- }
-
- _groupHeaderClick(row) {
- row.expanded = !row.expanded;
- //this.repeatList$.filter = "";
- this.perfFilter = performance.now().toString();
- this.repeatList$.filter = this.perfFilter;
- }
-
- // below is for grid row grouping
- customFilterPredicate(data: any | Group, filter: string): boolean {
- return data instanceof Group ? data.visible : this.getDataRowVisibleWithFilter(data, filter);
- }
-
- getDataRowVisible(data: any): boolean {
- const groupRows = this.repeatList$.data.filter((row) => {
- if (!(row instanceof Group)) {
- return false;
- }
- let match = true;
- this.groupByColumns$.forEach((column) => {
- if (!row[column] || !data[column] || row[column] !== data[column]) {
- match = false;
- }
- });
- return match;
- });
-
- if (groupRows.length === 0) {
- return true;
- }
- const parent = groupRows[0] as Group;
- return parent.visible && parent.expanded;
- }
-
- getDataRowVisibleWithFilter(data, filter) {
- // fist check if row is visible with grouping
- let bVisible = this.getDataRowVisible(data);
-
- if (bVisible && filter && filter != '' && filter != this.perfFilter) {
- // now check if row is filtered.
-
- // assume not there unless we find it
- bVisible = false;
- for (let col of this.displayedColumns$) {
- // filter is lower case
- if (data[col] && data[col].toString().toLowerCase().indexOf(filter) >= 0) {
- bVisible = true;
- break;
- }
- }
- }
-
- return bVisible;
- }
-
- updateData(listData: Array, fieldData: Array): Array {
- let returnList: Array = new Array();
- for (let row in listData) {
- // copy
- let rowData = JSON.parse(JSON.stringify(listData[row]));
-
- for (let field in fieldData) {
- let config = fieldData[field].config;
- let fieldName;
- let formattedDate;
- let myFormat;
-
- switch (fieldData[field].type) {
- case 'Date':
- fieldName = config.name;
- myFormat = config.formatter;
- if (!myFormat) {
- myFormat = 'Date';
- }
- formattedDate = this.utils.generateDate(rowData[fieldName], myFormat);
-
- rowData[fieldName] = formattedDate;
- break;
- case 'DateTime':
- fieldName = config.name;
- myFormat = config.formatter;
- if (!myFormat) {
- myFormat = 'DateTime-Long';
- }
- formattedDate = this.utils.generateDateTime(rowData[fieldName], myFormat);
-
- rowData[fieldName] = formattedDate;
- break;
- }
- }
-
- returnList.push(rowData);
- }
-
- return returnList;
- }
-
- openAssignment(row) {
- const { pxRefObjectClass, pzInsKey } = row;
- let sTarget = this.pConn$.getContainerName();
- let options = { containerName: sTarget };
- this.pConn$.getActionsApi().openAssignment(pzInsKey, pxRefObjectClass, options);
- }
-
- openWork(row) {
- const { pxRefObjectClass, pxRefObjectKey } = row;
-
- if (pxRefObjectClass != '' && pxRefObjectKey != '') {
- this.pConn$.getActionsApi().openWorkByHandle(pxRefObjectKey, pxRefObjectClass);
- }
- }
-
- initializeData(data) {
- data.forEach((item, idx) => {
- item.__original_index = idx;
- item.__level = 1;
- });
-
- return data;
- }
-
- getType(field) {
- const { config = {}, type } = field;
- const { formatType } = config;
- if (formatType === 'datetime' || formatType === 'date') {
- // currently cosmos has only support for date ... it also need to support dateTime
- return 'date';
- }
-
- return type.toLowerCase();
- }
-
- initializeColumns(fields = []) {
- return fields.map((field, originalColIndex) => ({
- ...field,
- type: this.getType(field),
- name: field.config.value.substring(4),
- label: field.config.label.substring(3),
- id: originalColIndex,
- groupingEnabled: true,
- grouped: false,
- minWidth: 50,
- cellRenderer: this.getType(field) === 'text' ? null : field.type,
- filter: true
- }));
- }
-
- getDisplayColums(fields = []) {
- let arReturn = fields.map((field, colIndex) => {
- let theField = field.config.value.substring(field.config.value.indexOf(' ') + 1);
- if (theField.indexOf('.') == 0) {
- theField = theField.substring(1);
- }
-
- return theField;
- });
- return arReturn;
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/multi-reference-readonly/multi-reference-readonly.component.html b/tests/assets/components/createAll/override-sdk/template/multi-reference-readonly/multi-reference-readonly.component.html
deleted file mode 100644
index 289ff244..00000000
--- a/tests/assets/components/createAll/override-sdk/template/multi-reference-readonly/multi-reference-readonly.component.html
+++ /dev/null
@@ -1,4 +0,0 @@
-
-
{{ label }}
-
-
diff --git a/tests/assets/components/createAll/override-sdk/template/multi-reference-readonly/multi-reference-readonly.component.scss b/tests/assets/components/createAll/override-sdk/template/multi-reference-readonly/multi-reference-readonly.component.scss
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/template/multi-reference-readonly/multi-reference-readonly.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/multi-reference-readonly/multi-reference-readonly.component.spec.ts
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/template/multi-reference-readonly/multi-reference-readonly.component.ts b/tests/assets/components/createAll/override-sdk/template/multi-reference-readonly/multi-reference-readonly.component.ts
deleted file mode 100644
index 771098f6..00000000
--- a/tests/assets/components/createAll/override-sdk/template/multi-reference-readonly/multi-reference-readonly.component.ts
+++ /dev/null
@@ -1,49 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { FormGroup } from '@angular/forms';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-multi-reference-readonly',
- templateUrl: './multi-reference-readonly.component.html',
- styleUrls: ['./multi-reference-readonly.component.scss'],
- standalone: true,
- imports: [forwardRef(() => ComponentMapperComponent)]
-})
-export class MultiReferenceReadonlyComponent implements OnInit {
- constructor(private angularPConnect: AngularPConnectService) {}
-
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- angularPConnectData: any = {};
- configProps$: any;
- label: string;
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.updateSelf();
- }
-
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- onStateChange() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- this.configProps$ = this.pConn$.getConfigProps();
- this.label = this.configProps$['label'];
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/narrow-wide-form/narrow-wide-form.component.html b/tests/assets/components/createAll/override-sdk/template/narrow-wide-form/narrow-wide-form.component.html
deleted file mode 100644
index a13dbe92..00000000
--- a/tests/assets/components/createAll/override-sdk/template/narrow-wide-form/narrow-wide-form.component.html
+++ /dev/null
@@ -1,16 +0,0 @@
-
diff --git a/tests/assets/components/createAll/override-sdk/template/narrow-wide-form/narrow-wide-form.component.scss b/tests/assets/components/createAll/override-sdk/template/narrow-wide-form/narrow-wide-form.component.scss
deleted file mode 100644
index 6e827e90..00000000
--- a/tests/assets/components/createAll/override-sdk/template/narrow-wide-form/narrow-wide-form.component.scss
+++ /dev/null
@@ -1,24 +0,0 @@
-* {
- box-sizing: border-box;
-}
-
-
-
-.psdk-narrow-wide-column {
- display: flow-root;
- height: 100%;
-}
-
-
-
-.psdk-narrow-column {
- float: left;
- min-width: 30%;
- padding: 0rem 0.3125rem;
-}
-
-.psdk-wide-column {
- float: left;
- width: 70%;
- padding: 0rem 0.3125rem;
-}
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/template/narrow-wide-form/narrow-wide-form.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/narrow-wide-form/narrow-wide-form.component.spec.ts
deleted file mode 100644
index 3caeb91b..00000000
--- a/tests/assets/components/createAll/override-sdk/template/narrow-wide-form/narrow-wide-form.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed } from '@angular/core/testing';
-
-import { NarrowWideFormComponent } from './narrow-wide-form.component';
-
-describe('NarrowWideFormComponent', () => {
- let component: NarrowWideFormComponent;
- let fixture: ComponentFixture;
-
- beforeEach(async () => {
- await TestBed.configureTestingModule({
- declarations: [ NarrowWideFormComponent ]
- })
- .compileComponents();
- });
-
- beforeEach(() => {
- fixture = TestBed.createComponent(NarrowWideFormComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/narrow-wide-form/narrow-wide-form.component.ts b/tests/assets/components/createAll/override-sdk/template/narrow-wide-form/narrow-wide-form.component.ts
deleted file mode 100644
index c615206e..00000000
--- a/tests/assets/components/createAll/override-sdk/template/narrow-wide-form/narrow-wide-form.component.ts
+++ /dev/null
@@ -1,38 +0,0 @@
-import { Component, OnInit, Input, forwardRef, SimpleChanges } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { RegionComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-narrow-wide-form',
- templateUrl: './narrow-wide-form.component.html',
- styleUrls: ['./narrow-wide-form.component.scss'],
- standalone: true,
- imports: [CommonModule, forwardRef(() => RegionComponent)]
-})
-export class NarrowWideFormComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- configProps$: Object;
- arChildren$: Array;
-
- constructor() {}
-
- ngOnInit() {
- this.updateSelf();
- }
-
- ngOnChanges(changes: SimpleChanges): void {
- const { pConn$ } = changes;
-
- if (pConn$.previousValue && pConn$.previousValue !== pConn$.currentValue) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.arChildren$ = this.pConn$.getChildren();
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/one-column-page/config.json b/tests/assets/components/createAll/override-sdk/template/one-column-page/config.json
deleted file mode 100644
index f6896a31..00000000
--- a/tests/assets/components/createAll/override-sdk/template/one-column-page/config.json
+++ /dev/null
@@ -1,17 +0,0 @@
-{
- "name": "OneColumnPage",
- "label": "One column",
- "description": "OneColumn Page Template",
- "type": "Template",
- "subtype": "PAGE",
- "icon": "OneColumnPage.svg",
- "viewNameLabel": "Page title",
- "properties": [
- {
- "name": "A",
- "label": "Region A",
- "format": "CONTENTPICKER",
- "addTypeList": ["Widgets", "Views", "Insights"]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/one-column-page/one-column-page.component.html b/tests/assets/components/createAll/override-sdk/template/one-column-page/one-column-page.component.html
deleted file mode 100644
index 4c7eab4d..00000000
--- a/tests/assets/components/createAll/override-sdk/template/one-column-page/one-column-page.component.html
+++ /dev/null
@@ -1 +0,0 @@
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/template/one-column-page/one-column-page.component.scss b/tests/assets/components/createAll/override-sdk/template/one-column-page/one-column-page.component.scss
deleted file mode 100644
index e69de29b..00000000
diff --git a/tests/assets/components/createAll/override-sdk/template/one-column-page/one-column-page.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/one-column-page/one-column-page.component.spec.ts
deleted file mode 100644
index 57260d1b..00000000
--- a/tests/assets/components/createAll/override-sdk/template/one-column-page/one-column-page.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { OneColumnPageComponent } from './one-column-page.component';
-
-describe('OneColumnPageComponent', () => {
- let component: OneColumnPageComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ OneColumnPageComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(OneColumnPageComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/one-column-page/one-column-page.component.ts b/tests/assets/components/createAll/override-sdk/template/one-column-page/one-column-page.component.ts
deleted file mode 100644
index 565790cc..00000000
--- a/tests/assets/components/createAll/override-sdk/template/one-column-page/one-column-page.component.ts
+++ /dev/null
@@ -1,19 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { FormGroup } from '@angular/forms';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-one-column-page',
- templateUrl: './one-column-page.component.html',
- styleUrls: ['./one-column-page.component.scss'],
- standalone: true,
- imports: [forwardRef(() => ComponentMapperComponent)]
-})
-export class OneColumnPageComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- constructor() {}
-
- ngOnInit(): void {}
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/one-column-tab/one-column-tab.component.html b/tests/assets/components/createAll/override-sdk/template/one-column-tab/one-column-tab.component.html
deleted file mode 100644
index 93327d5d..00000000
--- a/tests/assets/components/createAll/override-sdk/template/one-column-tab/one-column-tab.component.html
+++ /dev/null
@@ -1,9 +0,0 @@
-
-
-
-
-
-
Page Missing: {{ kid.getPConnect().getComponentName() }}
-
-
-
\ No newline at end of file
diff --git a/tests/assets/components/createAll/override-sdk/template/one-column-tab/one-column-tab.component.scss b/tests/assets/components/createAll/override-sdk/template/one-column-tab/one-column-tab.component.scss
deleted file mode 100644
index 522d5ee0..00000000
--- a/tests/assets/components/createAll/override-sdk/template/one-column-tab/one-column-tab.component.scss
+++ /dev/null
@@ -1,9 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-.psdk-one-column-tab {
- background-color: $app-form-color;
- margin-top: 0.5rem;
- margin-bottom: 0.5rem;
- border-radius: 0.3125rem;
- padding: 10px;
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/one-column-tab/one-column-tab.component.ts b/tests/assets/components/createAll/override-sdk/template/one-column-tab/one-column-tab.component.ts
deleted file mode 100644
index def54121..00000000
--- a/tests/assets/components/createAll/override-sdk/template/one-column-tab/one-column-tab.component.ts
+++ /dev/null
@@ -1,40 +0,0 @@
-import { Component, OnInit, Input, forwardRef, OnChanges, SimpleChanges } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { OneColumnComponent } from '@pega/angular-sdk-library';
-import { RegionComponent } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-one-column-tab',
- templateUrl: './one-column-tab.component.html',
- styleUrls: ['./one-column-tab.component.scss'],
- standalone: true,
- imports: [CommonModule, OneColumnComponent, RegionComponent, forwardRef(() => ComponentMapperComponent)]
-})
-export class OneColumnTabComponent implements OnInit, OnChanges {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- configProps$: Object;
- arChildren$: Array;
-
- constructor() {}
-
- ngOnInit(): void {
- this.updateSelf();
- }
-
- ngOnChanges(changes: SimpleChanges): void {
- const { pConn$ } = changes;
-
- if (pConn$.previousValue && pConn$.previousValue !== pConn$.currentValue) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.arChildren$ = this.pConn$.getChildren();
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/one-column/config.json b/tests/assets/components/createAll/override-sdk/template/one-column/config.json
deleted file mode 100644
index 9c53aa62..00000000
--- a/tests/assets/components/createAll/override-sdk/template/one-column/config.json
+++ /dev/null
@@ -1,39 +0,0 @@
-{
- "name": "OneColumn",
- "label": "One column",
- "description": "OneColumn Template",
- "type": "Template",
- "subtype": "FORM",
- "icon": "OneColumn.svg",
- "properties": [
- {
- "name": "A",
- "label": "Region A",
- "format": "CONTENTPICKER"
- },
- {
- "label": "Conditions",
- "format": "GROUP",
- "properties": [
- {
- "name": "required",
- "label": "Required",
- "format": "REQUIRED",
- "saveToReference": true
- },
- {
- "name": "disabled",
- "label": "Disabled",
- "format": "DISABLED",
- "saveToReference": true
- },
- {
- "name": "visibility",
- "label": "Visibility",
- "format": "VISIBILITY",
- "saveToReference": true
- }
- ]
- }
- ]
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/one-column/one-column.component.html b/tests/assets/components/createAll/override-sdk/template/one-column/one-column.component.html
deleted file mode 100644
index 0b955908..00000000
--- a/tests/assets/components/createAll/override-sdk/template/one-column/one-column.component.html
+++ /dev/null
@@ -1,11 +0,0 @@
-
diff --git a/tests/assets/components/createAll/override-sdk/template/one-column/one-column.component.scss b/tests/assets/components/createAll/override-sdk/template/one-column/one-column.component.scss
deleted file mode 100644
index 1236d8ed..00000000
--- a/tests/assets/components/createAll/override-sdk/template/one-column/one-column.component.scss
+++ /dev/null
@@ -1,3 +0,0 @@
-* {
- box-sizing: border-box;
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/one-column/one-column.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/one-column/one-column.component.spec.ts
deleted file mode 100644
index 55bfa270..00000000
--- a/tests/assets/components/createAll/override-sdk/template/one-column/one-column.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { OneColumnComponent } from './one-column.component';
-
-describe('OneColumnComponent', () => {
- let component: OneColumnComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ OneColumnComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(OneColumnComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/one-column/one-column.component.ts b/tests/assets/components/createAll/override-sdk/template/one-column/one-column.component.ts
deleted file mode 100644
index a0aeab3d..00000000
--- a/tests/assets/components/createAll/override-sdk/template/one-column/one-column.component.ts
+++ /dev/null
@@ -1,40 +0,0 @@
-import { Component, OnInit, Input, forwardRef, OnChanges, SimpleChanges } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { CaseCreateStageComponent } from '@pega/angular-sdk-library';
-import { ViewComponent } from '@pega/angular-sdk-library';
-import { RegionComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-one-column',
- templateUrl: './one-column.component.html',
- styleUrls: ['./one-column.component.scss'],
- standalone: true,
- imports: [CommonModule, ViewComponent, CaseCreateStageComponent, forwardRef(() => RegionComponent)]
-})
-export class OneColumnComponent implements OnInit, OnChanges {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- configProps$: Object;
- arChildren$: Array;
-
- constructor() {}
-
- ngOnInit(): void {
- this.updateSelf();
- }
-
- ngOnChanges(changes: SimpleChanges): void {
- const { pConn$ } = changes;
-
- if (pConn$.previousValue && pConn$.previousValue !== pConn$.currentValue) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.arChildren$ = this.pConn$.getChildren();
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/page/page.component.html b/tests/assets/components/createAll/override-sdk/template/page/page.component.html
deleted file mode 100644
index c44437d8..00000000
--- a/tests/assets/components/createAll/override-sdk/template/page/page.component.html
+++ /dev/null
@@ -1,12 +0,0 @@
-
-
{{ title$ }}
-
-
-
-
-
-
-
Page Missing: {{ kid.getPConnect().getComponentName() }}
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/template/page/page.component.scss b/tests/assets/components/createAll/override-sdk/template/page/page.component.scss
deleted file mode 100644
index 541a2eb2..00000000
--- a/tests/assets/components/createAll/override-sdk/template/page/page.component.scss
+++ /dev/null
@@ -1,3 +0,0 @@
-.psdk-page-title {
- padding-left: 0.2rem;
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/page/page.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/page/page.component.spec.ts
deleted file mode 100644
index 07d5966a..00000000
--- a/tests/assets/components/createAll/override-sdk/template/page/page.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PageComponent } from './page.component';
-
-describe('PageComponent', () => {
- let component: PageComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PageComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PageComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/page/page.component.ts b/tests/assets/components/createAll/override-sdk/template/page/page.component.ts
deleted file mode 100644
index d069f735..00000000
--- a/tests/assets/components/createAll/override-sdk/template/page/page.component.ts
+++ /dev/null
@@ -1,63 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { RegionComponent } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-page',
- templateUrl: './page.component.html',
- styleUrls: ['./page.component.scss'],
- standalone: true,
- imports: [CommonModule, RegionComponent, forwardRef(() => ComponentMapperComponent)]
-})
-export class PageComponent implements OnInit {
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
-
- configProps$: Object;
- arChildren$: Array;
- title$: string;
-
- constructor(private angularPConnect: AngularPConnectService) {}
-
- ngOnInit() {
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
-
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.arChildren$ = this.pConn$.getChildren();
-
- this.title$ = this.configProps$['title'];
- let operator = this.configProps$['operator'];
-
- if (operator && operator != '') {
- this.title$ += ', ' + operator;
- }
-
- // when showing a page, similar to updating root, need to cause viewContainer to call "initContainer"
- sessionStorage.setItem('hasViewContainer', 'false');
- }
-
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- onStateChange() {
- // Should always check the bridge to see if the component should update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- // AND removing the "gate" that was put there since shouldComponentUpdate
- // should be the real "gate"
- if (bUpdateSelf) {
- // turn off spinner
- //this.psService.sendMessage(false);
- }
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/promoted-filters/promoted-filters.component.html b/tests/assets/components/createAll/override-sdk/template/promoted-filters/promoted-filters.component.html
deleted file mode 100644
index 1d4b3143..00000000
--- a/tests/assets/components/createAll/override-sdk/template/promoted-filters/promoted-filters.component.html
+++ /dev/null
@@ -1,35 +0,0 @@
-
-
{{ listViewProps.title }}
-
-
-
-
- {{ localizedVal('Clear', localeCategory) }}
-
-
- {{ localizedVal('Search', localeCategory) }}
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/template/promoted-filters/promoted-filters.component.scss b/tests/assets/components/createAll/override-sdk/template/promoted-filters/promoted-filters.component.scss
deleted file mode 100644
index be9bb2d2..00000000
--- a/tests/assets/components/createAll/override-sdk/template/promoted-filters/promoted-filters.component.scss
+++ /dev/null
@@ -1,7 +0,0 @@
-.psdk-grid-filter {
- display: grid;
- grid-template-columns: repeat(2, minmax(0, 1fr));
- column-gap: calc(2 * 0.5rem);
- row-gap: calc(2 * 0.5rem);
- align-items: start;
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/promoted-filters/promoted-filters.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/promoted-filters/promoted-filters.component.spec.ts
deleted file mode 100644
index dbe5ab8c..00000000
--- a/tests/assets/components/createAll/override-sdk/template/promoted-filters/promoted-filters.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { PromotedFiltersComponent } from './promoted-filters.component';
-
-describe('PromotedFiltersComponent', () => {
- let component: PromotedFiltersComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ PromotedFiltersComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(PromotedFiltersComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/promoted-filters/promoted-filters.component.ts b/tests/assets/components/createAll/override-sdk/template/promoted-filters/promoted-filters.component.ts
deleted file mode 100644
index ce1444bd..00000000
--- a/tests/assets/components/createAll/override-sdk/template/promoted-filters/promoted-filters.component.ts
+++ /dev/null
@@ -1,167 +0,0 @@
-import { Component, OnInit, Input, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { MatButtonModule } from '@angular/material/button';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { ListViewComponent } from '@pega/angular-sdk-library';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-const SUPPORTED_TYPES_IN_PROMOTED_FILTERS = [
- 'TextInput',
- 'Percentage',
- 'Email',
- 'Integer',
- 'Decimal',
- 'Checkbox',
- 'DateTime',
- 'Date',
- 'Time',
- 'Text',
- 'TextArea',
- 'Currency',
- 'URL',
- 'RichText'
-];
-
-@Component({
- selector: 'app-promoted-filters',
- templateUrl: './promoted-filters.component.html',
- styleUrls: ['./promoted-filters.component.scss'],
- standalone: true,
- imports: [CommonModule, MatButtonModule, ListViewComponent, forwardRef(() => ComponentMapperComponent)]
-})
-export class PromotedFiltersComponent implements OnInit {
- @Input() viewName;
- @Input() filters;
- @Input() listViewProps;
- @Input() pageClass;
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
- @Input() parameters = {};
-
- angularPConnectData: any = {};
- PCore$: any;
-
- showFilters: boolean;
- localeCategory = 'SimpleTable';
- localizedVal;
- filtersProperties = {};
- showTable;
- transientItemID;
- processedFilters = [];
- payload = {};
-
- constructor(private angularPConnect: AngularPConnectService) {}
-
- ngOnInit(): void {
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
-
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- this.updateSelf();
- }
-
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- onStateChange() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- updateSelf() {
- this.localizedVal = this.PCore$.getLocaleUtils().getLocaleValue;
- this.filters.forEach((filter) => {
- this.filtersProperties[this.PCore$.getAnnotationUtils().getPropertyName(filter.config.value)] = '';
- });
-
- const filtersWithClassID = { ...this.filtersProperties, classID: this.pageClass };
- this.transientItemID = this.pConn$
- .getContainerManager()
- .addTransientItem({ id: this.viewName, data: filtersWithClassID });
- this.processedFilters = [];
- this.filters.map((filter) => {
- const filterClone = { ...filter };
- // convert any field which is not supported to TextInput and delete the placeholder as it may contain placeholder specific to original type.
- if (!SUPPORTED_TYPES_IN_PROMOTED_FILTERS.includes(filterClone.type)) {
- filterClone.type = 'TextInput';
- delete filterClone.config.placeholder;
- }
- filterClone.config.contextName = this.transientItemID;
- filterClone.config.readOnly = false;
- filterClone.config.context = this.transientItemID;
- filterClone.config.localeReference = this.listViewProps.localeReference;
- const c11nEnv = this.PCore$.createPConnect({
- meta: filterClone,
- options: {
- hasForm: true,
- contextName: this.transientItemID
- }
- });
- this.processedFilters.push(c11nEnv);
- });
- this.showFilters = true;
- }
-
- formatPromotedFilters(promotedFilters) {
- return Object.entries(promotedFilters).reduce((acc, [field, value]) => {
- if (value) {
- acc[field] = {
- lhs: {
- field
- },
- comparator: 'EQ',
- rhs: {
- value
- }
- };
- }
- return acc;
- }, {});
- }
-
- isValidInput(input) {
- return Object.values(input).findIndex((v) => v) >= 0;
- }
-
- getFilterData() {
- const changes = this.PCore$.getFormUtils().getChanges(this.transientItemID);
- const formValues = {};
- Object.keys(changes).forEach((key) => {
- if (!['context_data', 'pageInstructions'].includes(key)) {
- formValues[key] = changes[key];
- }
- });
- const promotedFilters = this.formatPromotedFilters(formValues);
- if (this.PCore$.getFormUtils().isFormValid(this.transientItemID) && this.isValidInput(formValues)) {
- this.showTable = true;
- const Query: any = {
- dataViewParameters: this.parameters || {}
- };
-
- if (Object.keys(promotedFilters).length > 0) {
- Query.query = { filter: { filterConditions: promotedFilters } };
- }
- this.payload = Query;
- }
- }
-
- clearFilterData() {
- this.PCore$.getContainerUtils().clearTransientData(this.transientItemID);
- this.showTable = false;
- this.pConn$?.getListActions?.()?.setSelectedRows([]); // Clear the selection (if any made by user)
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/repeating-structures/repeating-structures.component.html b/tests/assets/components/createAll/override-sdk/template/repeating-structures/repeating-structures.component.html
deleted file mode 100644
index 208c5e0b..00000000
--- a/tests/assets/components/createAll/override-sdk/template/repeating-structures/repeating-structures.component.html
+++ /dev/null
@@ -1,21 +0,0 @@
-
-
-
- Search
-
-
-
-
-
- {{ dCol.label }}
- {{ element[dCol.name] }}
-
-
-
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/template/repeating-structures/repeating-structures.component.scss b/tests/assets/components/createAll/override-sdk/template/repeating-structures/repeating-structures.component.scss
deleted file mode 100644
index 6ce527d3..00000000
--- a/tests/assets/components/createAll/override-sdk/template/repeating-structures/repeating-structures.component.scss
+++ /dev/null
@@ -1,17 +0,0 @@
-table {
- width: 100%;
-}
-
-.mat-mdc-row .mat-mdc-cell {
- text-align: left;
-}
-
-.psdk-search {
- padding-left: 0.625rem;
-}
-
-.psdk-icon-search {
- vertical-align: sub;
- padding: 0rem 0.125rem;
- min-width: unset;
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/repeating-structures/repeating-structures.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/repeating-structures/repeating-structures.component.spec.ts
deleted file mode 100644
index 342caa34..00000000
--- a/tests/assets/components/createAll/override-sdk/template/repeating-structures/repeating-structures.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
-
-import { RepeatingStructuresComponent } from './repeating-structures.component';
-
-describe('RepeatingStructuresComponent', () => {
- let component: RepeatingStructuresComponent;
- let fixture: ComponentFixture;
-
- beforeEach(waitForAsync(() => {
- TestBed.configureTestingModule({
- declarations: [ RepeatingStructuresComponent ]
- })
- .compileComponents();
- }));
-
- beforeEach(() => {
- fixture = TestBed.createComponent(RepeatingStructuresComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/repeating-structures/repeating-structures.component.ts b/tests/assets/components/createAll/override-sdk/template/repeating-structures/repeating-structures.component.ts
deleted file mode 100644
index ee1530b1..00000000
--- a/tests/assets/components/createAll/override-sdk/template/repeating-structures/repeating-structures.component.ts
+++ /dev/null
@@ -1,155 +0,0 @@
-import { Component, OnInit, Input, ViewChild } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { MatInputModule } from '@angular/material/input';
-import { MatIconModule } from '@angular/material/icon';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { MatPaginator, MatPaginatorModule } from '@angular/material/paginator';
-import { MatSort, MatSortModule } from '@angular/material/sort';
-import { MatTableDataSource, MatTableModule } from '@angular/material/table';
-import { ProgressSpinnerService } from '@pega/angular-sdk-library';
-import { Utils } from '@pega/angular-sdk-library';
-
-@Component({
- selector: 'app-repeating-structures',
- templateUrl: './repeating-structures.component.html',
- styleUrls: ['./repeating-structures.component.scss'],
- standalone: true,
- imports: [
- CommonModule,
- MatFormFieldModule,
- MatIconModule,
- MatInputModule,
- MatTableModule,
- MatSortModule,
- MatPaginatorModule
- ]
-})
-export class RepeatingStructuresComponent implements OnInit {
- @ViewChild(MatPaginator) paginator: MatPaginator;
- @ViewChild(MatSort) sort: MatSort;
- @Input() pConn$: any;
-
- configProps: any;
- repeatList$: MatTableDataSource;
- fields$: Array;
- displayedColumns$ = Array();
-
- constructor(private psService: ProgressSpinnerService, private utils: Utils) {}
-
- ngOnInit(): void {
- const componentConfig = this.pConn$.getRawMetadata().config || { fields: [] };
- this.configProps = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
- this.fields$ = this.initializeColumns(componentConfig.fields);
-
- const refList = this.configProps.referenceList;
- const tableDataResults = JSON.parse(JSON.stringify(this.pConn$.getValue(refList)));
-
- // update elements like date format
- let updatedRefList = this.updateData(tableDataResults, this.fields$);
-
- this.repeatList$ = new MatTableDataSource(updatedRefList);
- this.displayedColumns$ = this.getDisplayColums(this.fields$);
- this.repeatList$.paginator = this.paginator;
- }
-
- ngOnDestroy() {}
-
- ngAfterViewInit() {
- // paginator has to exist for this to work,
- // so called after init (paginator drawn)
- this.repeatList$.paginator = this.paginator;
- this.repeatList$.sort = this.sort;
- }
-
- applySearch(event: Event) {
- const filterValue = (event.target as HTMLInputElement).value;
- this.repeatList$.filter = filterValue.trim().toLowerCase();
-
- if (this.repeatList$.paginator) {
- this.repeatList$.paginator.firstPage();
- }
- }
-
- rowClick(row) {
- switch (this.configProps.rowClickAction) {
- case 'openAssignment':
- this.psService.sendMessage(true);
- this.openAssignment(row);
- break;
- }
- }
-
- updateData(listData: Array, fieldData: Array): Array {
- let returnList: Array = new Array();
- for (let row in listData) {
- // copy
- let rowData = JSON.parse(JSON.stringify(listData[row]));
-
- for (let field in fieldData) {
- if (fieldData[field].type == 'date') {
- let fieldName = fieldData[field].name;
- let formattedDate = rowData[fieldName];
-
- // format date
- // formattedDate = formattedDate.replace("GMT", "+0000");
- this.utils.generateDateTime(formattedDate, 'MMMM D, YYYY h:mm:ss A');
-
- // update
- rowData[fieldName] = formattedDate;
- }
- }
-
- returnList.push(rowData);
- }
-
- return returnList;
- }
-
- openAssignment(row) {
- const { pxRefObjectClass, pzInsKey } = row;
- let sTarget = this.pConn$.getContainerName();
- let options = { containerName: sTarget };
- this.pConn$
- .getActionsApi()
- .openAssignment(pzInsKey, pxRefObjectClass, options)
- .then(() => {});
- }
-
- initializeData(data) {
- data.forEach((item, idx) => {
- item.__original_index = idx;
- item.__level = 1;
- });
-
- return data;
- }
-
- getType(field) {
- const { config = {}, type } = field;
- const { formatType } = config;
- if (formatType === 'datetime' || formatType === 'date') {
- // currently cosmos has only support for date ... it also need to support dateTime
- return 'date';
- }
- return type.toLowerCase();
- }
-
- initializeColumns(fields = []) {
- return fields.map((field, originalColIndex) => ({
- ...field,
- type: this.getType(field),
- name: field.config.value.substring(4),
- label: field.config.label.substring(3),
- id: originalColIndex,
- groupingEnabled: true,
- grouped: false,
- minWidth: 50,
- cellRenderer: this.getType(field) === 'text' ? null : field.type,
- filter: true
- }));
- }
-
- getDisplayColums(fields = []) {
- return fields.map((field, colIndex) => field.name);
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/simple-table-manual/helpers.ts b/tests/assets/components/createAll/override-sdk/template/simple-table-manual/helpers.ts
deleted file mode 100644
index adf4ceb9..00000000
--- a/tests/assets/components/createAll/override-sdk/template/simple-table-manual/helpers.ts
+++ /dev/null
@@ -1,234 +0,0 @@
-declare var PCore;
-
-export const TABLE_CELL = "SdkRenderer";
-export const DELETE_ICON = "DeleteIcon";
-
-// BUG-615253: Workaround for autosize in table with lazy loading components
-/* istanbul ignore next */
-function getFiledWidth(field, label) {
- let width;
- switch (field.type) {
- case "Time":
- width = 150;
- break;
- case "Date":
- width = 160;
- break;
- case "DateTime":
- width = 205;
- break;
- case "AutoComplete":
- case "TextArea":
- width = 190;
- break;
- case "Currency":
- case "TextInput":
- width = 182;
- break;
- case "Checkbox":
-
- // eslint-disable-next-line no-case-declarations
- const text = document.createElement("span");
- document.body.appendChild(text);
- text.style.fontSize = "13px";
- text.style.position = "absolute";
- text.innerHTML = label;
- width = Math.ceil(text.clientWidth) + 30;
- document.body.removeChild(text);
- break;
- default:
- width = 180;
- }
- return width;
-}
-
-export const getContext = (thePConn) => {
- const contextName = thePConn.getContextName();
- const pageReference = thePConn.getPageReference();
- // 8.7 change = referenceList may now be in top-level of state props,
- // not always in config of state props
- let { referenceList } = thePConn.getStateProps()?.config || thePConn.getStateProps();
- const pageReferenceForRows = referenceList.startsWith(".")
- ? `${pageReference}.${referenceList.substring(1)}`
- : referenceList;
-
- // removing "caseInfo.content" prefix to avoid setting it as a target while preparing pageInstructions
- referenceList = pageReferenceForRows.replace(
- PCore.getConstants().CASE_INFO.CASE_INFO_CONTENT,
- ""
- );
-
- return {
- contextName,
- referenceListStr: referenceList,
- pageReferenceForRows
- };
-};
-
-export const populateRowKey = (rawData) => {
- return rawData.map((row, index) => {
- return { ...row, index };
- });
-};
-
-export const getApiContext = (processedData, pConnect, reorderCB) => {
- return {
- fetchData: () => {
- return new Promise((resolve) => {
- resolve({
- data: processedData,
- filteredRecordCount: processedData.length,
- totalRecordCount: processedData.length
- });
- });
- },
- fetchPersonalizations: () => {
- return Promise.resolve({});
- },
- applyRowReorder: (sourceKey, destinationKey) => {
- // indexes are keys for simple table so, it should work.
- reorderCB();
- return Promise.resolve(
- pConnect
- .getListActions()
- .reorder(parseInt(sourceKey, 10), parseInt(destinationKey, 10))
- );
- }
- };
-};
-
-export const buildMetaForListView = (
- fieldMetadata,
- fields,
- type,
- ruleClass,
- name,
- propertyLabel,
- parameters
-) => {
- return {
- name,
- config: {
- type,
- referenceList: fieldMetadata.datasource.name,
- parameters: parameters ?? fieldMetadata.datasource.parameters,
- personalization: false,
- grouping: true,
- globalSearch: true,
- reorderFields: true,
- toggleFieldVisibility: true,
- personalizationId: "" /* TODO */,
- template: "ListView",
- presets: [
- {
- name: "presets",
- template: "Table",
- config: {},
- children: [
- {
- name: "Columns",
- type: "Region",
- children: fields
- }
- ],
- label: propertyLabel,
- id: "P_" /* TODO */
- }
- ],
- ruleClass
- }
- };
-};
-
-export const buildFieldsForTable = (configFields, fields, showDeleteButton) => {
- const fieldDefs = configFields?.map((field, index) => {
- return {
- type: "text",
- label: fields[index].config.label || fields[index].config.caption,
- fillAvailableSpace: !!field.config.fillAvailableSpace,
- id: index,
- name: field.config.value.substr(4),
- cellRenderer: TABLE_CELL,
- sort: false,
- noContextMenu: true,
- showMenu: false,
- meta: {
- ...field
- },
- // BUG-615253: Workaround for autosize in table with lazy loading components
- width: getFiledWidth(field, fields[index].config.label)
- };
- });
-
- // ONLY add DELETE_ICON to fields when the table is requested as EDITABLE
- if (showDeleteButton) {
- fieldDefs.push({
- type: "text",
- label: "",
- name: DELETE_ICON,
- id: fieldDefs.length,
- cellRenderer: DELETE_ICON,
- sort: false,
- noContextMenu: true,
- showMenu: false,
- // BUG-615253: Workaround for autosize in table with lazy loading components
- width: 46
- });
- }
-
- return fieldDefs;
-};
-
-export const createMetaForTable = (fields, renderMode) => {
- return {
- height: {
- minHeight: "auto",
- fitHeightToElement: "fitHeightToElement",
- deltaAdjustment: "deltaAdjustment",
- autoSize: true
- },
- fieldDefs: fields,
- itemKey: "index",
- grouping: false,
- reorderFields: false,
- reorderItems: renderMode === "Editable",
- dragHandle: renderMode === "Editable",
- globalSearch: false,
- personalization: false,
- toggleFieldVisibility: false,
- toolbar: false,
- footer: false,
- filterExpression: null,
- editing: false,
- timezone: PCore.getEnvironmentInfo().getTimeZone()
- };
-};
-
-/**
- * This method returns a callBack function for Add action.
- * @param {object} pConnect - PConnect object
- * @param {number} index - index of the page list to add
- */
-export const getAddRowCallback = (pConnect, index) => {
- return () => pConnect.getListActions().insert({}, index);
-};
-
-/**
- * This method creates a PConnect object with proper options for Add and Delete actions
- * @param {string} contextName - contextName
- * @param {string} referenceList - referenceList
- * @param {string} pageReference - pageReference
- */
-export const createPConnect = (contextName, referenceList, pageReference) => {
- const options = {
- context: contextName,
- pageReference,
- referenceList
- };
-
- // create PConnect object
- const config = { meta: {}, options };
- const { getPConnect } = PCore.createPConnect(config);
-
- return getPConnect();
-};
diff --git a/tests/assets/components/createAll/override-sdk/template/simple-table-manual/simple-table-manual.component.html b/tests/assets/components/createAll/override-sdk/template/simple-table-manual/simple-table-manual.component.html
deleted file mode 100644
index e6f43f05..00000000
--- a/tests/assets/components/createAll/override-sdk/template/simple-table-manual/simple-table-manual.component.html
+++ /dev/null
@@ -1,164 +0,0 @@
-
-
-
- {{ label }} {{ getResultsText() }}
-
-
-
-
- {{ dCol.config.label }}
-
-
-
-
-
-
-
- Group By
-
-
- Ungroup
-
-
- Filter
-
-
-
-
- {{ element[dCol.config.name] }}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- No Records Found.
-
-
- No Records Found.
-
-
-
- + Add
-
-
-
-
-
diff --git a/tests/assets/components/createAll/override-sdk/template/simple-table-manual/simple-table-manual.component.scss b/tests/assets/components/createAll/override-sdk/template/simple-table-manual/simple-table-manual.component.scss
deleted file mode 100644
index d9be69c2..00000000
--- a/tests/assets/components/createAll/override-sdk/template/simple-table-manual/simple-table-manual.component.scss
+++ /dev/null
@@ -1,185 +0,0 @@
-@import '@pega/angular-sdk-library/_shared/styles.scss';
-
-/* Adapted from list-view.component.scss */
-
-.simple-table-wrapper {
- width: 100%;
- margin-top: 0.5rem;
- margin-bottom: 0.5rem;
-}
-
-table {
- width: 100%;
-}
-
-::ng-deep .mat-sort-header-content {
- white-space: normal;
-}
-
-::ng-deep td.mat-mdc-cell {
- white-space: normal;
-}
-
-::ng-deep th.mat-mdc-header-cell,
-td.mat-mdc-cell,
-td.mat-mdc-footer-cell {
- border-right: 1px solid lightgray;
- padding: 8px !important;
-}
-
-::ng-deep .mat-mdc-button {
- padding: 0px;
- text-align: left;
-}
-
-.mat-mdc-icon-button {
- width: fit-content;
-}
-
-.mat-mdc-row .mat-mdc-cell {
- text-align: left;
-}
-
-.psdk-mat-header {
- white-space: normal;
- padding-right: 5px;
-}
-
-.psdk-mat-header-button {
- display: inline-grid;
-}
-
-.psdk-mat-header-arrow {
- display: inline-grid;
- vertical-align: middle;
-}
-
-.psdk-mat-header-filter {
- display: inline-grid;
- vertical-align: middle;
-}
-
-.psdk-full-width {
- width: 100%;
-}
-
-.psdk-search {
- padding-left: 0.625rem;
-}
-
-.psdk-icon-search {
- vertical-align: sub;
- padding: 0rem 0.125rem;
- min-width: unset;
- width: 1.1rem;
-}
-
-.psdk-outer-div-in-form {
- display: inline-grid;
-}
-
-.psdk-inner-div-in-form {
- height: auto;
- position: relative;
- width: 100%;
- overflow: auto;
- max-height: 550px;
- min-height: auto;
-}
-
-.psdk-list-view-svg-icon {
- width: 1.4rem;
- display: inline-block;
- vertical-align: middle;
- filter: $app-primary-color-filter;
-}
-
-.psdk-filter-svg-icon {
- width: 1rem;
- display: inline-block;
- vertical-align: middle;
- filter: $app-neutral-color-filter;
-}
-
-.psdk-arrow-svg-icon {
- width: 1rem;
- display: inline-block;
- vertical-align: middle;
- filter: $app-neutral-color-filter;
-}
-
-.psdk-filter-popover {
- display: table;
- margin: auto;
- min-width: 100px;
- background-color: white;
- border: 1px solid black;
- border-radius: 10px;
- padding: 20px;
- box-shadow: 0 0 10px 3px #777;
- position: absolute;
- z-index: 99;
-}
-
-.psdk-dialog-background {
- display: flex;
- flex-direction: column;
- justify-content: center;
- align-items: center;
- height: 100%;
- width: 100%;
- background-color: rgba(100, 100, 100, 0.4);
- position: fixed;
- z-index: 999;
- top: 0px;
- left: 0px;
-}
-
-.psdk-modal-file-top {
- display: table;
- margin: auto;
- min-width: 150px;
- background-color: white;
- border: 1px solid black;
- border-radius: 10px;
- padding: 20px;
- box-shadow: 0 0 10px 3px #777;
-}
-
-tr.mat-mdc-row {
- cursor: pointer;
-}
-
-tr.mat-mdc-header-row {
- background: #f5f5f5;
-}
-
-.psdk-data-readonly {
- margin-top: 0.625rem;
- width: 100%;
-}
-
-.psdk-no-records {
- height: 56px;
- justify-content: center;
- display: flex;
- align-items: center;
- border: 1px solid lightgray;
- border-top: none;
- background: white;
-}
-
-.psdk-utility-card-action-svg-icon {
- width: 1.4rem;
-}
-
-.label {
- margin: 8px;
-}
-
-.results-count {
- opacity: 0.7;
- font-size: 0.8rem;
- font-weight: bold;
- margin-inline-start: 0.625rem;
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/simple-table-manual/simple-table-manual.component.spec.ts b/tests/assets/components/createAll/override-sdk/template/simple-table-manual/simple-table-manual.component.spec.ts
deleted file mode 100644
index 1d7d66db..00000000
--- a/tests/assets/components/createAll/override-sdk/template/simple-table-manual/simple-table-manual.component.spec.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { ComponentFixture, TestBed } from '@angular/core/testing';
-
-import { SimpleTableManualComponent } from './simple-table-manual.component';
-
-describe('SimpleTableManualComponent', () => {
- let component: SimpleTableManualComponent;
- let fixture: ComponentFixture;
-
- beforeEach(async () => {
- await TestBed.configureTestingModule({
- declarations: [ SimpleTableManualComponent ]
- })
- .compileComponents();
- });
-
- beforeEach(() => {
- fixture = TestBed.createComponent(SimpleTableManualComponent);
- component = fixture.componentInstance;
- fixture.detectChanges();
- });
-
- it('should create', () => {
- expect(component).toBeTruthy();
- });
-});
diff --git a/tests/assets/components/createAll/override-sdk/template/simple-table-manual/simple-table-manual.component.ts b/tests/assets/components/createAll/override-sdk/template/simple-table-manual/simple-table-manual.component.ts
deleted file mode 100644
index c9e63442..00000000
--- a/tests/assets/components/createAll/override-sdk/template/simple-table-manual/simple-table-manual.component.ts
+++ /dev/null
@@ -1,942 +0,0 @@
-/* eslint-disable max-classes-per-file */
-import { Component, OnInit, Input, ViewChild, forwardRef } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormGroup } from '@angular/forms';
-import { MatButtonModule } from '@angular/material/button';
-import { MatDatepickerModule } from '@angular/material/datepicker';
-import { MatFormFieldModule } from '@angular/material/form-field';
-import { MatInputModule } from '@angular/material/input';
-import { MatMenuModule } from '@angular/material/menu';
-import { MatOptionModule } from '@angular/material/core';
-import { MatSelectModule } from '@angular/material/select';
-import { MatSort, MatSortModule } from '@angular/material/sort';
-import { MatTableDataSource, MatTableModule } from '@angular/material/table';
-import { ComponentMapperComponent } from '@pega/angular-sdk-library';
-import { AngularPConnectService } from '@pega/angular-sdk-library';
-import { DatapageService } from '@pega/angular-sdk-library';
-import { FieldGroupUtils } from '@pega/angular-sdk-library';
-import { getContext, buildFieldsForTable } from './helpers';
-import { Utils } from '@pega/angular-sdk-library';
-
-declare const window: any;
-
-class Group {
- level = 0;
- parent: Group;
- expanded = true;
- totalCounts = 0;
- get visible(): boolean {
- return !this.parent || (this.parent.visible && this.parent.expanded);
- }
-}
-
-@Component({
- selector: 'app-simple-table-manual',
- templateUrl: './simple-table-manual.component.html',
- styleUrls: ['./simple-table-manual.component.scss'],
- standalone: true,
- imports: [
- CommonModule,
- MatTableModule,
- MatButtonModule,
- MatSortModule,
- MatMenuModule,
- MatFormFieldModule,
- MatDatepickerModule,
- MatOptionModule,
- MatSelectModule,
- MatInputModule,
- forwardRef(() => ComponentMapperComponent)
- ]
-})
-export class SimpleTableManualComponent implements OnInit {
- @ViewChild(MatSort) sort: MatSort;
-
- @Input() pConn$: any;
- @Input() formGroup$: FormGroup;
-
- // Used with AngularPConnect
- angularPConnectData: any = {};
- PCore$: any;
- configProps$: any;
- fields$: Array;
-
- bVisible$: boolean = true;
- displayedColumns: Array = [];
- rowData: MatTableDataSource;
- originalData: Array = [];
- processedFields: Array = [];
- fieldDefs: Array = [];
- requestedReadOnlyMode: boolean = false;
- readOnlyMode: boolean = false;
- editableMode: boolean;
- menuIconOverride$: string;
- pageReference: string;
- referenceList: any;
- contextClass: any;
- showAddRowButton: boolean;
- prevRefLength: number;
- elementsData: MatTableDataSource;
- rawFields: any;
- label: string = '';
- searchIcon$: string;
-
- bShowSearch$: boolean = false;
- bColumnReorder$: boolean = false;
- bGrouping$: boolean = false;
-
- perfFilter: string;
- searchFilter: string;
-
- menuSvgIcon$: string;
- arrowSvgIcon$: string = '';
- arrowDownSvgIcon$: string;
- arrowUpSvgIcon$: string;
-
- filterSvgIcon$: string;
- filterOnSvgIcon$: string;
- groupBySvgIcon$: string;
-
- groupByColumns$: Array = [];
- compareType: string;
- compareRef: string;
- arrowDirection: string = 'down';
- filterByColumns: Array = [];
- currentFilterRefData: any;
- filterContainsLabel$: string = '';
- filterContainsType$: string = 'contains';
- filterContainsValue$: any;
- bShowFilterPopover$: boolean = false;
- bContains$: boolean = true;
- bDateTime$: boolean = false;
-
- bIsDate$: boolean = false;
- bIsDateTime$: boolean = false;
- bIsTime$: boolean = false;
- currentFilterImageEl: any;
-
- arFilterMainButtons$: Array = [];
- arFilterSecondaryButtons$: Array = [];
- selectionMode: string;
- singleSelectionMode: boolean;
- multiSelectionMode: boolean;
- rowID: any;
- response: any;
- compositeKeys: any;
-
- constructor(
- private angularPConnect: AngularPConnectService,
- private utils: Utils,
- private dataPageService: DatapageService,
- private fieldGroupUtils: FieldGroupUtils
- ) {}
-
- ngOnInit(): void {
- // First thing in initialization is registering and subscribing to the AngularPConnect service
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
- if (!this.PCore$) {
- this.PCore$ = window.PCore;
- }
- this.configProps$ = this.pConn$.getConfigProps();
- // Then, continue on with other initialization
- this.menuIconOverride$ = this.utils.getImageSrc('trash', this.utils.getSDKStaticContentUrl());
- // call checkAndUpdate when initializing
- this.checkAndUpdate();
- this.filterSvgIcon$ = this.utils.getImageSrc('filter', this.utils.getSDKStaticContentUrl());
- this.filterOnSvgIcon$ = this.utils.getImageSrc('filter-on', this.utils.getSDKStaticContentUrl());
- this.groupBySvgIcon$ = this.utils.getImageSrc('row', this.utils.getSDKStaticContentUrl());
- this.bGrouping$ = this.utils.getBooleanValue(this.configProps$.grouping);
- this.menuSvgIcon$ = this.utils.getImageSrc('more', this.utils.getSDKStaticContentUrl());
-
- this.arFilterMainButtons$.push({ actionID: 'submit', jsAction: 'submit', name: 'Submit' });
- this.arFilterSecondaryButtons$.push({ actionID: 'cancel', jsAction: 'cancel', name: 'Cancel' });
-
- this.searchIcon$ = this.utils.getImageSrc('search', this.utils.getSDKStaticContentUrl());
- }
-
- ngOnDestroy(): void {
- if (this.angularPConnectData.unsubscribeFn) {
- this.angularPConnectData.unsubscribeFn();
- }
- }
-
- checkAndUpdate() {
- // Should always check the bridge to see if the component should
- // update itself (re-render)
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
-
- // ONLY call updateSelf when the component should update
- if (bUpdateSelf) {
- this.updateSelf();
- }
- }
-
- // updateSelf
- updateSelf(): void {
- // moved this from ngOnInit() and call this from there instead...
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
-
- if (this.configProps$['visibility'] != null) {
- // eslint-disable-next-line no-multi-assign
- this.bVisible$ = this.bVisible$ = this.utils.getBooleanValue(this.configProps$['visibility']);
- }
-
- // NOTE: getConfigProps() has each child.config with datasource and value undefined
- // but getRawMetadata() has each child.config with datasource and value showing their unresolved values (ex: "@P thePropName")
- // We need to use the prop name as the "glue" to tie the Angular Material table dataSource, displayColumns and data together.
- // So, in the code below, we'll use the unresolved config.value (but replacing the space with an underscore to keep things happy)
- const rawMetadata = this.pConn$.getRawMetadata();
-
- // Adapted from Nebula
- const {
- label,
- showLabel,
- referenceList = [], // if referenceList not in configProps$, default to empy list
- renderMode,
- children, // destructure children into an array var: "resolvedFields"
- presets,
- allowTableEdit,
- labelProp,
- propertyLabel
- } = this.configProps$;
-
- this.label = labelProp || propertyLabel;
-
- const hideAddRow = allowTableEdit === false ? true : false;
- const hideDeleteRow = allowTableEdit === false ? true : false;
- let { contextClass } = this.configProps$;
- this.referenceList = referenceList;
- if (!contextClass) {
- let listName = this.pConn$.getComponentConfig().referenceList;
- listName = this.PCore$.getAnnotationUtils().getPropertyName(listName);
- contextClass = this.pConn$.getFieldMetadata(listName)?.pageClass;
- }
- this.contextClass = contextClass;
-
- const resolvedFields = children?.[0]?.children || presets?.[0].children?.[0].children;
- // get raw config as @P and other annotations are processed and don't appear in the resolved config.
- // Destructure "raw" children into array var: "rawFields"
- // NOTE: when config.listType == "associated", the property can be found in either
- // config.value (ex: "@P .DeclarantChoice") or
- // config.datasource (ex: "@ASSOCIATED .DeclarantChoice")
- // Neither of these appear in the resolved (this.configProps$)
- const rawConfig = rawMetadata?.config;
- const rawFields = rawConfig?.children?.[0]?.children || rawConfig?.presets?.[0].children?.[0]?.children;
- this.rawFields = rawFields;
- // At this point, fields has resolvedFields and rawFields we can use
-
- // start of from Nebula
- // get context name and referenceList which will be used to prepare config of PConnect
- const { contextName, referenceListStr, pageReferenceForRows } = getContext(this.pConn$);
-
- const resolvedList = this.fieldGroupUtils.getReferenceList(this.pConn$);
- this.pageReference = `${this.pConn$.getPageReference()}${resolvedList}`;
- this.pConn$.setReferenceList(resolvedList);
-
- // This gives up the "properties" we need to map to row/column values later
- // const processedData = populateRowKey(referenceList);
-
- this.requestedReadOnlyMode = renderMode === 'ReadOnly';
- this.readOnlyMode = renderMode === 'ReadOnly';
- this.editableMode = renderMode === 'Editable';
- this.showAddRowButton = !this.readOnlyMode && !hideAddRow;
- const showDeleteButton = !this.readOnlyMode && !hideDeleteRow;
-
- // Nebula has other handling for isReadOnlyMode but has Cosmos-specific code
- // so ignoring that for now...
- // fieldDefs will be an array where each entry will have a "name" which will be the
- // "resolved" property name (that we can use as the colId) though it's not really
- // resolved. The buildFieldsForTable helper just removes the "@P " (which is what
- // Nebula does). It will also have the "label", and "meta" contains the original,
- // unchanged config info. For now, much of the info here is carried over from
- // Nebula and we may not end up using it all.
- this.fieldDefs = buildFieldsForTable(rawFields, resolvedFields, showDeleteButton);
-
- // end of from Nebula
-
- // Here, we use the "name" field in fieldDefs since that has the assoicated property
- // (if one exists for the field). If no "name", use "cellRenderer" (typically get DELETE_ICON)
- // for our columns.
- this.displayedColumns = this.fieldDefs?.map((field) => {
- return field.name ? field.name : field.cellRenderer;
- });
-
- // And now we can process the resolvedFields to add in the "name"
- // from from the fieldDefs. This "name" is the value that
- // we'll share to connect things together in the table.
-
- this.processedFields = [];
-
- this.processedFields = resolvedFields.map((field, i) => {
- field.config['name'] = this.displayedColumns[i]; // .config["value"].replace(/ ./g,"_"); // replace space dot with underscore
- return field;
- });
-
- if (this.prevRefLength !== this.referenceList?.length) {
- if (this.editableMode) {
- this.buildElementsForTable();
- } else {
- this.generateRowsData();
- }
- }
-
- this.prevRefLength = this.referenceList?.length;
-
- // These are the data structures referred to in the html file.
- // These are the relationships that make the table work
- // displayedColumns: key/value pairs where key is order of column and
- // value is the property shown in that column. Ex: 1: "FirstName"
- // processedFields: key/value pairs where each key is order of column
- // and each value is an object of more detailed information about that
- // column.
- // rowData: array of each row's key/value pairs. Inside each row,
- // each key is an entry in displayedColumns: ex: "FirstName": "Charles"
- // Ex: { 1: {config: {label: "First Name", readOnly: true: name: "FirstName"}}, type: "TextInput" }
- // The "type" indicates the type of component that should be used for editing (when editing is enabled)
- //
- // Note that the "property" shown in the column ("FirstName" in the above examples) is what
- // ties the 3 data structures together.
- }
-
- getResultsText() {
- const recordsCount = this.readOnlyMode ? this.rowData?.data.length : this.referenceList?.length;
- return `${recordsCount} result${recordsCount > 1 ? 's' : ''}`;
- }
-
- sortCompare(a, b): number {
- let aValue = a[this.compareRef];
- let bValue = b[this.compareRef];
-
- if (this.compareType == 'Date' || this.compareType == 'DateTime') {
- aValue = this.utils.getSeconds(aValue);
- bValue = this.utils.getSeconds(bValue);
- }
-
- if (this.compareRef == 'pxRefObjectInsName') {
- const prefixX = aValue.split('-');
- const prefixY = bValue.split('-');
- switch (this.arrowDirection) {
- case 'up':
- if (prefixX[0] !== prefixY[0]) {
- if (prefixX[0] < prefixY[0]) return -1;
- if (prefixX[0] > prefixY[0]) return 1;
- return 0;
- }
- return prefixX[1] - prefixY[1];
- break;
- case 'down':
- if (prefixX[0] !== prefixY[0]) {
- if (prefixX[0] > prefixY[0]) return -1;
- if (prefixX[0] < prefixY[0]) return 1;
- return 0;
- }
- return prefixY[1] - prefixX[1];
- break;
- }
- }
-
- switch (this.arrowDirection) {
- case 'up':
- if (aValue < bValue) {
- return -1;
- } else if (aValue > bValue) {
- return 1;
- }
- break;
- case 'down':
- if (aValue > bValue) {
- return -1;
- } else if (aValue < bValue) {
- return 1;
- }
- break;
- }
-
- return 0;
- }
-
- updateFilterDisplay(type) {
- switch (type) {
- case 'Date':
- this.filterContainsType$ = 'notequal';
- this.bContains$ = false;
- this.bDateTime$ = true;
- this.bIsDate$ = true;
- this.bIsDateTime$ = false;
- this.bIsTime$ = false;
- break;
- case 'DateTime':
- this.filterContainsType$ = 'notequal';
- this.bContains$ = false;
- this.bDateTime$ = true;
- this.bIsDate$ = false;
- this.bIsDateTime$ = true;
- this.bIsTime$ = false;
- break;
- case 'Time':
- this.filterContainsType$ = 'notequal';
- this.bContains$ = false;
- this.bDateTime$ = true;
- this.bIsDate$ = false;
- this.bIsDateTime$ = false;
- this.bIsTime$ = true;
- break;
- default:
- this.filterContainsType$ = 'contains';
- this.bContains$ = true;
- this.bDateTime$ = false;
- this.bIsDate$ = false;
- this.bIsDateTime$ = false;
- this.bIsTime$ = false;
- break;
- }
- }
-
- _filter(event, columnData) {
- // add clickAway listener
- window.addEventListener('mouseup', this._clickAway.bind(this));
-
- this.currentFilterRefData = columnData;
- this.filterContainsLabel$ = columnData.config.label;
-
- setTimeout(() => {
- this.updateFilterDisplay(columnData.type);
-
- this.updateFilterVarsWithCurrent(columnData);
-
- this.bShowFilterPopover$ = true;
- });
- }
-
- _clickAway(event: any) {
- var bInPopUp = false;
-
- //run through list of elements in path, if menu not in th path, then want to
- // hide (toggle) the menu
- for (let i in event.path) {
- if (
- event.path[i].className == 'psdk-modal-file-top' ||
- event.path[i].tagName == 'BUTTON' ||
- event.path[i].tagName == 'MAT-OPTION' ||
- event.path[i].tagName == 'MAT-INPUT'
- ) {
- bInPopUp = true;
- break;
- }
- }
- if (!bInPopUp) {
- // this.bShowFilterPopover$ = false;
-
- window.removeEventListener('mouseup', this._clickAway.bind(this));
- }
- }
-
- _filterContainsType(event) {
- this.filterContainsType$ = event.value;
- }
-
- _filterContainsValue(event) {
- this.filterContainsValue$ = event.target.value;
- }
-
- _filterContainsDateValue(event, value) {
- this.filterContainsValue$ = value;
- }
-
- _filterContainsDateTimeValue(event) {
- this.filterContainsValue$ = event.target.value;
- }
-
- _filterContainsTimeValue(event) {
- this.filterContainsValue$ = event.target.value;
- }
-
- _onFilterActionButtonClick(event: any) {
- // modal buttons
- switch (event.action) {
- case 'cancel':
- this.currentFilterRefData = [];
- break;
- case 'submit':
- this.updateFilterWithInfo();
- this.filterSortGroupBy();
-
- break;
- }
-
- this.bShowFilterPopover$ = false;
-
- window.removeEventListener('mouseup', this._clickAway.bind(this));
- }
-
- updateFilterWithInfo() {
- let bFound = false;
- for (let filterObj of this.filterByColumns) {
- if (filterObj['ref'] === this.currentFilterRefData.config.name) {
- filterObj['type'] = this.currentFilterRefData.type;
- filterObj['containsFilter'] = this.filterContainsType$;
- filterObj['containsFilterValue'] = this.filterContainsValue$;
-
- bFound = true;
- break;
- }
- }
-
- if (!bFound) {
- // add in
- let filterObj: any = {};
- filterObj.ref = this.currentFilterRefData.config.name;
- filterObj.type = this.currentFilterRefData.type;
- filterObj.containsFilter = this.filterContainsType$;
- filterObj.containsFilterValue = this.filterContainsValue$;
-
- this.filterByColumns.push(filterObj);
- }
-
- // iterate through filters and update filterOn icon
- for (let filterObj of this.filterByColumns) {
- let containsFilterValue = filterObj['containsFilterValue'];
- let containsFilter = filterObj['containsFilter'];
- let filterRef = filterObj['ref'];
- let filterIndex = this.displayedColumns.indexOf(filterRef);
- let arFilterImg = document.getElementsByName('filterOnIcon');
- let filterImg: any = arFilterImg[filterIndex];
- if (containsFilterValue == '' && containsFilter != 'null' && containsFilter != 'notnull') {
- // clear icon
- filterImg.src = '';
- } else {
- // show icon
- filterImg.src = this.filterOnSvgIcon$;
- }
- }
- }
-
- updateFilterVarsWithCurrent(columnData) {
- // find current ref, if exists, move data to variable to display
-
- let bFound = false;
- for (let filterObj of this.filterByColumns) {
- if (filterObj['ref'] === this.currentFilterRefData.config.name) {
- this.filterContainsType$ = filterObj['containsFilter'];
- this.filterContainsValue$ = filterObj['containsFilterValue'];
-
- bFound = true;
- break;
- }
- }
-
- if (!bFound) {
- switch (columnData.type) {
- case 'Date':
- case 'DateTime':
- case 'Time':
- this.filterContainsType$ = 'notequal';
- break;
- default:
- this.filterContainsType$ = 'contains';
- break;
- }
-
- this.filterContainsValue$ = '';
- }
- }
-
- filterData(item: any) {
- let bKeep = true;
- for (let filterObj of this.filterByColumns) {
- if (filterObj.containsFilterValue != '' || filterObj.containsFilter == 'null' || filterObj.containsFilter == 'notnull') {
- let value: any;
- let filterValue: any;
-
- switch (filterObj.type) {
- case 'Date':
- case 'DateTime':
- case 'Time':
- value = item[filterObj.ref] != null ?? item[filterObj.ref] != '' ? this.utils.getSeconds(item[filterObj.ref]) : null;
- filterValue =
- filterObj.containsFilterValue != null && filterObj.containsFilterValue != ''
- ? this.utils.getSeconds(filterObj.containsFilterValue)
- : null;
-
- switch (filterObj.containsFilter) {
- case 'notequal':
- // becasue filterValue is in minutes, need to have a range of less than 60 secons
-
- if (value != null && filterValue != null) {
- // get rid of millisecons
- value = value / 1000;
- filterValue = filterValue / 1000;
-
- let diff = value - filterValue;
- if (diff >= 0 && diff < 60) {
- bKeep = false;
- }
- }
-
- break;
- case 'after':
- if (value < filterValue) {
- bKeep = false;
- }
- break;
- case 'before':
- if (value > filterValue) {
- bKeep = false;
- }
- break;
- case 'null':
- if (value != null) {
- bKeep = false;
- }
- break;
- case 'notnull':
- if (value == null) {
- bKeep = false;
- }
- break;
- }
- break;
- default:
- value = item[filterObj.ref].toLowerCase();
- filterValue = filterObj.containsFilterValue.toLowerCase();
-
- switch (filterObj.containsFilter) {
- case 'contains':
- if (value.indexOf(filterValue) < 0) {
- bKeep = false;
- }
- break;
- case 'equals':
- if (value != filterValue) {
- bKeep = false;
- }
- break;
- case 'startswith':
- if (value.indexOf(filterValue) != 0) {
- bKeep = false;
- }
- break;
- }
-
- break;
- }
- }
-
- // if don't keep stop filtering
- if (!bKeep) {
- break;
- }
- }
-
- return bKeep;
- }
-
- filterSortGroupBy() {
- let theData = this.originalData.slice();
-
- // last filter config data is global
- theData = theData.filter(this.filterData.bind(this));
-
- // last sort config data is global
- theData.sort(this.sortCompare.bind(this));
- this.rowData.data = theData;
- }
-
- _headerSortClick(event, columnData) {
- // images 0 - filter, 1 - arrow, 2 - more
-
- /** Commenting this code for now as it is giving errors not sure if it ever worked */
- // let arrowImage = event.srcElement.getElementsByTagName('img')[1];
- // let arrowAttr = arrowImage.getAttribute('arrow');
-
- // this.clearOutArrows(event, columnData);
-
- // switch (arrowAttr) {
- // case 'up':
- // arrowImage.src = this.arrowDownSvgIcon$;
- // arrowImage.setAttribute('arrow', 'down');
- // break;
- // case 'down':
- // arrowImage.src = '';
- // arrowImage.setAttribute('arrow', 'none');
- // break;
- // default:
- // arrowImage.src = this.arrowUpSvgIcon$;
- // arrowImage.setAttribute('arrow', 'up');
- // break;
- // }
-
- this.compareType = columnData.type;
- this.compareRef = columnData.config.name;
- // this.arrowDirection = arrowImage.getAttribute('arrow');
- this.arrowDirection = this.arrowDirection === 'up' ? 'down' : 'up';
-
- this.filterSortGroupBy();
- }
-
- _showUnGroupBy(columnData): boolean {
- for (let val of this.groupByColumns$) {
- if (val == columnData.config.name) {
- return true;
- }
- }
-
- return false;
- }
-
- _groupBy(event, columnData) {
- this.checkGroupByColumn(columnData.config.name, true);
-
- this.filterSortGroupBy();
- }
-
- _unGroupBy(event, columnData) {
- //event.stopPropagation();
- this.checkGroupByColumn(columnData.config.name, false);
-
- this.filterSortGroupBy();
- }
-
- checkGroupByColumn(field, add) {
- let found = null;
- for (const column of this.groupByColumns$) {
- if (column === field) {
- found = this.groupByColumns$.indexOf(column, 0);
- }
- }
- if (found != null && found >= 0) {
- if (!add) {
- this.groupByColumns$.splice(found, 1);
- }
- } else {
- if (add) {
- this.groupByColumns$.push(field);
- }
- }
- }
-
- _getGroupName(fieldName) {
- for (let i in this.fields$) {
- let field = this.fields$[i];
- if (field.config.name == fieldName) {
- return field.config.label;
- }
- }
-
- return '';
- }
-
- addGroups(data: Array, groupByColumns: Array): Array {
- const rootGroup = new Group();
- rootGroup.expanded = true;
- return this.getSublevel(data, 0, groupByColumns, rootGroup);
- }
-
- getSublevel(data: Array, level: number, groupByColumns: Array, parent: Group): Array {
- if (level >= groupByColumns.length) {
- return data;
- }
- const groups = this.uniqueBy(
- data.map((row) => {
- const result = new Group();
- result.level = level + 1;
- result.parent = parent;
- for (let i = 0; i <= level; i++) {
- result[groupByColumns[i]] = row[groupByColumns[i]];
- }
- return result;
- }),
- JSON.stringify
- );
-
- const currentColumn = groupByColumns[level];
- let subGroups = [];
- groups.forEach((group) => {
- const rowsInGroup = data.filter((row) => group[currentColumn] === row[currentColumn]);
- group.totalCounts = rowsInGroup.length;
- const subGroup = this.getSublevel(rowsInGroup, level + 1, groupByColumns, group);
- subGroup.unshift(group);
- subGroups = subGroups.concat(subGroup);
- });
- return subGroups;
- }
-
- uniqueBy(a, key) {
- const seen = {};
- return a.filter((item) => {
- const k = key(item);
- // eslint-disable-next-line no-return-assign, no-prototype-builtins
- return seen.hasOwnProperty(k) ? false : (seen[k] = true);
- });
- }
-
- isGroup(index, item): boolean {
- return item.level;
- }
-
- _groupHeaderClick(row) {
- row.expanded = !row.expanded;
- //this.repeatList$.filter = "";
- this.perfFilter = performance.now().toString();
- this.rowData.filter = this.perfFilter;
- }
-
- // below is for grid row grouping
- customFilterPredicate(data: any | Group, filter: string): boolean {
- return data instanceof Group ? data.visible : this.getDataRowVisibleWithFilter(data, filter);
- }
-
- getDataRowVisible(data: any): boolean {
- const groupRows = this.rowData.data.filter((row) => {
- if (!(row instanceof Group)) {
- return false;
- }
- let match = true;
- this.groupByColumns$.forEach((column) => {
- if (!row[column] || !data[column] || row[column] !== data[column]) {
- match = false;
- }
- });
- return match;
- });
-
- if (groupRows.length === 0) {
- return true;
- }
- const parent = groupRows[0] as Group;
- return parent.visible && parent.expanded;
- }
-
- getDataRowVisibleWithFilter(data, filter) {
- // fist check if row is visible with grouping
- let bVisible = this.getDataRowVisible(data);
-
- if (bVisible && filter && filter != '' && filter != this.perfFilter) {
- // now check if row is filtered.
-
- // assume not there unless we find it
- bVisible = false;
- for (let col of this.displayedColumns) {
- // filter is lower case
- if (data[col] && data[col].toString().toLowerCase().indexOf(filter) >= 0) {
- bVisible = true;
- break;
- }
- }
- }
-
- return bVisible;
- }
-
- getDisplayColums(fields = []) {
- let arReturn = fields.map((field, colIndex) => {
- let theField = field.config.value.substring(field.config.value.indexOf(' ') + 1);
- if (theField.indexOf('.') == 0) {
- theField = theField.substring(1);
- }
-
- return theField;
- });
- return arReturn;
- }
-
- _getIconStyle(level): string {
- let sReturn = '';
- let nLevel = parseInt(level);
- nLevel--;
- nLevel = nLevel * 15;
- sReturn = 'padding-left: ' + nLevel + 'px; vertical-align: middle';
-
- return sReturn;
- }
-
- // Callback passed when subscribing to store change
- onStateChange() {
- this.checkAndUpdate();
- }
-
- // return the value that should be shown as the contents for the given row data
- // of the given row field
- getRowValue(inRowData: Object, inColKey: string): any {
- // See what data (if any) we have to display
- const refKeys: Array = inColKey.split('.');
- let valBuilder = inRowData;
- for (var key of refKeys) {
- valBuilder = valBuilder[key];
- }
- return valBuilder;
- }
-
- generateRowsData() {
- const { dataPageName, referenceList } = this.configProps$;
- const context = this.pConn$.getContextName();
- // if dataPageName property value exists then make a datapage fetch call and get the list of data.
- if (dataPageName) {
- this.dataPageService.getDataPageData(dataPageName, context).then((listData) => {
- const data = this.formatRowsData(listData);
- this.originalData = data;
- this.rowData = new MatTableDataSource(data);
- });
- } else {
- // The referenceList prop has the JSON data for each row to be displayed
- // in the table. So, iterate over referenceList to create the dataRows that
- // we're using as the table's dataSource
- const data = this.formatRowsData(referenceList);
- this.originalData = data;
- this.rowData = new MatTableDataSource(data);
- }
- }
-
- formatRowsData(data) {
- return data?.map((item) => {
- return this.displayedColumns.reduce((dataForRow, colKey) => {
- dataForRow[colKey] = this.getRowValue(item, colKey);
- return dataForRow;
- }, {});
- });
- }
-
- addRecord() {
- if (this.PCore$.getPCoreVersion()?.includes('8.7')) {
- this.pConn$.getListActions().insert({ classID: this.contextClass }, this.referenceList.length, this.pageReference);
- } else {
- this.pConn$.getListActions().insert({ classID: this.contextClass }, this.referenceList.length);
- }
- }
-
- deleteRecord(index) {
- if (this.PCore$.getPCoreVersion()?.includes('8.7')) {
- this.pConn$.getListActions().deleteEntry(index, this.pageReference);
- } else {
- this.pConn$.getListActions().deleteEntry(index);
- }
- }
-
- buildElementsForTable() {
- const context = this.pConn$.getContextName();
- const eleData: any = [];
- this.referenceList.forEach((element, index) => {
- const data: any = [];
- this.rawFields?.forEach((item) => {
- const referenceListData = this.fieldGroupUtils.getReferenceList(this.pConn$);
- const isDatapage = referenceListData.startsWith('D_');
- const pageReferenceValue = isDatapage
- ? `${referenceListData}[${index}]`
- : `${this.pConn$.getPageReference()}${referenceListData.substring(referenceListData.lastIndexOf('.'))}[${index}]`;
- const config = {
- meta: item,
- options: {
- context,
- pageReference: pageReferenceValue,
- referenceList: referenceListData,
- hasForm: true
- }
- };
- const view = this.PCore$.createPConnect(config);
- data.push(view);
- });
- eleData.push(data);
- });
- this.elementsData = eleData;
- }
-}
diff --git a/tests/assets/components/createAll/override-sdk/template/simple-table-select/simple-table-select.component.html b/tests/assets/components/createAll/override-sdk/template/simple-table-select/simple-table-select.component.html
deleted file mode 100644
index dc4e2e24..00000000
--- a/tests/assets/components/createAll/override-sdk/template/simple-table-select/simple-table-select.component.html
+++ /dev/null
@@ -1,14 +0,0 @@
-