Remove with Text

Remove GetEngineeringSpcReview
Better error message
EnforceCodeStyleInBuild
NginxFileSystem
Remove Reactors and Working Directory
AppSettings
Delete self contained Thunder Tests
Back to .net8.0
api/v4/InfinityQS
ApiExplorerSettings
Wafer Counter
This commit is contained in:
2024-04-15 13:13:55 -07:00
parent 7e16ee7f98
commit 5c9f0d1aff
974 changed files with 205399 additions and 1385 deletions

View File

@ -0,0 +1,2 @@
export {};
//# sourceMappingURL=interfaces.js.map

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,499 @@
:root {
--ifx-font-family: "Source Sans 3";
font-family: var(--ifx-font-family, sans-serif);
}
/*===============================
= Choices =
===============================*/
.ifx-select-container {
background-color: #FFFFFF;
box-sizing: border-box;
font-family: var(--ifx-font-family);
/*
START Select options: item alignment
*/
/*
END Select options: item alignment
*/
/* clears the 'X' for the input type=search from Internet Explorer */
/* clears the 'X' for the input type=search from Chrome */
/*===== End of Choices ======*/
}
.ifx-select-container.small-select {
height: 36px;
}
.ifx-select-container.medium-select {
height: 40px;
}
.ifx-select-container:hover {
cursor: pointer;
}
.ifx-select-container .ifx-label-wrapper {
font-size: 1rem;
line-height: 1.5rem;
white-space: pre-wrap;
word-wrap: break-word;
overflow-wrap: anywhere;
max-width: 100%;
overflow: hidden;
}
.ifx-select-container .ifx-error-message-wrapper {
color: #CD002F;
font-size: 0.75rem;
line-height: 1rem;
white-space: pre-wrap;
word-wrap: break-word;
overflow-wrap: anywhere;
max-width: 100%;
overflow: hidden;
}
.ifx-select-container .ifx-choices__wrapper {
box-sizing: border-box;
position: relative;
display: flex;
align-items: center;
border: 1px solid #8D8786;
border-radius: 1px;
font-weight: 400;
font-style: normal;
}
.ifx-select-container .ifx-choices__wrapper.small-select {
height: 36px;
line-height: 20px;
padding: 8px 12px;
font-size: 0.875rem;
line-height: 1.25rem;
}
.ifx-select-container .ifx-choices__wrapper.medium-select {
height: 40px;
line-height: 24px;
padding: 8px 16px;
font-size: 1rem;
line-height: 1.5rem;
}
.ifx-select-container .ifx-choices__wrapper.disabled {
background: #EEEDED;
color: #575352;
border-color: #575352;
cursor: not-allowed;
-webkit-user-select: none;
-ms-user-select: none;
user-select: none;
}
.ifx-select-container .ifx-choices__wrapper.error {
border-color: #CD002F;
}
.ifx-select-container .ifx-choices__wrapper:hover:not(.focus, :focus) {
border-color: #575352;
}
.ifx-select-container .ifx-choices__wrapper.active {
border-color: #0A8276 !important;
}
.ifx-select-container .ifx-choices__wrapper.active .ifx-choices__icon-wrapper-up {
display: flex;
align-items: center;
justify-content: center;
padding-left: 8px;
}
.ifx-select-container .ifx-choices__wrapper.active .ifx-choices__icon-wrapper-down {
display: none;
}
.ifx-select-container .ifx-choices__wrapper:focus-visible:not(.active):not(:active) {
outline: none;
}
.ifx-select-container .ifx-choices__wrapper:focus-visible:not(.active):not(:active)::before {
content: "";
position: absolute;
width: calc(100% + 4px);
height: calc(100% + 4px);
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
border: 2px solid #0A8276;
border-radius: 2px;
}
.ifx-select-container .ifx-choices__wrapper:focus:not(.active, :active):not(.disabled)::before {
content: "";
position: absolute;
width: calc(100% + 4px);
height: calc(100% + 4px);
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
.ifx-select-container .ifx-choices__wrapper .ifx-choices__icon-wrapper-up {
display: none;
}
.ifx-select-container .ifx-choices__wrapper .ifx-choices__icon-wrapper-up:hover {
cursor: pointer;
}
.ifx-select-container .ifx-choices__wrapper .ifx-choices__icon-wrapper-down {
display: flex;
align-items: center;
justify-content: center;
padding-left: 8px;
}
.ifx-select-container .ifx-choices__wrapper .ifx-choices__icon-wrapper-down:hover {
cursor: pointer;
}
.ifx-select-container .choices {
width: 100%;
}
.ifx-select-container .choices:focus {
outline: none;
}
.choices .ifx-select-container.is-focused {
outline: none;
}
.ifx-select-container .choices:last-child {
margin-bottom: 0;
}
.ifx-select-container .choices.is-disabled .choices__inner,
.ifx-select-container .choices.is-disabled .choices__input {
background-color: #eaeaea;
cursor: not-allowed;
-webkit-user-select: none;
-ms-user-select: none;
user-select: none;
}
.ifx-select-container .choices.is-disabled .choices__item {
cursor: not-allowed;
color: #575352;
}
.ifx-select-container .choices [hidden] {
display: none !important;
}
.ifx-select-container .choices[data-type*=select-one] {
cursor: pointer;
}
.ifx-select-container .choices[data-type*=select-one] .choices__input {
display: block;
width: 100%;
padding: 8px 16px;
border-bottom: 1px solid #8D8786;
background-color: #ffffff;
margin: 0;
font-style: normal;
font-weight: 400;
}
.ifx-select-container .choices[data-type*=select-one] .choices__input.small-select {
font-size: 0.875rem;
line-height: 1.25rem;
}
.ifx-select-container .choices[data-type*=select-one] .choices__input.medium-select {
font-size: 1rem;
line-height: 1.5rem;
}
.ifx-select-container .choices[data-type*=select-one] .choices__single-button {
background-image: url();
padding: 0;
background-size: 8px;
position: absolute;
top: 50%;
right: 0;
margin-top: -10px;
margin-right: 25px;
height: 20px;
width: 20px;
border-radius: 10em;
opacity: 0.5;
}
.ifx-select-container .choices[data-type*=select-one] .choices__single-button:hover,
.ifx-select-container .choices[data-type*=select-one] .choices__single-button:focus {
opacity: 1;
}
.ifx-select-container .choices[data-type*=select-one] .choices__single-button:focus {
box-shadow: 0px 0px 0px 2px #0A8276;
}
.ifx-select-container .choices[data-type*=select-one] .choices__item[data-value=""] .choices__single-button {
display: none;
}
.ifx-select-container .choices[data-type*=select-one].is-open:after {
margin-top: -7.5px;
}
.ifx-select-container .choices[data-type*=select-one][dir=rtl]:after {
left: 11.5px;
right: auto;
}
.ifx-select-container .choices[data-type*=select-one][dir=rtl] .choices__single-button {
right: auto;
left: 0;
margin-left: 25px;
margin-right: 0;
}
.ifx-select-container .choices[data-type*=select-multiple] {
cursor: pointer;
}
.ifx-select-container .choices[data-type*=select-multiple] .choices__input {
display: block;
width: 100%;
margin: 0;
}
.ifx-select-container .choices[data-type*=select-multiple] .choices__inner,
.ifx-select-container .choices[data-type*=text] .choices__inner {
cursor: text;
}
.ifx-select-container .choices[data-type*=select-multiple] .choices__button,
.ifx-select-container .choices[data-type*=text] .choices__button {
position: relative;
display: inline-block;
margin-top: 0;
margin-right: -4px;
margin-bottom: 0;
margin-left: 8px;
padding-left: 16px;
border-left: 1px solid #0A8276;
background-image: url();
background-size: 8px;
width: 8px;
line-height: 1;
opacity: 0.75;
border-radius: 0;
}
.ifx-select-container .choices[data-type*=select-multiple] .choices__button:hover,
.ifx-select-container .choices[data-type*=select-multiple] .choices__button:focus,
.ifx-select-container .choices[data-type*=text] .choices__button:hover,
.ifx-select-container .choices[data-type*=text] .choices__button:focus {
opacity: 1;
}
.ifx-select-container .choices__inner {
overflow: hidden;
}
.ifx-select-container .is-focused .choices__inner,
.ifx-select-container .is-open .choices__inner {
border-color: #b7b7b7;
}
.ifx-select-container .is-open .choices__inner {
border-radius: 2.5px 2.5px 0 0;
}
.ifx-select-container .is-flipped.is-open .choices__inner {
border-radius: 0 0 2.5px 2.5px;
}
.ifx-select-container .choices__list {
margin: 0;
padding-left: 0;
list-style: none;
}
.ifx-select-container .choices__list--single .choices__item {
width: 100%;
display: flex;
justify-content: space-between;
}
.ifx-select-container .disabled > .choices__list--single .choices__item[data-value=""] {
color: #8D8786;
/* Placeholder font color */
}
.ifx-select-container .choices__list--multiple .choices__item {
display: inline-block;
vertical-align: middle;
border-radius: 20px;
padding: 4px 10px;
font-size: 0.75rem;
line-height: 1rem;
font-weight: 500;
margin-right: 3.75px;
margin-bottom: 3.75px;
background-color: #0A8276;
border: 1px solid #0A8276;
color: #FFFFFF;
word-break: break-all;
box-sizing: border-box;
}
.ifx-select-container .choices__list--multiple .choices__item[data-deletable] {
padding-right: 5px;
}
.ifx-select-container [dir=rtl] .choices__list--multiple .choices__item {
margin-right: 0;
margin-left: 3.75px;
}
.ifx-select-container .choices__list--multiple .choices__item.is-highlighted {
background-color: #EEEDED;
border: 1px solid #0A8276;
}
.ifx-select-container .choices__list--dropdown {
visibility: hidden;
box-sizing: border-box;
position: absolute;
width: 100%;
background-color: #fff;
top: 100%;
margin-top: -1px;
overflow: hidden;
word-break: break-all;
will-change: visibility;
box-shadow: 0px 0px 16px rgba(29, 29, 29, 0.12);
border-radius: 1px;
margin-top: 8px;
z-index: 1000;
left: 0;
}
.ifx-select-container .choices__list--dropdown.is-active {
visibility: visible;
}
.ifx-select-container .is-open .choices__list--dropdown {
border-color: #b7b7b7;
}
.ifx-select-container .is-flipped .choices__list--dropdown {
top: auto;
bottom: 100%;
margin-top: 0;
margin-bottom: -1px;
border-radius: 0.25rem 0.25rem 0 0;
}
.ifx-select-container .choices__list--dropdown .choices__list {
position: relative;
max-height: 300px;
overflow: auto;
-webkit-overflow-scrolling: touch;
will-change: scroll-position;
}
.ifx-select-container .choices__list--dropdown .choices__item {
position: relative;
padding: 8px 16px;
gap: 8px;
align-items: center;
display: flex;
justify-content: space-between;
font-style: normal;
font-weight: 400;
}
.ifx-select-container .choices__list--dropdown .choices__item.small-select {
font-size: 0.875rem;
line-height: 1.25rem;
}
.ifx-select-container .choices__list--dropdown .choices__item.medium-select {
font-size: 1rem;
line-height: 1.5rem;
}
.ifx-select-container .choices__list--dropdown .choices__item.selected {
color: #0A8276;
}
.ifx-select-container [dir=rtl] .choices__list--dropdown .choices__item {
text-align: right;
}
@media (min-width: 640px) {
.ifx-select-container .choices__list--dropdown .choices__item--selectable:after {
font-size: 0.75rem;
line-height: 1rem;
opacity: 0;
position: absolute;
right: 10px;
top: 50%;
transform: translateY(-50%);
}
.ifx-select-container [dir=rtl] .choices__list--dropdown .choices__item--selectable {
text-align: right;
padding-left: 100px;
padding-right: 10px;
}
.ifx-select-container [dir=rtl] .choices__list--dropdown .choices__item--selectable:after {
right: auto;
left: 10px;
}
}
.ifx-select-container .choices__list--dropdown .choices__item--selectable.is-highlighted {
background-color: #EEEDED;
}
.ifx-select-container .choices__list--dropdown .choices__item--selectable.is-highlighted.selected {
color: #0A8276;
}
.ifx-select-container .choices__list--dropdown .choices__item--selectable:hover {
background-color: #EEEDED;
}
.ifx-select-container .choices__list--dropdown .choices__item--selectable:hover.selected {
color: #0A8276;
}
.ifx-select-container .choices__list--dropdown .choices__item--selectable.is-highlighted:after {
opacity: 0.5;
}
.ifx-select-container .choices__item {
cursor: default;
}
.ifx-select-container .choices__item--selectable {
cursor: pointer;
}
.ifx-select-container .choices__item--disabled {
cursor: not-allowed;
-webkit-user-select: none;
-ms-user-select: none;
user-select: none;
opacity: 0.5;
}
.ifx-select-container .choices__heading {
font-weight: 600;
font-size: 0.75rem;
line-height: 1rem;
padding: 10px;
border-bottom: 1px solid #f7f7f7;
color: #1D1D1D;
}
.ifx-select-container .choices__button {
text-indent: -9999px;
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
border: 0;
background-color: transparent;
background-repeat: no-repeat;
background-position: center;
cursor: pointer;
}
.ifx-select-container .choices__button:focus {
outline: none;
}
.ifx-select-container .choices__single-button {
text-indent: -9999px;
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
border: 0;
background-color: transparent;
background-repeat: no-repeat;
background-position: center;
cursor: pointer;
visibility: hidden;
}
.ifx-select-container .choices__single-button:focus {
outline: none;
}
.ifx-select-container .choices__input {
display: inline-block;
vertical-align: baseline;
background-color: #f9f9f9;
font-size: 0.875rem;
line-height: 1.25rem;
margin-bottom: 5px;
border: 0;
border-radius: 0;
max-width: 100%;
}
.ifx-select-container .choices__input--cloned {
background-color: transparent;
}
.ifx-select-container .choices__input::-ms-clear {
display: none;
width: 0;
height: 0;
}
.ifx-select-container .choices__input::-ms-reveal {
display: none;
width: 0;
height: 0;
}
.ifx-select-container .choices__input::-webkit-search-decoration,
.ifx-select-container .choices__input::-webkit-search-cancel-button,
.ifx-select-container .choices__input::-webkit-search-results-button,
.ifx-select-container .choices__input::-webkit-search-results-decoration {
display: none;
}
.ifx-select-container .choices__input:focus {
outline: 0;
}
.ifx-select-container [dir=rtl] .choices__input {
padding-right: 2px;
padding-left: 0;
}
.ifx-select-container .choices__placeholder {
opacity: 0.5;
}

View File

@ -0,0 +1,24 @@
import { newE2EPage } from "@stencil/core/testing";
describe('ifx-select', () => {
it('should render without errors', async () => {
const page = await newE2EPage();
await page.setContent('<ifx-select></ifx-select>');
const element = await page.find('ifx-select');
expect(element).toHaveClass('hydrated');
});
it('should accept properties and reflect them', async () => {
const page = await newE2EPage();
await page.setContent('<ifx-select ifx-label="Test label"></ifx-select>');
const component = await page.find('ifx-select');
const label = await component.getProperty('ifxLabel');
expect(label).toBe('Test label');
});
it('should display error message when ifxError is true', async () => {
const page = await newE2EPage();
await page.setContent('<ifx-select ifx-error="true" ifx-error-message="This is an error"></ifx-select>');
const component = await page.find('ifx-select');
const errorMessage = await component.getProperty('ifxErrorMessage');
expect(errorMessage).toBe('This is an error');
});
});
//# sourceMappingURL=select.e2e.js.map

View File

@ -0,0 +1 @@
{"version":3,"file":"select.e2e.js","sourceRoot":"","sources":["../../../../src/components/select/single-select/select.e2e.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAEnD,QAAQ,CAAC,YAAY,EAAE,GAAG,EAAE;EAE1B,EAAE,CAAC,8BAA8B,EAAE,KAAK,IAAI,EAAE;IAC5C,MAAM,IAAI,GAAG,MAAM,UAAU,EAAE,CAAC;IAChC,MAAM,IAAI,CAAC,UAAU,CAAC,2BAA2B,CAAC,CAAC;IAEnD,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC9C,MAAM,CAAC,OAAO,CAAC,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;EAC1C,CAAC,CAAC,CAAC;EAEH,EAAE,CAAC,2CAA2C,EAAE,KAAK,IAAI,EAAE;IACzD,MAAM,IAAI,GAAG,MAAM,UAAU,EAAE,CAAC;IAChC,MAAM,IAAI,CAAC,UAAU,CAAC,kDAAkD,CAAC,CAAC;IAE1E,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAEhD,MAAM,KAAK,GAAG,MAAM,SAAS,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;IACtD,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;EACnC,CAAC,CAAC,CAAC;EAIH,EAAE,CAAC,oDAAoD,EAAE,KAAK,IAAI,EAAE;IAClE,MAAM,IAAI,GAAG,MAAM,UAAU,EAAE,CAAC;IAChC,MAAM,IAAI,CAAC,UAAU,CAAC,iFAAiF,CAAC,CAAC;IACzG,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAEhD,MAAM,YAAY,GAAG,MAAM,SAAS,CAAC,WAAW,CAAC,iBAAiB,CAAC,CAAC;IACpE,MAAM,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;EAChD,CAAC,CAAC,CAAC;AAIL,CAAC,CAAC,CAAC","sourcesContent":["import { newE2EPage } from '@stencil/core/testing';\n\ndescribe('ifx-select', () => {\n\n it('should render without errors', async () => {\n const page = await newE2EPage();\n await page.setContent('<ifx-select></ifx-select>');\n\n const element = await page.find('ifx-select');\n expect(element).toHaveClass('hydrated');\n });\n\n it('should accept properties and reflect them', async () => {\n const page = await newE2EPage();\n await page.setContent('<ifx-select ifx-label=\"Test label\"></ifx-select>');\n\n const component = await page.find('ifx-select');\n\n const label = await component.getProperty('ifxLabel');\n expect(label).toBe('Test label');\n });\n\n\n\n it('should display error message when ifxError is true', async () => {\n const page = await newE2EPage();\n await page.setContent('<ifx-select ifx-error=\"true\" ifx-error-message=\"This is an error\"></ifx-select>');\n const component = await page.find('ifx-select');\n\n const errorMessage = await component.getProperty('ifxErrorMessage');\n expect(errorMessage).toBe('This is an error');\n });\n\n\n\n});\n"]}

File diff suppressed because it is too large Load Diff

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,138 @@
import { action } from "@storybook/addon-actions";
//use string instead of json format here to avoid ugly formatting in the storybook code snippet
// let options = "[{'value': 'a','label': 'option a','selected': 'false'},{'value': 'b','label': 'option b','selected': 'false'},{'value': 'c','label': 'option c','selected': 'false'}]"
const options = [{
value: "a",
label: "option a",
selected: false
},
{
value: "b",
label: "option b",
selected: false
},
{
value: "c",
label: "option c",
selected: false
}];
export default {
title: 'Components/Select/Single Select',
// tags: ['autodocs'],
args: {
size: "m",
searchEnabled: true,
searchPlaceholderValue: 'Search...',
placeholder: true,
placeholderValue: 'Placeholder',
error: false,
errorMessage: 'Some error',
label: '',
disabled: false,
// type: 'single', //for later implementation
},
argTypes: {
// type: { //for later implementation
// // control: { type: 'radio' },
// control: false,
// },
size: {
options: {
'small (36px)': 's',
'medium (40px)': 'm'
},
control: {
type: 'radio',
},
},
placeholder: {
options: [true, false],
control: { type: 'radio' },
},
placeholderValue: { control: 'text' },
// value: { for later implementation
// control: 'text',
// description: 'Programmatically set the selected value',
// },
error: {
options: [true, false],
control: { type: 'radio' },
},
errorMessage: { control: 'text' },
label: { control: 'text' },
disabled: {
options: [true, false],
control: { type: 'radio' },
},
searchEnabled: {
options: [true, false],
control: { type: 'radio' },
},
searchPlaceholderValue: { control: { type: 'text' } },
options: {
description: 'Takes an array of objects in the following format',
},
ifxSelect: {
action: 'ifxSelect',
description: 'Custom event emitted when item is selected',
table: {
type: {
summary: 'Framework integration',
detail: 'React: onIfxSelect={handleInput}\nVue:@ifxSelect="handleInput"\nAngular:(ifxSelect)="handleInput()"\nVanillaJs:.addEventListener("ifxSelect", (event) => {//handle input});',
},
},
},
},
};
const DefaultTemplate = (args) => {
const template = `<ifx-select
ifx-size='${args.size}'
placeholder='${args.placeholder}'
search-enabled='${args.searchEnabled}'
search-placeholder-value='${args.searchPlaceholderValue}'
ifx-disabled='${args.disabled}'
ifx-error='${args.error}'
ifx-error-message='${args.errorMessage}'
ifx-label='${args.label}'
ifx-placeholder-value='${args.placeholderValue}'
ifx-options='${JSON.stringify(args.options)}' >
</ifx-select>`;
setTimeout(() => {
var _a, _b;
(_a = document.querySelector('ifx-select')) === null || _a === void 0 ? void 0 : _a.addEventListener('ifxSelect', action('ifxSelect'));
(_b = document.querySelector('ifx-select')) === null || _b === void 0 ? void 0 : _b.addEventListener('ifxInput', action('ifxInput'));
}, 0);
return template;
};
export const Single = DefaultTemplate.bind({});
Single.args = {
// type: 'single',
options: options,
};
// export const Text = DefaultTemplate.bind({});
// Text.args = {
// type: 'text',
// name: 'text',
// value: 'Placeholder',
// allowHTML: true,
// delimiter: ',',
// editItems: true,
// maxItemCount: 5,
// };
// export const Text = DefaultTemplate.bind({});
// Text.args = {
// type: 'multiple',
// name: 'multiple',
// choices: 'Choice 1, Choice 2, Choice 3',
// };
// export const SingleWithIcon = DefaultTemplate.bind({});
// SingleWithIcon.args = {
// type: 'single',
// choices: "Choice 1, Choice 2 <ifx-icon icon='check16'></ifx-icon>, Choice 3 <ifx-icon icon='check16'></ifx-icon>",
// };
// export const MultiselectCombobox = DefaultTemplate.bind({});
// MultiselectCombobox.args = {
// type: 'multiple',
// // removeItemButton: true,
// };
//# sourceMappingURL=select.stories.js.map

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,37 @@
/**
* Filter out entries from an object.
*
* @param obj - object to filter.
* @param fn - filter function.
* @returns a new object without the entries satisfying the filter function.
*/
export function filterObject(obj, fn) {
return Object.keys(obj).reduce((accum, property) => {
const value = obj[property];
if (fn(value, property, obj)) {
accum[property] = value;
}
return accum;
}, {});
}
/**
* Check if given parameter is not undefined.
*
* @param value - value to check.
* @returns whether the value is defined.
*/
export function isDefined(value) {
return typeof value !== 'undefined';
}
/**
* Returns the list of values.
*
* @param value - Value or list of values.
* @returns List of values.
*/
export function getValues(value) {
return typeof value !== 'undefined'
? [].concat(typeof value === 'string' ? value.split(',') : value)
: [];
}
//# sourceMappingURL=utils.js.map

View File

@ -0,0 +1 @@
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/components/select/single-select/utils.ts"],"names":[],"mappings":"AAEA;;;;;;GAMG;AACH,MAAM,UAAU,YAAY,CAAC,GAAW,EAAE,EAAkB;EAC1D,OAAO,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE;IACjD,MAAM,KAAK,GAAG,GAAG,CAAC,QAAQ,CAAC,CAAC;IAE5B,IAAI,EAAE,CAAC,KAAK,EAAE,QAAQ,EAAE,GAAG,CAAC,EAAE;MAC5B,KAAK,CAAC,QAAQ,CAAC,GAAG,KAAK,CAAC;KACzB;IAED,OAAO,KAAK,CAAC;EACf,CAAC,EAAE,EAAE,CAAC,CAAC;AACT,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,SAAS,CAAC,KAAU;EAClC,OAAO,OAAO,KAAK,KAAK,WAAW,CAAC;AACtC,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,SAAS,CAAC,KAA6B;EACrD,OAAO,OAAO,KAAK,KAAK,WAAW;IACjC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IACjE,CAAC,CAAC,EAAE,CAAC;AACT,CAAC","sourcesContent":["export type FilterObjectFn = (value: any, key: string | number, obj: object) => boolean;\n\n/**\n * Filter out entries from an object.\n *\n * @param obj - object to filter.\n * @param fn - filter function.\n * @returns a new object without the entries satisfying the filter function.\n */\nexport function filterObject(obj: object, fn: FilterObjectFn): object {\n return Object.keys(obj).reduce((accum, property) => {\n const value = obj[property];\n\n if (fn(value, property, obj)) {\n accum[property] = value;\n }\n\n return accum;\n }, {});\n}\n\n/**\n * Check if given parameter is not undefined.\n *\n * @param value - value to check.\n * @returns whether the value is defined.\n */\nexport function isDefined(value: any): boolean {\n return typeof value !== 'undefined';\n}\n\n/**\n * Returns the list of values.\n *\n * @param value - Value or list of values.\n * @returns List of values.\n */\nexport function getValues(value: string | Array<string>): Array<string> {\n return typeof value !== 'undefined'\n ? [].concat(typeof value === 'string' ? value.split(',') : value)\n : [];\n}\n"]}