@commercetools-uikit/filters 19.22.1 → 19.22.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -123,8 +123,7 @@ const operatorInputContainer = process.env.NODE_ENV === "production" ? {
123
123
  styles: "word-break:break-word;display:flex;align-items:center"
124
124
  } : {
125
125
  name: "8xu73l-operatorInputContainer",
126
- styles: "word-break:break-word;display:flex;align-items:center;label:operatorInputContainer;",
127
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0RrQyIsImZpbGUiOiJoZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdXNlU3RhdGUsXG4gIHR5cGUgUmVhY3ROb2RlLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IEljb25CdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvaWNvbi1idXR0b24nO1xuaW1wb3J0IHsgU29ydGluZ0ljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxudHlwZSBUSGVhZGVyUHJvcHMgPSB7XG4gIC8qKlxuICAgKiB0aGUgbGFiZWwgb2YgdGhlIG1lbnUgaGVhZGVyXG4gICAqL1xuICBsYWJlbDogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGZ1bmN0aW9uIHRvIHJlbmRlciB0aGUgb3BlcmF0b3IgaW5wdXRcbiAgICovXG4gIHJlbmRlck9wZXJhdG9yc0lucHV0PzogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGZ1bmN0aW9uIHRvIHNvcnQgdGhlIGRhdGFcbiAgICovXG4gIG9uU29ydFJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICAvKipcbiAgICogdGhlIHdpZHRoIG9mIHRoZSBtZW51IGhlYWRlclxuICAgKi9cbn07XG5cbmNvbnN0IGhlYWRlckNvbnRhaW5lclN0eWxlcyA9IGNzc2BcbiAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDQwfTtcbiAgZm9udC13ZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmZvbnRXZWlnaHQ1MDB9O1xuICBmb250LXNpemU6ICR7ZGVzaWduVG9rZW5zLmZvbnRTaXplMjB9O1xuICBsaW5lLWhlaWdodDogJHtkZXNpZ25Ub2tlbnMubGluZUhlaWdodDIwfTtcbiAgZGlzcGxheTogZ3JpZDtcbiAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAxZnIgbWluLWNvbnRlbnQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctYm90dG9tOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMTB9O1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICB3aWR0aDogMTAwJTtcbmA7XG5cbmNvbnN0IHNlbGVjdElucHV0U3R5bGVzID0gY3NzYFxuICBmbGV4OiAwIDAgYXV0bztcbiAgbWF4LXdpZHRoOiAke2Rlc2lnblRva2Vucy5jb25zdHJhaW50M307XG4gIG1hcmdpbi1sZWZ0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjB9O1xuYDtcblxuY29uc3Qgc29ydEJ1dHRvbk1hcmdpbiA9IGNzc2BcbiAgbWFyZ2luLXJpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNDB9O1xuYDtcblxuY29uc3Qgb3BlcmF0b3JJbnB1dENvbnRhaW5lciA9IGNzc2BcbiAgd29yZC1icmVhazogYnJlYWstd29yZDtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmA7XG5cbmNvbnN0IEhlYWRlciA9IChwcm9wczogVEhlYWRlclByb3BzKSA9PiB7XG4gIGNvbnN0IFtpc0FjdGl2ZSwgc2V0SXNBY3RpdmVdID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIHJldHVybiAoXG4gICAgPGhlYWRlciBjc3M9e2hlYWRlckNvbnRhaW5lclN0eWxlc30+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17W29wZXJhdG9ySW5wdXRDb250YWluZXIsIHByb3BzLm9uU29ydFJlcXVlc3QgJiYgc29ydEJ1dHRvbk1hcmdpbl19XG4gICAgICA+XG4gICAgICAgIDxkaXY+e3Byb3BzLmxhYmVsfTwvZGl2PlxuICAgICAgICB7cHJvcHMucmVuZGVyT3BlcmF0b3JzSW5wdXQgJiYgKFxuICAgICAgICAgIDxkaXYgY3NzPXtzZWxlY3RJbnB1dFN0eWxlc30+e3Byb3BzLnJlbmRlck9wZXJhdG9yc0lucHV0KCl9PC9kaXY+XG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICAgIHtwcm9wcy5vblNvcnRSZXF1ZXN0ICYmIChcbiAgICAgICAgPEljb25CdXR0b25cbiAgICAgICAgICBzaXplPVwiMjBcIlxuICAgICAgICAgIHRoZW1lPXtpc0FjdGl2ZSA/ICdpbmZvJyA6ICdkZWZhdWx0J31cbiAgICAgICAgICBsYWJlbD1cIlNvcnRcIlxuICAgICAgICAgIGljb249ezxTb3J0aW5nSWNvbiAvPn1cbiAgICAgICAgICBpc1RvZ2dsZUJ1dHRvbj17dHJ1ZX1cbiAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgc2V0SXNBY3RpdmUoIWlzQWN0aXZlKTtcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy5vblNvcnRSZXF1ZXN0ICYmIHByb3BzLm9uU29ydFJlcXVlc3QoZSk7XG4gICAgICAgICAgfX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC9oZWFkZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBIZWFkZXI7XG4iXX0= */",
126
+ styles: "word-break:break-word;display:flex;align-items:center;label:operatorInputContainer;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0RrQyIsImZpbGUiOiJoZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdXNlU3RhdGUsXG4gIHR5cGUgUmVhY3ROb2RlLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IEljb25CdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvaWNvbi1idXR0b24nO1xuaW1wb3J0IHsgU29ydGluZ0ljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxudHlwZSBUSGVhZGVyUHJvcHMgPSB7XG4gIC8qKlxuICAgKiB0aGUgbGFiZWwgb2YgdGhlIG1lbnUgaGVhZGVyXG4gICAqL1xuICBsYWJlbDogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGZ1bmN0aW9uIHRvIHJlbmRlciB0aGUgb3BlcmF0b3IgaW5wdXRcbiAgICovXG4gIHJlbmRlck9wZXJhdG9yc0lucHV0PzogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGZ1bmN0aW9uIHRvIHNvcnQgdGhlIGRhdGFcbiAgICovXG4gIG9uU29ydFJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICAvKipcbiAgICogdGhlIHdpZHRoIG9mIHRoZSBtZW51IGhlYWRlclxuICAgKi9cbn07XG5cbmNvbnN0IGhlYWRlckNvbnRhaW5lclN0eWxlcyA9IGNzc2BcbiAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDQwfTtcbiAgZm9udC13ZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmZvbnRXZWlnaHQ1MDB9O1xuICBmb250LXNpemU6ICR7ZGVzaWduVG9rZW5zLmZvbnRTaXplMjB9O1xuICBsaW5lLWhlaWdodDogJHtkZXNpZ25Ub2tlbnMubGluZUhlaWdodDIwfTtcbiAgZGlzcGxheTogZ3JpZDtcbiAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAxZnIgbWluLWNvbnRlbnQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctYm90dG9tOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMTB9O1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICB3aWR0aDogMTAwJTtcbmA7XG5cbmNvbnN0IHNlbGVjdElucHV0U3R5bGVzID0gY3NzYFxuICBmbGV4OiAwIDAgYXV0bztcbiAgbWF4LXdpZHRoOiAke2Rlc2lnblRva2Vucy5jb25zdHJhaW50M307XG4gIG1hcmdpbi1sZWZ0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjB9O1xuYDtcblxuY29uc3Qgc29ydEJ1dHRvbk1hcmdpbiA9IGNzc2BcbiAgbWFyZ2luLXJpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNDB9O1xuYDtcblxuY29uc3Qgb3BlcmF0b3JJbnB1dENvbnRhaW5lciA9IGNzc2BcbiAgd29yZC1icmVhazogYnJlYWstd29yZDtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmA7XG5cbmNvbnN0IEhlYWRlciA9IChwcm9wczogVEhlYWRlclByb3BzKSA9PiB7XG4gIGNvbnN0IFtpc0FjdGl2ZSwgc2V0SXNBY3RpdmVdID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIHJldHVybiAoXG4gICAgPGhlYWRlciBjc3M9e2hlYWRlckNvbnRhaW5lclN0eWxlc30+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17W29wZXJhdG9ySW5wdXRDb250YWluZXIsIHByb3BzLm9uU29ydFJlcXVlc3QgJiYgc29ydEJ1dHRvbk1hcmdpbl19XG4gICAgICA+XG4gICAgICAgIDxkaXY+e3Byb3BzLmxhYmVsfTwvZGl2PlxuICAgICAgICB7cHJvcHMucmVuZGVyT3BlcmF0b3JzSW5wdXQgJiYgKFxuICAgICAgICAgIDxkaXYgY3NzPXtzZWxlY3RJbnB1dFN0eWxlc30+e3Byb3BzLnJlbmRlck9wZXJhdG9yc0lucHV0KCl9PC9kaXY+XG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICAgIHtwcm9wcy5vblNvcnRSZXF1ZXN0ICYmIChcbiAgICAgICAgPEljb25CdXR0b25cbiAgICAgICAgICBzaXplPVwiMjBcIlxuICAgICAgICAgIHRoZW1lPXtpc0FjdGl2ZSA/ICdpbmZvJyA6ICdkZWZhdWx0J31cbiAgICAgICAgICBsYWJlbD1cIlNvcnRcIlxuICAgICAgICAgIGljb249ezxTb3J0aW5nSWNvbiAvPn1cbiAgICAgICAgICBpc1RvZ2dsZUJ1dHRvbj17dHJ1ZX1cbiAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgc2V0SXNBY3RpdmUoIWlzQWN0aXZlKTtcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy5vblNvcnRSZXF1ZXN0ICYmIHByb3BzLm9uU29ydFJlcXVlc3QoZSk7XG4gICAgICAgICAgfX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC9oZWFkZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBIZWFkZXI7XG4iXX0= */",
128
127
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
129
128
  };
130
129
  const Header = props => {
@@ -333,8 +332,7 @@ const menuBodyStyle = process.env.NODE_ENV === "production" ? {
333
332
  styles: "width:100%;overflow:hidden auto"
334
333
  } : {
335
334
  name: "a5of5h-menuBodyStyle",
336
- styles: "width:100%;overflow:hidden auto;label:menuBodyStyle;",
337
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbHRlci1tZW51LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvSGdDIiwiZmlsZSI6ImZpbHRlci1tZW51LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIHR5cGUgUmVhY3ROb2RlLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbiAgdXNlUmVmLFxuICB1c2VDYWxsYmFjayxcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgKiBhcyBQb3BvdmVyIGZyb20gJ0ByYWRpeC11aS9yZWFjdC1wb3BvdmVyJztcbmltcG9ydCB7IEZvb3RlciB9IGZyb20gJy4vZm9vdGVyJztcbmltcG9ydCB7IEhlYWRlciB9IGZyb20gJy4vaGVhZGVyJztcbmltcG9ydCB7IFRyaWdnZXJCdXR0b24gfSBmcm9tICcuL3RyaWdnZXItYnV0dG9uJztcblxuLyoqXG4gKiBDU1Mgc2VsZWN0b3IgdG8gZmluZCBmb2N1c2FibGUgZWxlbWVudHMuXG4gKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9taWNyb3NvZnQvdGFic3Rlci9ibG9iLzZiZmQ1NGE0NWY1YjIwZWNjZDE3YjhhMDVmNmM4NmMyNDFiOTkyYzMvc3JjL0ZvY3VzYWJsZS50cyNMMTctTDI1XG4gKiBUT0RPOiBtYWtlIGF2YWlsYWJsZSBhcyBhIHV0aWwgZm9yIGdlbmVyYWwgdXNlXG4gKi9cbmNvbnN0IEZPQ1VTQUJMRV9DU1NfU0VMRUNUT1IgPSBgYVtocmVmXSwgYnV0dG9uOm5vdChbZGlzYWJsZWRdKSwgaW5wdXQ6bm90KFtkaXNhYmxlZF0pLCBzZWxlY3Q6bm90KFtkaXNhYmxlZF0pLCB0ZXh0YXJlYTpub3QoW2Rpc2FibGVkXSksICpbdGFiaW5kZXhdLCAqW2NvbnRlbnRlZGl0YWJsZV1gO1xuXG4vKipcbiAqIEZpbmQgdGhlIGZpcnN0IGZvY3VzYWJsZSBlbGVtZW50IGluIHRoZSBnaXZlbiBjb250YWluZXIsXG4gKiBzdWNoIGFzIHRoZSBmaXJzdCBmb2N1c2FibGUgbGlzdCBpdGVtLlxuICogQHBhcmFtIHtIVE1MRWxlbWVudH0gY29udGFpbmVyXG4gKiBAcmV0dXJucyB7SFRNTEVsZW1lbnQgfCBudWxsfVxuICovXG5mdW5jdGlvbiBmaW5kRmlyc3RGb2N1c2FibGU8VCBleHRlbmRzIEhUTUxFbGVtZW50Pihjb250YWluZXI6IFQpOiBUIHwgbnVsbCB7XG4gIHJldHVybiBjb250YWluZXIucXVlcnlTZWxlY3RvcihGT0NVU0FCTEVfQ1NTX1NFTEVDVE9SKTtcbn1cblxuZXhwb3J0IHR5cGUgVEFwcGxpZWRGaWx0ZXJWYWx1ZSA9IHtcbiAgdmFsdWU6IHN0cmluZztcbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbn07XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51UHJvcHMgPSB7XG4gIC8qKlxuICAgKiB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIGZpbHRlclxuICAgKi9cbiAgZmlsdGVyS2V5OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBmb3JtYXR0ZWQgbWVzc2FnZSB0byBkaXNwbGF5IHRoZSBmaWx0ZXIncyBuYW1lXG4gICAqL1xuICBsYWJlbDogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIHNlbGVjdHMgdmFsdWVzIGZvciB0aGUgZmlsdGVyXG4gICAqL1xuICByZW5kZXJNZW51Qm9keTogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIGNhbiBzZWxlY3Qgd2hpY2ggb3BlcmF0b3Igc2hvdWxkIGJlIHVzZWQgZm9yIHRoaXMgZmlsdGVyXG4gICAqL1xuICByZW5kZXJPcGVyYXRvcnNJbnB1dD86ICgpID0+IFJlYWN0Tm9kZTtcbiAgLyoqXG4gICAqIGZvcm1hdHRlZCBtZXNzYWdlIHRvIGRpc3BsYXkgdGhlIHNlbGVjdGVkIG9wZXJhdG9yIHZhbHVlXG4gICAqL1xuICBvcGVyYXRvckxhYmVsPzogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIHZhbHVlcyBhcHBsaWVkIHRvIHRoaXMgZmlsdGVyIGJ5IHRoZSB1c2VyXG4gICAqL1xuICBhcHBsaWVkRmlsdGVyVmFsdWVzOiBUQXBwbGllZEZpbHRlclZhbHVlW10gfCB1bmRlZmluZWQgfCBudWxsO1xuICAvKipcbiAgICogaW5kaWNhdGVzIHdoZXRoZXIgRmlsdGVyTWVudSBjYW4gYmUgcmVtb3ZlZCBmcm9tIHRoZSBmaWx0ZXJzTGlzdFxuICAgKi9cbiAgaXNQZXJzaXN0ZW50PzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIHdoZXRoZXIgb3Igbm90IHRoZSBmaWx0ZXIgaXMgZGlzYWJsZWRcbiAgICovXG4gIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgeGAgaW4gVHJpZ2dlciBCdXR0b24gaXMgZGlzcGxheWVkIC0gcmVxdWlyZWQgaWYgYGlzUGVyc2lzdGVudGAgaXMgYGZhbHNlYFxuICAgKi9cbiAgb25SZW1vdmVSZXF1ZXN0PzogKFxuICAgIGV2ZW50PzogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4gfCBLZXlib2FyZEV2ZW50PEhUTUxCdXR0b25FbGVtZW50PlxuICApID0+IHZvaWQ7XG4gIC8qKlxuICAgKiBvcHRpb25hbCBidXR0b24gdGhhdCBhbGxvd3MgdGhlIHVzZXIgdG8gYXBwbHkgc2VsZWN0ZWQgZmlsdGVyIHZhbHVlc1xuICAgKi9cbiAgcmVuZGVyQXBwbHlCdXR0b24/OiAoKSA9PiBSZWFjdE5vZGU7XG4gIC8qKlxuICAgKiBjb250cm9scyB3aGV0aGVyIGBjbGVhciBhbGxgIGJ1dHRvbiBpbiBNZW51IEJvZHkgRm9vdGVyIGlzIGRpc3BsYXllZFxuICAgKi9cbiAgb25DbGVhclJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgc29ydGAgYnV0dG9uIGluIE1lbnUgQm9keSBIZWFkZXIgaXMgZGlzcGxheWVkXG4gICAqL1xuICBvblNvcnRSZXF1ZXN0PzogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgLyoqXG4gICAqIGNvbnRyb2xzIHdoZXRoZXIgbWVudSBpcyBvcGVuIG9uIGluaXRpYWwgcmVuZGVyXG4gICAqL1xuICBkZWZhdWx0T3Blbj86IGJvb2xlYW47XG59O1xuXG5leHBvcnQgY29uc3QgbWVudVN0eWxlcyA9IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzMwfTtcbiAgd2lkdGg6ICR7ZGVzaWduVG9rZW5zLmNvbnN0cmFpbnQ2fTtcbiAgbWF4LWhlaWdodDogJHtkZXNpZ25Ub2tlbnMuY29uc3RyYWludDEwfTtcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzIwfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nMzB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXI6IDFweCBzb2xpZCAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM4fTtcbiAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93MTh9O1xuICBhbmltYXRpb24tZHVyYXRpb246ICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gIHdpbGwtY2hhbmdlOiAndHJhbnNmb3JtLCBvcGFjaXR5JztcbiAgbWFyZ2luLXRvcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB6LWluZGV4OiA1O1xuYDtcblxuZXhwb3J0IGNvbnN0IG1lbnVCb2R5U3R5bGUgPSBjc3NgXG4gIHdpZHRoOiAxMDAlO1xuXG4gIC8qKiBlbnN1cmUgdGhhdCBib2R5IHNjcm9sbHMgd2l0aCBvdmVyZmxvdyBub3cgdGhhdCB0aGVyZSBpcyBhIG1lbnUgbWF4LWhlaWdodCAqL1xuICBvdmVyZmxvdzogaGlkZGVuIGF1dG87XG5gO1xuXG5mdW5jdGlvbiBGaWx0ZXJNZW51KHByb3BzOiBURmlsdGVyTWVudVByb3BzKSB7XG4gIGNvbnN0IG1lbnVCb2R5UmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICBjb25zdCBmb2N1c01lbnVCb2R5ID0gdXNlQ2FsbGJhY2soXG4gICAgKGUpID0+IHtcbiAgICAgIGlmIChtZW51Qm9keVJlZi5jdXJyZW50KSB7XG4gICAgICAgIGNvbnN0IGZpcnN0Rm9jdXNhYmxlRWxlbWVudEluTWVudUJvZHkgPSBmaW5kRmlyc3RGb2N1c2FibGUoXG4gICAgICAgICAgbWVudUJvZHlSZWYuY3VycmVudFxuICAgICAgICApO1xuICAgICAgICBpZiAoZmlyc3RGb2N1c2FibGVFbGVtZW50SW5NZW51Qm9keSkge1xuICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICBmaXJzdEZvY3VzYWJsZUVsZW1lbnRJbk1lbnVCb2R5LmZvY3VzKCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9LFxuICAgIFttZW51Qm9keVJlZl1cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxQb3BvdmVyLlJvb3RcbiAgICAgIGRlZmF1bHRPcGVuPXtwcm9wcy5pc0Rpc2FibGVkID8gZmFsc2UgOiBwcm9wcy5kZWZhdWx0T3Blbn1cbiAgICAgIG9uT3BlbkNoYW5nZT17KG9wZW4pID0+IHtcbiAgICAgICAgaWYgKFxuICAgICAgICAgICFvcGVuICYmXG4gICAgICAgICAgIXByb3BzLmFwcGxpZWRGaWx0ZXJWYWx1ZXM/Lmxlbmd0aCAmJlxuICAgICAgICAgICFwcm9wcy5pc1BlcnNpc3RlbnQgJiZcbiAgICAgICAgICBwcm9wcy5vblJlbW92ZVJlcXVlc3RcbiAgICAgICAgKSB7XG4gICAgICAgICAgcHJvcHMub25SZW1vdmVSZXF1ZXN0KCk7XG4gICAgICAgIH1cbiAgICAgIH19XG4gICAgPlxuICAgICAgPFBvcG92ZXIuVHJpZ2dlciBhc0NoaWxkPlxuICAgICAgICA8VHJpZ2dlckJ1dHRvblxuICAgICAgICAgIGZpbHRlcktleT17cHJvcHMuZmlsdGVyS2V5fVxuICAgICAgICAgIGxhYmVsPXtwcm9wcy5sYWJlbH1cbiAgICAgICAgICBvcGVyYXRvckxhYmVsPXtwcm9wcy5vcGVyYXRvckxhYmVsfVxuICAgICAgICAgIGFwcGxpZWRGaWx0ZXJWYWx1ZXM9e3Byb3BzLmFwcGxpZWRGaWx0ZXJWYWx1ZXN9XG4gICAgICAgICAgaXNEaXNhYmxlZD17cHJvcHMuaXNEaXNhYmxlZH1cbiAgICAgICAgICBpc1BlcnNpc3RlbnQ9e3Byb3BzLmlzUGVyc2lzdGVudH1cbiAgICAgICAgICBvblJlbW92ZVJlcXVlc3Q9e3Byb3BzLm9uUmVtb3ZlUmVxdWVzdH1cbiAgICAgICAgLz5cbiAgICAgIDwvUG9wb3Zlci5UcmlnZ2VyPlxuICAgICAgPFBvcG92ZXIuUG9ydGFsPlxuICAgICAgICA8UG9wb3Zlci5Db250ZW50XG4gICAgICAgICAgc2lkZT1cImJvdHRvbVwiXG4gICAgICAgICAgYWxpZ249XCJzdGFydFwiXG4gICAgICAgICAgY3NzPXttZW51U3R5bGVzfVxuICAgICAgICAgIG9uT3BlbkF1dG9Gb2N1cz17Zm9jdXNNZW51Qm9keX1cbiAgICAgICAgPlxuICAgICAgICAgIDxIZWFkZXJcbiAgICAgICAgICAgIGxhYmVsPXtwcm9wcy5sYWJlbH1cbiAgICAgICAgICAgIHJlbmRlck9wZXJhdG9yc0lucHV0PXtwcm9wcy5yZW5kZXJPcGVyYXRvcnNJbnB1dH1cbiAgICAgICAgICAgIG9uU29ydFJlcXVlc3Q9e3Byb3BzLm9uU29ydFJlcXVlc3R9XG4gICAgICAgICAgLz5cbiAgICAgICAgICA8ZGl2IGNzcz17bWVudUJvZHlTdHlsZX0gcmVmPXttZW51Qm9keVJlZn0+XG4gICAgICAgICAgICB7cHJvcHMucmVuZGVyTWVudUJvZHkoKX1cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8Rm9vdGVyXG4gICAgICAgICAgICBvbkNsZWFyUmVxdWVzdD17cHJvcHMub25DbGVhclJlcXVlc3R9XG4gICAgICAgICAgICByZW5kZXJBcHBseUJ1dHRvbj17cHJvcHMucmVuZGVyQXBwbHlCdXR0b259XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9Qb3BvdmVyLkNvbnRlbnQ+XG4gICAgICA8L1BvcG92ZXIuUG9ydGFsPlxuICAgIDwvUG9wb3Zlci5Sb290PlxuICApO1xufVxuXG5leHBvcnQgZGVmYXVsdCBGaWx0ZXJNZW51O1xuIl19 */",
335
+ styles: "width:100%;overflow:hidden auto;label:menuBodyStyle;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbHRlci1tZW51LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvSGdDIiwiZmlsZSI6ImZpbHRlci1tZW51LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIHR5cGUgUmVhY3ROb2RlLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbiAgdXNlUmVmLFxuICB1c2VDYWxsYmFjayxcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgKiBhcyBQb3BvdmVyIGZyb20gJ0ByYWRpeC11aS9yZWFjdC1wb3BvdmVyJztcbmltcG9ydCB7IEZvb3RlciB9IGZyb20gJy4vZm9vdGVyJztcbmltcG9ydCB7IEhlYWRlciB9IGZyb20gJy4vaGVhZGVyJztcbmltcG9ydCB7IFRyaWdnZXJCdXR0b24gfSBmcm9tICcuL3RyaWdnZXItYnV0dG9uJztcblxuLyoqXG4gKiBDU1Mgc2VsZWN0b3IgdG8gZmluZCBmb2N1c2FibGUgZWxlbWVudHMuXG4gKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9taWNyb3NvZnQvdGFic3Rlci9ibG9iLzZiZmQ1NGE0NWY1YjIwZWNjZDE3YjhhMDVmNmM4NmMyNDFiOTkyYzMvc3JjL0ZvY3VzYWJsZS50cyNMMTctTDI1XG4gKiBUT0RPOiBtYWtlIGF2YWlsYWJsZSBhcyBhIHV0aWwgZm9yIGdlbmVyYWwgdXNlXG4gKi9cbmNvbnN0IEZPQ1VTQUJMRV9DU1NfU0VMRUNUT1IgPSBgYVtocmVmXSwgYnV0dG9uOm5vdChbZGlzYWJsZWRdKSwgaW5wdXQ6bm90KFtkaXNhYmxlZF0pLCBzZWxlY3Q6bm90KFtkaXNhYmxlZF0pLCB0ZXh0YXJlYTpub3QoW2Rpc2FibGVkXSksICpbdGFiaW5kZXhdLCAqW2NvbnRlbnRlZGl0YWJsZV1gO1xuXG4vKipcbiAqIEZpbmQgdGhlIGZpcnN0IGZvY3VzYWJsZSBlbGVtZW50IGluIHRoZSBnaXZlbiBjb250YWluZXIsXG4gKiBzdWNoIGFzIHRoZSBmaXJzdCBmb2N1c2FibGUgbGlzdCBpdGVtLlxuICogQHBhcmFtIHtIVE1MRWxlbWVudH0gY29udGFpbmVyXG4gKiBAcmV0dXJucyB7SFRNTEVsZW1lbnQgfCBudWxsfVxuICovXG5mdW5jdGlvbiBmaW5kRmlyc3RGb2N1c2FibGU8VCBleHRlbmRzIEhUTUxFbGVtZW50Pihjb250YWluZXI6IFQpOiBUIHwgbnVsbCB7XG4gIHJldHVybiBjb250YWluZXIucXVlcnlTZWxlY3RvcihGT0NVU0FCTEVfQ1NTX1NFTEVDVE9SKTtcbn1cblxuZXhwb3J0IHR5cGUgVEFwcGxpZWRGaWx0ZXJWYWx1ZSA9IHtcbiAgdmFsdWU6IHN0cmluZztcbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbn07XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51UHJvcHMgPSB7XG4gIC8qKlxuICAgKiB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIGZpbHRlclxuICAgKi9cbiAgZmlsdGVyS2V5OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBmb3JtYXR0ZWQgbWVzc2FnZSB0byBkaXNwbGF5IHRoZSBmaWx0ZXIncyBuYW1lXG4gICAqL1xuICBsYWJlbDogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIHNlbGVjdHMgdmFsdWVzIGZvciB0aGUgZmlsdGVyXG4gICAqL1xuICByZW5kZXJNZW51Qm9keTogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIGNhbiBzZWxlY3Qgd2hpY2ggb3BlcmF0b3Igc2hvdWxkIGJlIHVzZWQgZm9yIHRoaXMgZmlsdGVyXG4gICAqL1xuICByZW5kZXJPcGVyYXRvcnNJbnB1dD86ICgpID0+IFJlYWN0Tm9kZTtcbiAgLyoqXG4gICAqIGZvcm1hdHRlZCBtZXNzYWdlIHRvIGRpc3BsYXkgdGhlIHNlbGVjdGVkIG9wZXJhdG9yIHZhbHVlXG4gICAqL1xuICBvcGVyYXRvckxhYmVsPzogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIHZhbHVlcyBhcHBsaWVkIHRvIHRoaXMgZmlsdGVyIGJ5IHRoZSB1c2VyXG4gICAqL1xuICBhcHBsaWVkRmlsdGVyVmFsdWVzOiBUQXBwbGllZEZpbHRlclZhbHVlW10gfCB1bmRlZmluZWQgfCBudWxsO1xuICAvKipcbiAgICogaW5kaWNhdGVzIHdoZXRoZXIgRmlsdGVyTWVudSBjYW4gYmUgcmVtb3ZlZCBmcm9tIHRoZSBmaWx0ZXJzTGlzdFxuICAgKi9cbiAgaXNQZXJzaXN0ZW50PzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIHdoZXRoZXIgb3Igbm90IHRoZSBmaWx0ZXIgaXMgZGlzYWJsZWRcbiAgICovXG4gIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgeGAgaW4gVHJpZ2dlciBCdXR0b24gaXMgZGlzcGxheWVkIC0gcmVxdWlyZWQgaWYgYGlzUGVyc2lzdGVudGAgaXMgYGZhbHNlYFxuICAgKi9cbiAgb25SZW1vdmVSZXF1ZXN0PzogKFxuICAgIGV2ZW50PzogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4gfCBLZXlib2FyZEV2ZW50PEhUTUxCdXR0b25FbGVtZW50PlxuICApID0+IHZvaWQ7XG4gIC8qKlxuICAgKiBvcHRpb25hbCBidXR0b24gdGhhdCBhbGxvd3MgdGhlIHVzZXIgdG8gYXBwbHkgc2VsZWN0ZWQgZmlsdGVyIHZhbHVlc1xuICAgKi9cbiAgcmVuZGVyQXBwbHlCdXR0b24/OiAoKSA9PiBSZWFjdE5vZGU7XG4gIC8qKlxuICAgKiBjb250cm9scyB3aGV0aGVyIGBjbGVhciBhbGxgIGJ1dHRvbiBpbiBNZW51IEJvZHkgRm9vdGVyIGlzIGRpc3BsYXllZFxuICAgKi9cbiAgb25DbGVhclJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgc29ydGAgYnV0dG9uIGluIE1lbnUgQm9keSBIZWFkZXIgaXMgZGlzcGxheWVkXG4gICAqL1xuICBvblNvcnRSZXF1ZXN0PzogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgLyoqXG4gICAqIGNvbnRyb2xzIHdoZXRoZXIgbWVudSBpcyBvcGVuIG9uIGluaXRpYWwgcmVuZGVyXG4gICAqL1xuICBkZWZhdWx0T3Blbj86IGJvb2xlYW47XG59O1xuXG5leHBvcnQgY29uc3QgbWVudVN0eWxlcyA9IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzMwfTtcbiAgd2lkdGg6ICR7ZGVzaWduVG9rZW5zLmNvbnN0cmFpbnQ2fTtcbiAgbWF4LWhlaWdodDogJHtkZXNpZ25Ub2tlbnMuY29uc3RyYWludDEwfTtcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzIwfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nMzB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXI6IDFweCBzb2xpZCAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM4fTtcbiAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93MTh9O1xuICBhbmltYXRpb24tZHVyYXRpb246ICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gIHdpbGwtY2hhbmdlOiAndHJhbnNmb3JtLCBvcGFjaXR5JztcbiAgbWFyZ2luLXRvcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB6LWluZGV4OiA1O1xuYDtcblxuZXhwb3J0IGNvbnN0IG1lbnVCb2R5U3R5bGUgPSBjc3NgXG4gIHdpZHRoOiAxMDAlO1xuXG4gIC8qKiBlbnN1cmUgdGhhdCBib2R5IHNjcm9sbHMgd2l0aCBvdmVyZmxvdyBub3cgdGhhdCB0aGVyZSBpcyBhIG1lbnUgbWF4LWhlaWdodCAqL1xuICBvdmVyZmxvdzogaGlkZGVuIGF1dG87XG5gO1xuXG5mdW5jdGlvbiBGaWx0ZXJNZW51KHByb3BzOiBURmlsdGVyTWVudVByb3BzKSB7XG4gIGNvbnN0IG1lbnVCb2R5UmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICBjb25zdCBmb2N1c01lbnVCb2R5ID0gdXNlQ2FsbGJhY2soXG4gICAgKGUpID0+IHtcbiAgICAgIGlmIChtZW51Qm9keVJlZi5jdXJyZW50KSB7XG4gICAgICAgIGNvbnN0IGZpcnN0Rm9jdXNhYmxlRWxlbWVudEluTWVudUJvZHkgPSBmaW5kRmlyc3RGb2N1c2FibGUoXG4gICAgICAgICAgbWVudUJvZHlSZWYuY3VycmVudFxuICAgICAgICApO1xuICAgICAgICBpZiAoZmlyc3RGb2N1c2FibGVFbGVtZW50SW5NZW51Qm9keSkge1xuICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICBmaXJzdEZvY3VzYWJsZUVsZW1lbnRJbk1lbnVCb2R5LmZvY3VzKCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9LFxuICAgIFttZW51Qm9keVJlZl1cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxQb3BvdmVyLlJvb3RcbiAgICAgIGRlZmF1bHRPcGVuPXtwcm9wcy5pc0Rpc2FibGVkID8gZmFsc2UgOiBwcm9wcy5kZWZhdWx0T3Blbn1cbiAgICAgIG9uT3BlbkNoYW5nZT17KG9wZW4pID0+IHtcbiAgICAgICAgaWYgKFxuICAgICAgICAgICFvcGVuICYmXG4gICAgICAgICAgIXByb3BzLmFwcGxpZWRGaWx0ZXJWYWx1ZXM/Lmxlbmd0aCAmJlxuICAgICAgICAgICFwcm9wcy5pc1BlcnNpc3RlbnQgJiZcbiAgICAgICAgICBwcm9wcy5vblJlbW92ZVJlcXVlc3RcbiAgICAgICAgKSB7XG4gICAgICAgICAgcHJvcHMub25SZW1vdmVSZXF1ZXN0KCk7XG4gICAgICAgIH1cbiAgICAgIH19XG4gICAgPlxuICAgICAgPFBvcG92ZXIuVHJpZ2dlciBhc0NoaWxkPlxuICAgICAgICA8VHJpZ2dlckJ1dHRvblxuICAgICAgICAgIGZpbHRlcktleT17cHJvcHMuZmlsdGVyS2V5fVxuICAgICAgICAgIGxhYmVsPXtwcm9wcy5sYWJlbH1cbiAgICAgICAgICBvcGVyYXRvckxhYmVsPXtwcm9wcy5vcGVyYXRvckxhYmVsfVxuICAgICAgICAgIGFwcGxpZWRGaWx0ZXJWYWx1ZXM9e3Byb3BzLmFwcGxpZWRGaWx0ZXJWYWx1ZXN9XG4gICAgICAgICAgaXNEaXNhYmxlZD17cHJvcHMuaXNEaXNhYmxlZH1cbiAgICAgICAgICBpc1BlcnNpc3RlbnQ9e3Byb3BzLmlzUGVyc2lzdGVudH1cbiAgICAgICAgICBvblJlbW92ZVJlcXVlc3Q9e3Byb3BzLm9uUmVtb3ZlUmVxdWVzdH1cbiAgICAgICAgLz5cbiAgICAgIDwvUG9wb3Zlci5UcmlnZ2VyPlxuICAgICAgPFBvcG92ZXIuUG9ydGFsPlxuICAgICAgICA8UG9wb3Zlci5Db250ZW50XG4gICAgICAgICAgc2lkZT1cImJvdHRvbVwiXG4gICAgICAgICAgYWxpZ249XCJzdGFydFwiXG4gICAgICAgICAgY3NzPXttZW51U3R5bGVzfVxuICAgICAgICAgIG9uT3BlbkF1dG9Gb2N1cz17Zm9jdXNNZW51Qm9keX1cbiAgICAgICAgPlxuICAgICAgICAgIDxIZWFkZXJcbiAgICAgICAgICAgIGxhYmVsPXtwcm9wcy5sYWJlbH1cbiAgICAgICAgICAgIHJlbmRlck9wZXJhdG9yc0lucHV0PXtwcm9wcy5yZW5kZXJPcGVyYXRvcnNJbnB1dH1cbiAgICAgICAgICAgIG9uU29ydFJlcXVlc3Q9e3Byb3BzLm9uU29ydFJlcXVlc3R9XG4gICAgICAgICAgLz5cbiAgICAgICAgICA8ZGl2IGNzcz17bWVudUJvZHlTdHlsZX0gcmVmPXttZW51Qm9keVJlZn0+XG4gICAgICAgICAgICB7cHJvcHMucmVuZGVyTWVudUJvZHkoKX1cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8Rm9vdGVyXG4gICAgICAgICAgICBvbkNsZWFyUmVxdWVzdD17cHJvcHMub25DbGVhclJlcXVlc3R9XG4gICAgICAgICAgICByZW5kZXJBcHBseUJ1dHRvbj17cHJvcHMucmVuZGVyQXBwbHlCdXR0b259XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9Qb3BvdmVyLkNvbnRlbnQ+XG4gICAgICA8L1BvcG92ZXIuUG9ydGFsPlxuICAgIDwvUG9wb3Zlci5Sb290PlxuICApO1xufVxuXG5leHBvcnQgZGVmYXVsdCBGaWx0ZXJNZW51O1xuIl19 */",
338
336
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
339
337
  };
340
338
  function FilterMenu(props) {
@@ -458,8 +456,7 @@ var _ref9 = process.env.NODE_ENV === "production" ? {
458
456
  styles: "display:inline-flex"
459
457
  } : {
460
458
  name: "irmyae-Filters",
461
- styles: "display:inline-flex;label:Filters;",
462
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AAwWuB","file":"filters.tsx","sourcesContent":["import {\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n  useRef,\n  useState,\n} from 'react';\nimport { css } from '@emotion/react';\nimport * as Popover from '@radix-ui/react-popover';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport SelectInput, {\n  TOption,\n  TOptionObject,\n} from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { useIntl } from 'react-intl';\nimport FilterMenu, {\n  menuStyles,\n  menuBodyStyle,\n  type TAppliedFilterValue,\n} from './filter-menu';\nimport messages from './messages';\nimport { Badge } from './badge';\n\ninterface TAddFilterSelectOption extends TOption {\n  isDisabled?: boolean;\n}\n\ninterface TAddFilterOptionGroup extends TOptionObject {\n  options: TAddFilterSelectOption[];\n  label: ReactNode;\n  key: string;\n}\n\nexport type TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\nexport type TFilterConfiguration = {\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n  /**\n   * formatted message to display the selected operator value\n   */\n  operatorLabel?: ReactNode;\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactNode;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactNode;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * indicates whether the filter is disabled\n   */\n  isDisabled?: boolean;\n};\n\nexport type TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   *\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   *\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n\n  /**\n   * controls the `clear all` (added filters) button from the menu list, meant to clear the parent application's filter state\n   */\n  onClearAllRequest: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * optional callback when the add filter button is clicked\n   */\n  onAddFilterRequest?: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: ReactNode;\n  /**\n   * controls whether the filters list is initially open\n   */\n  defaultOpen?: boolean;\n};\n\nconst horizontalDividerStyles = css`\n  color: ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral90};\n  width: 100%;\n  height: 1px;\n  border: 0;\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction getFilterOptions(\n  filters: TFilterConfiguration[],\n  filterGroups?: TFilterGroupConfiguration[]\n): (TAddFilterSelectOption | TAddFilterOptionGroup)[] {\n  let filterOptions: (TAddFilterSelectOption | TAddFilterOptionGroup)[] = [];\n  // define option groups\n  if (filterGroups) {\n    filterOptions = filterGroups.map((filterGroup) => ({\n      label: filterGroup.label,\n      key: filterGroup.key,\n      options: [],\n    }));\n  }\n  return filters.reduce((filterOptions, filter) => {\n    const formattedOption = {\n      value: filter.key,\n      label: filter.label,\n      isDisabled: filter.isDisabled,\n    };\n    //if theres a groupkey, filterGroups, and the groupKey matches a filterGroup, add option to its group\n    if (filter.groupKey && filterGroups) {\n      const optionGroup = filterOptions.find(\n        (option) => 'key' in option && option.key === filter.groupKey\n      );\n      if (optionGroup && 'options' in optionGroup) {\n        optionGroup.options.push(formattedOption);\n        return filterOptions;\n      }\n    }\n    // otherwise add option directly\n    return [formattedOption, ...filterOptions];\n  }, filterOptions);\n}\n\nfunction Filters({\n  appliedFilters,\n  filters,\n  filterGroups,\n  onClearAllRequest,\n  onAddFilterRequest,\n  renderSearchComponent,\n  defaultOpen = false,\n}: TFiltersProps) {\n  const intl = useIntl();\n  const [showFilterControls, setShowFilterControls] = useState(defaultOpen);\n\n  const handleFiltersClick = () => {\n    setShowFilterControls((currState) => !currState);\n  };\n  /**\n   * persisted filters: always visible\n   * applied filters: filters for which values have been selected\n   * visible filters = persisted + applied\n   *\n   * visibleFiltersFromProps = filters visible based on props\n   * localVisibleFilters = filters actually visible in component currently\n   */\n  const persistedFilterKeys = filters\n    .filter(({ isPersistent }) => isPersistent)\n    .map((filter) => filter.key);\n\n  const persistedFiltersRef = useRef<string[]>(persistedFilterKeys);\n\n  const appliedFilterKeys = appliedFilters.map(({ filterKey }) => filterKey);\n\n  // applied filters must have corresponding filter in `props.filters`,\n  const visibleFiltersFromProps = filters\n    .filter(({ key, isPersistent }) => {\n      const isVisible =\n        Boolean(isPersistent) || appliedFilterKeys.includes(key);\n      return isVisible;\n    })\n    // persistent filters should be first in filter list\n    .sort(({ isPersistent }) => (isPersistent ? -1 : 1));\n\n  // set initial state as visibleFiltersFromProps\n  const [localVisibleFilters, setLocalVisibleFilters] = useState<string[]>(\n    visibleFiltersFromProps.map(({ key }) => key)\n  );\n\n  //update localVisibleFilters if persisted filter count changes\n  if (persistedFiltersRef.current.length !== persistedFilterKeys.length) {\n    setLocalVisibleFilters(visibleFiltersFromProps.map(({ key }) => key));\n    persistedFiltersRef.current = persistedFilterKeys;\n  }\n\n  const removeFilter = (filterKey: string) =>\n    setLocalVisibleFilters((currentVisibleFilters) =>\n      currentVisibleFilters.filter(\n        (visibleFilterKey) => visibleFilterKey !== filterKey\n      )\n    );\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {renderSearchComponent}\n        </div>\n        <Spacings.Inline scale=\"s\" alignItems=\"center\">\n          <FlatButton\n            label={intl.formatMessage(messages.filtersButtonLabel)}\n            icon={<FilterIcon />}\n            onClick={handleFiltersClick}\n          />\n          {appliedFilters.length > 1 && !showFilterControls && (\n            <Badge\n              id={'uikit-filters-selected-filter-count'}\n              label={`${appliedFilters.length}`}\n            />\n          )}\n        </Spacings.Inline>\n      </Spacings.Inline>\n      <hr css={horizontalDividerStyles} />\n      <CollapsibleMotion\n        isClosed={!showFilterControls}\n        onToggle={() => setShowFilterControls(!showFilterControls)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div\n              ref={registerContentNode}\n              css={menuListStyles}\n              aria-live=\"polite\"\n            >\n              {localVisibleFilters.map((activeFilter) => {\n                const activeFilterConfig = filters.find(\n                  (filter) => filter.key === activeFilter\n                )!;\n                return (\n                  <FilterMenu\n                    key={activeFilterConfig.key}\n                    filterKey={activeFilterConfig.key}\n                    label={activeFilterConfig.label}\n                    operatorLabel={activeFilterConfig.operatorLabel}\n                    isPersistent={activeFilterConfig.isPersistent}\n                    isDisabled={activeFilterConfig.isDisabled}\n                    renderMenuBody={\n                      activeFilterConfig.filterMenuConfiguration.renderMenuBody\n                    }\n                    renderOperatorsInput={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderOperatorsInput\n                    }\n                    renderApplyButton={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderApplyButton\n                    }\n                    appliedFilterValues={\n                      appliedFilters.find(\n                        (appliedFilter) =>\n                          activeFilter === appliedFilter.filterKey\n                      )?.values\n                    }\n                    onClearRequest={\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest\n                    }\n                    onRemoveRequest={(e) => {\n                      removeFilter(activeFilter);\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest(\n                        e\n                      );\n                    }}\n                    onSortRequest={\n                      activeFilterConfig.filterMenuConfiguration.onSortRequest\n                    }\n                    defaultOpen={\n                      activeFilterConfig.isPersistent ||\n                      localVisibleFilters.length ===\n                        visibleFiltersFromProps.length\n                        ? false\n                        : true\n                    }\n                  />\n                );\n              })}\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={(e) => {\n                        if (onAddFilterRequest) {\n                          onAddFilterRequest(e);\n                        }\n                        setShowFilterControls(true);\n                      }}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content\n                    side=\"bottom\"\n                    align=\"start\"\n                    css={[menuStyles, menuBodyStyle]}\n                  >\n                    <SelectInput\n                      id=\"ui-kit-add-filters-select\"\n                      name=\"select filters\"\n                      aria-label=\"select filters\"\n                      appearance=\"filter\"\n                      options={\n                        getFilterOptions(filters, filterGroups) as TOption[]\n                      }\n                      onChange={(e) => {\n                        setLocalVisibleFilters(\n                          Array.prototype.concat(\n                            e.target.value ? e.target.value : []\n                          )\n                        );\n                      }}\n                      value={localVisibleFilters}\n                      isMulti={true}\n                      // @ts-ignore\n                      isOptionDisabled={(option: TAddFilterSelectOption) =>\n                        option.isDisabled\n                      }\n                    />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              {appliedFilters.length > 1 && (\n                <>\n                  <div css={verticalDividerStyles} />\n                  <FlatButton\n                    icon={<CloseBoldIcon />}\n                    label={intl.formatMessage(\n                      messages.clearAllFiltersButtonLabel\n                    )}\n                    onClick={(e) => {\n                      onClearAllRequest(e);\n                      setLocalVisibleFilters(persistedFilterKeys);\n                    }}\n                    tone=\"secondary\"\n                  />\n                </>\n              )}\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */",
459
+ styles: "display:inline-flex;label:Filters;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AAwWuB","file":"filters.tsx","sourcesContent":["import {\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n  useRef,\n  useState,\n} from 'react';\nimport { css } from '@emotion/react';\nimport * as Popover from '@radix-ui/react-popover';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport SelectInput, {\n  TOption,\n  TOptionObject,\n} from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { useIntl } from 'react-intl';\nimport FilterMenu, {\n  menuStyles,\n  menuBodyStyle,\n  type TAppliedFilterValue,\n} from './filter-menu';\nimport messages from './messages';\nimport { Badge } from './badge';\n\ninterface TAddFilterSelectOption extends TOption {\n  isDisabled?: boolean;\n}\n\ninterface TAddFilterOptionGroup extends TOptionObject {\n  options: TAddFilterSelectOption[];\n  label: ReactNode;\n  key: string;\n}\n\nexport type TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\nexport type TFilterConfiguration = {\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n  /**\n   * formatted message to display the selected operator value\n   */\n  operatorLabel?: ReactNode;\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactNode;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactNode;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * indicates whether the filter is disabled\n   */\n  isDisabled?: boolean;\n};\n\nexport type TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   *\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   *\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n\n  /**\n   * controls the `clear all` (added filters) button from the menu list, meant to clear the parent application's filter state\n   */\n  onClearAllRequest: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * optional callback when the add filter button is clicked\n   */\n  onAddFilterRequest?: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: ReactNode;\n  /**\n   * controls whether the filters list is initially open\n   */\n  defaultOpen?: boolean;\n};\n\nconst horizontalDividerStyles = css`\n  color: ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral90};\n  width: 100%;\n  height: 1px;\n  border: 0;\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction getFilterOptions(\n  filters: TFilterConfiguration[],\n  filterGroups?: TFilterGroupConfiguration[]\n): (TAddFilterSelectOption | TAddFilterOptionGroup)[] {\n  let filterOptions: (TAddFilterSelectOption | TAddFilterOptionGroup)[] = [];\n  // define option groups\n  if (filterGroups) {\n    filterOptions = filterGroups.map((filterGroup) => ({\n      label: filterGroup.label,\n      key: filterGroup.key,\n      options: [],\n    }));\n  }\n  return filters.reduce((filterOptions, filter) => {\n    const formattedOption = {\n      value: filter.key,\n      label: filter.label,\n      isDisabled: filter.isDisabled,\n    };\n    //if theres a groupkey, filterGroups, and the groupKey matches a filterGroup, add option to its group\n    if (filter.groupKey && filterGroups) {\n      const optionGroup = filterOptions.find(\n        (option) => 'key' in option && option.key === filter.groupKey\n      );\n      if (optionGroup && 'options' in optionGroup) {\n        optionGroup.options.push(formattedOption);\n        return filterOptions;\n      }\n    }\n    // otherwise add option directly\n    return [formattedOption, ...filterOptions];\n  }, filterOptions);\n}\n\nfunction Filters({\n  appliedFilters,\n  filters,\n  filterGroups,\n  onClearAllRequest,\n  onAddFilterRequest,\n  renderSearchComponent,\n  defaultOpen = false,\n}: TFiltersProps) {\n  const intl = useIntl();\n  const [showFilterControls, setShowFilterControls] = useState(defaultOpen);\n\n  const handleFiltersClick = () => {\n    setShowFilterControls((currState) => !currState);\n  };\n  /**\n   * persisted filters: always visible\n   * applied filters: filters for which values have been selected\n   * visible filters = persisted + applied\n   *\n   * visibleFiltersFromProps = filters visible based on props\n   * localVisibleFilters = filters actually visible in component currently\n   */\n  const persistedFilterKeys = filters\n    .filter(({ isPersistent }) => isPersistent)\n    .map((filter) => filter.key);\n\n  const persistedFiltersRef = useRef<string[]>(persistedFilterKeys);\n\n  const appliedFilterKeys = appliedFilters.map(({ filterKey }) => filterKey);\n\n  // applied filters must have corresponding filter in `props.filters`,\n  const visibleFiltersFromProps = filters\n    .filter(({ key, isPersistent }) => {\n      const isVisible =\n        Boolean(isPersistent) || appliedFilterKeys.includes(key);\n      return isVisible;\n    })\n    // persistent filters should be first in filter list\n    .sort(({ isPersistent }) => (isPersistent ? -1 : 1));\n\n  // set initial state as visibleFiltersFromProps\n  const [localVisibleFilters, setLocalVisibleFilters] = useState<string[]>(\n    visibleFiltersFromProps.map(({ key }) => key)\n  );\n\n  //update localVisibleFilters if persisted filter count changes\n  if (persistedFiltersRef.current.length !== persistedFilterKeys.length) {\n    setLocalVisibleFilters(visibleFiltersFromProps.map(({ key }) => key));\n    persistedFiltersRef.current = persistedFilterKeys;\n  }\n\n  const removeFilter = (filterKey: string) =>\n    setLocalVisibleFilters((currentVisibleFilters) =>\n      currentVisibleFilters.filter(\n        (visibleFilterKey) => visibleFilterKey !== filterKey\n      )\n    );\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {renderSearchComponent}\n        </div>\n        <Spacings.Inline scale=\"s\" alignItems=\"center\">\n          <FlatButton\n            label={intl.formatMessage(messages.filtersButtonLabel)}\n            icon={<FilterIcon />}\n            onClick={handleFiltersClick}\n          />\n          {appliedFilters.length > 1 && !showFilterControls && (\n            <Badge\n              id={'uikit-filters-selected-filter-count'}\n              label={`${appliedFilters.length}`}\n            />\n          )}\n        </Spacings.Inline>\n      </Spacings.Inline>\n      <hr css={horizontalDividerStyles} />\n      <CollapsibleMotion\n        isClosed={!showFilterControls}\n        onToggle={() => setShowFilterControls(!showFilterControls)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div\n              ref={registerContentNode}\n              css={menuListStyles}\n              aria-live=\"polite\"\n            >\n              {localVisibleFilters.map((activeFilter) => {\n                const activeFilterConfig = filters.find(\n                  (filter) => filter.key === activeFilter\n                )!;\n                return (\n                  <FilterMenu\n                    key={activeFilterConfig.key}\n                    filterKey={activeFilterConfig.key}\n                    label={activeFilterConfig.label}\n                    operatorLabel={activeFilterConfig.operatorLabel}\n                    isPersistent={activeFilterConfig.isPersistent}\n                    isDisabled={activeFilterConfig.isDisabled}\n                    renderMenuBody={\n                      activeFilterConfig.filterMenuConfiguration.renderMenuBody\n                    }\n                    renderOperatorsInput={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderOperatorsInput\n                    }\n                    renderApplyButton={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderApplyButton\n                    }\n                    appliedFilterValues={\n                      appliedFilters.find(\n                        (appliedFilter) =>\n                          activeFilter === appliedFilter.filterKey\n                      )?.values\n                    }\n                    onClearRequest={\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest\n                    }\n                    onRemoveRequest={(e) => {\n                      removeFilter(activeFilter);\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest(\n                        e\n                      );\n                    }}\n                    onSortRequest={\n                      activeFilterConfig.filterMenuConfiguration.onSortRequest\n                    }\n                    defaultOpen={\n                      activeFilterConfig.isPersistent ||\n                      localVisibleFilters.length ===\n                        visibleFiltersFromProps.length\n                        ? false\n                        : true\n                    }\n                  />\n                );\n              })}\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={(e) => {\n                        if (onAddFilterRequest) {\n                          onAddFilterRequest(e);\n                        }\n                        setShowFilterControls(true);\n                      }}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content\n                    side=\"bottom\"\n                    align=\"start\"\n                    css={[menuStyles, menuBodyStyle]}\n                  >\n                    <SelectInput\n                      id=\"ui-kit-add-filters-select\"\n                      name=\"select filters\"\n                      aria-label=\"select filters\"\n                      appearance=\"filter\"\n                      options={\n                        getFilterOptions(filters, filterGroups) as TOption[]\n                      }\n                      onChange={(e) => {\n                        setLocalVisibleFilters(\n                          Array.prototype.concat(\n                            e.target.value ? e.target.value : []\n                          )\n                        );\n                      }}\n                      value={localVisibleFilters}\n                      isMulti={true}\n                      // @ts-ignore\n                      isOptionDisabled={(option: TAddFilterSelectOption) =>\n                        option.isDisabled\n                      }\n                    />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              {appliedFilters.length > 1 && (\n                <>\n                  <div css={verticalDividerStyles} />\n                  <FlatButton\n                    icon={<CloseBoldIcon />}\n                    label={intl.formatMessage(\n                      messages.clearAllFiltersButtonLabel\n                    )}\n                    onClick={(e) => {\n                      onClearAllRequest(e);\n                      setLocalVisibleFilters(persistedFilterKeys);\n                    }}\n                    tone=\"secondary\"\n                  />\n                </>\n              )}\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */",
463
460
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
464
461
  };
465
462
  function Filters(_ref) {
@@ -674,7 +671,7 @@ Filters.propTypes = process.env.NODE_ENV !== "production" ? {
674
671
  Filters.displayName = 'Filters';
675
672
 
676
673
  // NOTE: This string will be replaced on build time with the package version.
677
- var version = "19.22.1";
674
+ var version = "19.22.3";
678
675
 
679
676
  exports["default"] = Filters;
680
677
  exports.version = version;
@@ -604,7 +604,7 @@ Filters.propTypes = {};
604
604
  Filters.displayName = 'Filters';
605
605
 
606
606
  // NOTE: This string will be replaced on build time with the package version.
607
- var version = "19.22.1";
607
+ var version = "19.22.3";
608
608
 
609
609
  exports["default"] = Filters;
610
610
  exports.version = version;
@@ -75,8 +75,7 @@ const operatorInputContainer = process.env.NODE_ENV === "production" ? {
75
75
  styles: "word-break:break-word;display:flex;align-items:center"
76
76
  } : {
77
77
  name: "8xu73l-operatorInputContainer",
78
- styles: "word-break:break-word;display:flex;align-items:center;label:operatorInputContainer;",
79
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0RrQyIsImZpbGUiOiJoZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdXNlU3RhdGUsXG4gIHR5cGUgUmVhY3ROb2RlLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IEljb25CdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvaWNvbi1idXR0b24nO1xuaW1wb3J0IHsgU29ydGluZ0ljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxudHlwZSBUSGVhZGVyUHJvcHMgPSB7XG4gIC8qKlxuICAgKiB0aGUgbGFiZWwgb2YgdGhlIG1lbnUgaGVhZGVyXG4gICAqL1xuICBsYWJlbDogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGZ1bmN0aW9uIHRvIHJlbmRlciB0aGUgb3BlcmF0b3IgaW5wdXRcbiAgICovXG4gIHJlbmRlck9wZXJhdG9yc0lucHV0PzogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGZ1bmN0aW9uIHRvIHNvcnQgdGhlIGRhdGFcbiAgICovXG4gIG9uU29ydFJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICAvKipcbiAgICogdGhlIHdpZHRoIG9mIHRoZSBtZW51IGhlYWRlclxuICAgKi9cbn07XG5cbmNvbnN0IGhlYWRlckNvbnRhaW5lclN0eWxlcyA9IGNzc2BcbiAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDQwfTtcbiAgZm9udC13ZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmZvbnRXZWlnaHQ1MDB9O1xuICBmb250LXNpemU6ICR7ZGVzaWduVG9rZW5zLmZvbnRTaXplMjB9O1xuICBsaW5lLWhlaWdodDogJHtkZXNpZ25Ub2tlbnMubGluZUhlaWdodDIwfTtcbiAgZGlzcGxheTogZ3JpZDtcbiAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAxZnIgbWluLWNvbnRlbnQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctYm90dG9tOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMTB9O1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICB3aWR0aDogMTAwJTtcbmA7XG5cbmNvbnN0IHNlbGVjdElucHV0U3R5bGVzID0gY3NzYFxuICBmbGV4OiAwIDAgYXV0bztcbiAgbWF4LXdpZHRoOiAke2Rlc2lnblRva2Vucy5jb25zdHJhaW50M307XG4gIG1hcmdpbi1sZWZ0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjB9O1xuYDtcblxuY29uc3Qgc29ydEJ1dHRvbk1hcmdpbiA9IGNzc2BcbiAgbWFyZ2luLXJpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNDB9O1xuYDtcblxuY29uc3Qgb3BlcmF0b3JJbnB1dENvbnRhaW5lciA9IGNzc2BcbiAgd29yZC1icmVhazogYnJlYWstd29yZDtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmA7XG5cbmNvbnN0IEhlYWRlciA9IChwcm9wczogVEhlYWRlclByb3BzKSA9PiB7XG4gIGNvbnN0IFtpc0FjdGl2ZSwgc2V0SXNBY3RpdmVdID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIHJldHVybiAoXG4gICAgPGhlYWRlciBjc3M9e2hlYWRlckNvbnRhaW5lclN0eWxlc30+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17W29wZXJhdG9ySW5wdXRDb250YWluZXIsIHByb3BzLm9uU29ydFJlcXVlc3QgJiYgc29ydEJ1dHRvbk1hcmdpbl19XG4gICAgICA+XG4gICAgICAgIDxkaXY+e3Byb3BzLmxhYmVsfTwvZGl2PlxuICAgICAgICB7cHJvcHMucmVuZGVyT3BlcmF0b3JzSW5wdXQgJiYgKFxuICAgICAgICAgIDxkaXYgY3NzPXtzZWxlY3RJbnB1dFN0eWxlc30+e3Byb3BzLnJlbmRlck9wZXJhdG9yc0lucHV0KCl9PC9kaXY+XG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICAgIHtwcm9wcy5vblNvcnRSZXF1ZXN0ICYmIChcbiAgICAgICAgPEljb25CdXR0b25cbiAgICAgICAgICBzaXplPVwiMjBcIlxuICAgICAgICAgIHRoZW1lPXtpc0FjdGl2ZSA/ICdpbmZvJyA6ICdkZWZhdWx0J31cbiAgICAgICAgICBsYWJlbD1cIlNvcnRcIlxuICAgICAgICAgIGljb249ezxTb3J0aW5nSWNvbiAvPn1cbiAgICAgICAgICBpc1RvZ2dsZUJ1dHRvbj17dHJ1ZX1cbiAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgc2V0SXNBY3RpdmUoIWlzQWN0aXZlKTtcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy5vblNvcnRSZXF1ZXN0ICYmIHByb3BzLm9uU29ydFJlcXVlc3QoZSk7XG4gICAgICAgICAgfX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC9oZWFkZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBIZWFkZXI7XG4iXX0= */",
78
+ styles: "word-break:break-word;display:flex;align-items:center;label:operatorInputContainer;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0RrQyIsImZpbGUiOiJoZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdXNlU3RhdGUsXG4gIHR5cGUgUmVhY3ROb2RlLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IEljb25CdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvaWNvbi1idXR0b24nO1xuaW1wb3J0IHsgU29ydGluZ0ljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxudHlwZSBUSGVhZGVyUHJvcHMgPSB7XG4gIC8qKlxuICAgKiB0aGUgbGFiZWwgb2YgdGhlIG1lbnUgaGVhZGVyXG4gICAqL1xuICBsYWJlbDogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGZ1bmN0aW9uIHRvIHJlbmRlciB0aGUgb3BlcmF0b3IgaW5wdXRcbiAgICovXG4gIHJlbmRlck9wZXJhdG9yc0lucHV0PzogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGZ1bmN0aW9uIHRvIHNvcnQgdGhlIGRhdGFcbiAgICovXG4gIG9uU29ydFJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICAvKipcbiAgICogdGhlIHdpZHRoIG9mIHRoZSBtZW51IGhlYWRlclxuICAgKi9cbn07XG5cbmNvbnN0IGhlYWRlckNvbnRhaW5lclN0eWxlcyA9IGNzc2BcbiAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDQwfTtcbiAgZm9udC13ZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmZvbnRXZWlnaHQ1MDB9O1xuICBmb250LXNpemU6ICR7ZGVzaWduVG9rZW5zLmZvbnRTaXplMjB9O1xuICBsaW5lLWhlaWdodDogJHtkZXNpZ25Ub2tlbnMubGluZUhlaWdodDIwfTtcbiAgZGlzcGxheTogZ3JpZDtcbiAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAxZnIgbWluLWNvbnRlbnQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctYm90dG9tOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMTB9O1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICB3aWR0aDogMTAwJTtcbmA7XG5cbmNvbnN0IHNlbGVjdElucHV0U3R5bGVzID0gY3NzYFxuICBmbGV4OiAwIDAgYXV0bztcbiAgbWF4LXdpZHRoOiAke2Rlc2lnblRva2Vucy5jb25zdHJhaW50M307XG4gIG1hcmdpbi1sZWZ0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjB9O1xuYDtcblxuY29uc3Qgc29ydEJ1dHRvbk1hcmdpbiA9IGNzc2BcbiAgbWFyZ2luLXJpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNDB9O1xuYDtcblxuY29uc3Qgb3BlcmF0b3JJbnB1dENvbnRhaW5lciA9IGNzc2BcbiAgd29yZC1icmVhazogYnJlYWstd29yZDtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmA7XG5cbmNvbnN0IEhlYWRlciA9IChwcm9wczogVEhlYWRlclByb3BzKSA9PiB7XG4gIGNvbnN0IFtpc0FjdGl2ZSwgc2V0SXNBY3RpdmVdID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIHJldHVybiAoXG4gICAgPGhlYWRlciBjc3M9e2hlYWRlckNvbnRhaW5lclN0eWxlc30+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17W29wZXJhdG9ySW5wdXRDb250YWluZXIsIHByb3BzLm9uU29ydFJlcXVlc3QgJiYgc29ydEJ1dHRvbk1hcmdpbl19XG4gICAgICA+XG4gICAgICAgIDxkaXY+e3Byb3BzLmxhYmVsfTwvZGl2PlxuICAgICAgICB7cHJvcHMucmVuZGVyT3BlcmF0b3JzSW5wdXQgJiYgKFxuICAgICAgICAgIDxkaXYgY3NzPXtzZWxlY3RJbnB1dFN0eWxlc30+e3Byb3BzLnJlbmRlck9wZXJhdG9yc0lucHV0KCl9PC9kaXY+XG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICAgIHtwcm9wcy5vblNvcnRSZXF1ZXN0ICYmIChcbiAgICAgICAgPEljb25CdXR0b25cbiAgICAgICAgICBzaXplPVwiMjBcIlxuICAgICAgICAgIHRoZW1lPXtpc0FjdGl2ZSA/ICdpbmZvJyA6ICdkZWZhdWx0J31cbiAgICAgICAgICBsYWJlbD1cIlNvcnRcIlxuICAgICAgICAgIGljb249ezxTb3J0aW5nSWNvbiAvPn1cbiAgICAgICAgICBpc1RvZ2dsZUJ1dHRvbj17dHJ1ZX1cbiAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgc2V0SXNBY3RpdmUoIWlzQWN0aXZlKTtcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy5vblNvcnRSZXF1ZXN0ICYmIHByb3BzLm9uU29ydFJlcXVlc3QoZSk7XG4gICAgICAgICAgfX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC9oZWFkZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBIZWFkZXI7XG4iXX0= */",
80
79
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
81
80
  };
82
81
  const Header = props => {
@@ -285,8 +284,7 @@ const menuBodyStyle = process.env.NODE_ENV === "production" ? {
285
284
  styles: "width:100%;overflow:hidden auto"
286
285
  } : {
287
286
  name: "a5of5h-menuBodyStyle",
288
- styles: "width:100%;overflow:hidden auto;label:menuBodyStyle;",
289
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbHRlci1tZW51LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvSGdDIiwiZmlsZSI6ImZpbHRlci1tZW51LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIHR5cGUgUmVhY3ROb2RlLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbiAgdXNlUmVmLFxuICB1c2VDYWxsYmFjayxcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgKiBhcyBQb3BvdmVyIGZyb20gJ0ByYWRpeC11aS9yZWFjdC1wb3BvdmVyJztcbmltcG9ydCB7IEZvb3RlciB9IGZyb20gJy4vZm9vdGVyJztcbmltcG9ydCB7IEhlYWRlciB9IGZyb20gJy4vaGVhZGVyJztcbmltcG9ydCB7IFRyaWdnZXJCdXR0b24gfSBmcm9tICcuL3RyaWdnZXItYnV0dG9uJztcblxuLyoqXG4gKiBDU1Mgc2VsZWN0b3IgdG8gZmluZCBmb2N1c2FibGUgZWxlbWVudHMuXG4gKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9taWNyb3NvZnQvdGFic3Rlci9ibG9iLzZiZmQ1NGE0NWY1YjIwZWNjZDE3YjhhMDVmNmM4NmMyNDFiOTkyYzMvc3JjL0ZvY3VzYWJsZS50cyNMMTctTDI1XG4gKiBUT0RPOiBtYWtlIGF2YWlsYWJsZSBhcyBhIHV0aWwgZm9yIGdlbmVyYWwgdXNlXG4gKi9cbmNvbnN0IEZPQ1VTQUJMRV9DU1NfU0VMRUNUT1IgPSBgYVtocmVmXSwgYnV0dG9uOm5vdChbZGlzYWJsZWRdKSwgaW5wdXQ6bm90KFtkaXNhYmxlZF0pLCBzZWxlY3Q6bm90KFtkaXNhYmxlZF0pLCB0ZXh0YXJlYTpub3QoW2Rpc2FibGVkXSksICpbdGFiaW5kZXhdLCAqW2NvbnRlbnRlZGl0YWJsZV1gO1xuXG4vKipcbiAqIEZpbmQgdGhlIGZpcnN0IGZvY3VzYWJsZSBlbGVtZW50IGluIHRoZSBnaXZlbiBjb250YWluZXIsXG4gKiBzdWNoIGFzIHRoZSBmaXJzdCBmb2N1c2FibGUgbGlzdCBpdGVtLlxuICogQHBhcmFtIHtIVE1MRWxlbWVudH0gY29udGFpbmVyXG4gKiBAcmV0dXJucyB7SFRNTEVsZW1lbnQgfCBudWxsfVxuICovXG5mdW5jdGlvbiBmaW5kRmlyc3RGb2N1c2FibGU8VCBleHRlbmRzIEhUTUxFbGVtZW50Pihjb250YWluZXI6IFQpOiBUIHwgbnVsbCB7XG4gIHJldHVybiBjb250YWluZXIucXVlcnlTZWxlY3RvcihGT0NVU0FCTEVfQ1NTX1NFTEVDVE9SKTtcbn1cblxuZXhwb3J0IHR5cGUgVEFwcGxpZWRGaWx0ZXJWYWx1ZSA9IHtcbiAgdmFsdWU6IHN0cmluZztcbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbn07XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51UHJvcHMgPSB7XG4gIC8qKlxuICAgKiB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIGZpbHRlclxuICAgKi9cbiAgZmlsdGVyS2V5OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBmb3JtYXR0ZWQgbWVzc2FnZSB0byBkaXNwbGF5IHRoZSBmaWx0ZXIncyBuYW1lXG4gICAqL1xuICBsYWJlbDogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIHNlbGVjdHMgdmFsdWVzIGZvciB0aGUgZmlsdGVyXG4gICAqL1xuICByZW5kZXJNZW51Qm9keTogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIGNhbiBzZWxlY3Qgd2hpY2ggb3BlcmF0b3Igc2hvdWxkIGJlIHVzZWQgZm9yIHRoaXMgZmlsdGVyXG4gICAqL1xuICByZW5kZXJPcGVyYXRvcnNJbnB1dD86ICgpID0+IFJlYWN0Tm9kZTtcbiAgLyoqXG4gICAqIGZvcm1hdHRlZCBtZXNzYWdlIHRvIGRpc3BsYXkgdGhlIHNlbGVjdGVkIG9wZXJhdG9yIHZhbHVlXG4gICAqL1xuICBvcGVyYXRvckxhYmVsPzogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIHZhbHVlcyBhcHBsaWVkIHRvIHRoaXMgZmlsdGVyIGJ5IHRoZSB1c2VyXG4gICAqL1xuICBhcHBsaWVkRmlsdGVyVmFsdWVzOiBUQXBwbGllZEZpbHRlclZhbHVlW10gfCB1bmRlZmluZWQgfCBudWxsO1xuICAvKipcbiAgICogaW5kaWNhdGVzIHdoZXRoZXIgRmlsdGVyTWVudSBjYW4gYmUgcmVtb3ZlZCBmcm9tIHRoZSBmaWx0ZXJzTGlzdFxuICAgKi9cbiAgaXNQZXJzaXN0ZW50PzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIHdoZXRoZXIgb3Igbm90IHRoZSBmaWx0ZXIgaXMgZGlzYWJsZWRcbiAgICovXG4gIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgeGAgaW4gVHJpZ2dlciBCdXR0b24gaXMgZGlzcGxheWVkIC0gcmVxdWlyZWQgaWYgYGlzUGVyc2lzdGVudGAgaXMgYGZhbHNlYFxuICAgKi9cbiAgb25SZW1vdmVSZXF1ZXN0PzogKFxuICAgIGV2ZW50PzogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4gfCBLZXlib2FyZEV2ZW50PEhUTUxCdXR0b25FbGVtZW50PlxuICApID0+IHZvaWQ7XG4gIC8qKlxuICAgKiBvcHRpb25hbCBidXR0b24gdGhhdCBhbGxvd3MgdGhlIHVzZXIgdG8gYXBwbHkgc2VsZWN0ZWQgZmlsdGVyIHZhbHVlc1xuICAgKi9cbiAgcmVuZGVyQXBwbHlCdXR0b24/OiAoKSA9PiBSZWFjdE5vZGU7XG4gIC8qKlxuICAgKiBjb250cm9scyB3aGV0aGVyIGBjbGVhciBhbGxgIGJ1dHRvbiBpbiBNZW51IEJvZHkgRm9vdGVyIGlzIGRpc3BsYXllZFxuICAgKi9cbiAgb25DbGVhclJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgc29ydGAgYnV0dG9uIGluIE1lbnUgQm9keSBIZWFkZXIgaXMgZGlzcGxheWVkXG4gICAqL1xuICBvblNvcnRSZXF1ZXN0PzogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgLyoqXG4gICAqIGNvbnRyb2xzIHdoZXRoZXIgbWVudSBpcyBvcGVuIG9uIGluaXRpYWwgcmVuZGVyXG4gICAqL1xuICBkZWZhdWx0T3Blbj86IGJvb2xlYW47XG59O1xuXG5leHBvcnQgY29uc3QgbWVudVN0eWxlcyA9IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzMwfTtcbiAgd2lkdGg6ICR7ZGVzaWduVG9rZW5zLmNvbnN0cmFpbnQ2fTtcbiAgbWF4LWhlaWdodDogJHtkZXNpZ25Ub2tlbnMuY29uc3RyYWludDEwfTtcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzIwfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nMzB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXI6IDFweCBzb2xpZCAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM4fTtcbiAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93MTh9O1xuICBhbmltYXRpb24tZHVyYXRpb246ICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gIHdpbGwtY2hhbmdlOiAndHJhbnNmb3JtLCBvcGFjaXR5JztcbiAgbWFyZ2luLXRvcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB6LWluZGV4OiA1O1xuYDtcblxuZXhwb3J0IGNvbnN0IG1lbnVCb2R5U3R5bGUgPSBjc3NgXG4gIHdpZHRoOiAxMDAlO1xuXG4gIC8qKiBlbnN1cmUgdGhhdCBib2R5IHNjcm9sbHMgd2l0aCBvdmVyZmxvdyBub3cgdGhhdCB0aGVyZSBpcyBhIG1lbnUgbWF4LWhlaWdodCAqL1xuICBvdmVyZmxvdzogaGlkZGVuIGF1dG87XG5gO1xuXG5mdW5jdGlvbiBGaWx0ZXJNZW51KHByb3BzOiBURmlsdGVyTWVudVByb3BzKSB7XG4gIGNvbnN0IG1lbnVCb2R5UmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICBjb25zdCBmb2N1c01lbnVCb2R5ID0gdXNlQ2FsbGJhY2soXG4gICAgKGUpID0+IHtcbiAgICAgIGlmIChtZW51Qm9keVJlZi5jdXJyZW50KSB7XG4gICAgICAgIGNvbnN0IGZpcnN0Rm9jdXNhYmxlRWxlbWVudEluTWVudUJvZHkgPSBmaW5kRmlyc3RGb2N1c2FibGUoXG4gICAgICAgICAgbWVudUJvZHlSZWYuY3VycmVudFxuICAgICAgICApO1xuICAgICAgICBpZiAoZmlyc3RGb2N1c2FibGVFbGVtZW50SW5NZW51Qm9keSkge1xuICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICBmaXJzdEZvY3VzYWJsZUVsZW1lbnRJbk1lbnVCb2R5LmZvY3VzKCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9LFxuICAgIFttZW51Qm9keVJlZl1cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxQb3BvdmVyLlJvb3RcbiAgICAgIGRlZmF1bHRPcGVuPXtwcm9wcy5pc0Rpc2FibGVkID8gZmFsc2UgOiBwcm9wcy5kZWZhdWx0T3Blbn1cbiAgICAgIG9uT3BlbkNoYW5nZT17KG9wZW4pID0+IHtcbiAgICAgICAgaWYgKFxuICAgICAgICAgICFvcGVuICYmXG4gICAgICAgICAgIXByb3BzLmFwcGxpZWRGaWx0ZXJWYWx1ZXM/Lmxlbmd0aCAmJlxuICAgICAgICAgICFwcm9wcy5pc1BlcnNpc3RlbnQgJiZcbiAgICAgICAgICBwcm9wcy5vblJlbW92ZVJlcXVlc3RcbiAgICAgICAgKSB7XG4gICAgICAgICAgcHJvcHMub25SZW1vdmVSZXF1ZXN0KCk7XG4gICAgICAgIH1cbiAgICAgIH19XG4gICAgPlxuICAgICAgPFBvcG92ZXIuVHJpZ2dlciBhc0NoaWxkPlxuICAgICAgICA8VHJpZ2dlckJ1dHRvblxuICAgICAgICAgIGZpbHRlcktleT17cHJvcHMuZmlsdGVyS2V5fVxuICAgICAgICAgIGxhYmVsPXtwcm9wcy5sYWJlbH1cbiAgICAgICAgICBvcGVyYXRvckxhYmVsPXtwcm9wcy5vcGVyYXRvckxhYmVsfVxuICAgICAgICAgIGFwcGxpZWRGaWx0ZXJWYWx1ZXM9e3Byb3BzLmFwcGxpZWRGaWx0ZXJWYWx1ZXN9XG4gICAgICAgICAgaXNEaXNhYmxlZD17cHJvcHMuaXNEaXNhYmxlZH1cbiAgICAgICAgICBpc1BlcnNpc3RlbnQ9e3Byb3BzLmlzUGVyc2lzdGVudH1cbiAgICAgICAgICBvblJlbW92ZVJlcXVlc3Q9e3Byb3BzLm9uUmVtb3ZlUmVxdWVzdH1cbiAgICAgICAgLz5cbiAgICAgIDwvUG9wb3Zlci5UcmlnZ2VyPlxuICAgICAgPFBvcG92ZXIuUG9ydGFsPlxuICAgICAgICA8UG9wb3Zlci5Db250ZW50XG4gICAgICAgICAgc2lkZT1cImJvdHRvbVwiXG4gICAgICAgICAgYWxpZ249XCJzdGFydFwiXG4gICAgICAgICAgY3NzPXttZW51U3R5bGVzfVxuICAgICAgICAgIG9uT3BlbkF1dG9Gb2N1cz17Zm9jdXNNZW51Qm9keX1cbiAgICAgICAgPlxuICAgICAgICAgIDxIZWFkZXJcbiAgICAgICAgICAgIGxhYmVsPXtwcm9wcy5sYWJlbH1cbiAgICAgICAgICAgIHJlbmRlck9wZXJhdG9yc0lucHV0PXtwcm9wcy5yZW5kZXJPcGVyYXRvcnNJbnB1dH1cbiAgICAgICAgICAgIG9uU29ydFJlcXVlc3Q9e3Byb3BzLm9uU29ydFJlcXVlc3R9XG4gICAgICAgICAgLz5cbiAgICAgICAgICA8ZGl2IGNzcz17bWVudUJvZHlTdHlsZX0gcmVmPXttZW51Qm9keVJlZn0+XG4gICAgICAgICAgICB7cHJvcHMucmVuZGVyTWVudUJvZHkoKX1cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8Rm9vdGVyXG4gICAgICAgICAgICBvbkNsZWFyUmVxdWVzdD17cHJvcHMub25DbGVhclJlcXVlc3R9XG4gICAgICAgICAgICByZW5kZXJBcHBseUJ1dHRvbj17cHJvcHMucmVuZGVyQXBwbHlCdXR0b259XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9Qb3BvdmVyLkNvbnRlbnQ+XG4gICAgICA8L1BvcG92ZXIuUG9ydGFsPlxuICAgIDwvUG9wb3Zlci5Sb290PlxuICApO1xufVxuXG5leHBvcnQgZGVmYXVsdCBGaWx0ZXJNZW51O1xuIl19 */",
287
+ styles: "width:100%;overflow:hidden auto;label:menuBodyStyle;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbHRlci1tZW51LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvSGdDIiwiZmlsZSI6ImZpbHRlci1tZW51LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIHR5cGUgUmVhY3ROb2RlLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbiAgdXNlUmVmLFxuICB1c2VDYWxsYmFjayxcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgKiBhcyBQb3BvdmVyIGZyb20gJ0ByYWRpeC11aS9yZWFjdC1wb3BvdmVyJztcbmltcG9ydCB7IEZvb3RlciB9IGZyb20gJy4vZm9vdGVyJztcbmltcG9ydCB7IEhlYWRlciB9IGZyb20gJy4vaGVhZGVyJztcbmltcG9ydCB7IFRyaWdnZXJCdXR0b24gfSBmcm9tICcuL3RyaWdnZXItYnV0dG9uJztcblxuLyoqXG4gKiBDU1Mgc2VsZWN0b3IgdG8gZmluZCBmb2N1c2FibGUgZWxlbWVudHMuXG4gKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9taWNyb3NvZnQvdGFic3Rlci9ibG9iLzZiZmQ1NGE0NWY1YjIwZWNjZDE3YjhhMDVmNmM4NmMyNDFiOTkyYzMvc3JjL0ZvY3VzYWJsZS50cyNMMTctTDI1XG4gKiBUT0RPOiBtYWtlIGF2YWlsYWJsZSBhcyBhIHV0aWwgZm9yIGdlbmVyYWwgdXNlXG4gKi9cbmNvbnN0IEZPQ1VTQUJMRV9DU1NfU0VMRUNUT1IgPSBgYVtocmVmXSwgYnV0dG9uOm5vdChbZGlzYWJsZWRdKSwgaW5wdXQ6bm90KFtkaXNhYmxlZF0pLCBzZWxlY3Q6bm90KFtkaXNhYmxlZF0pLCB0ZXh0YXJlYTpub3QoW2Rpc2FibGVkXSksICpbdGFiaW5kZXhdLCAqW2NvbnRlbnRlZGl0YWJsZV1gO1xuXG4vKipcbiAqIEZpbmQgdGhlIGZpcnN0IGZvY3VzYWJsZSBlbGVtZW50IGluIHRoZSBnaXZlbiBjb250YWluZXIsXG4gKiBzdWNoIGFzIHRoZSBmaXJzdCBmb2N1c2FibGUgbGlzdCBpdGVtLlxuICogQHBhcmFtIHtIVE1MRWxlbWVudH0gY29udGFpbmVyXG4gKiBAcmV0dXJucyB7SFRNTEVsZW1lbnQgfCBudWxsfVxuICovXG5mdW5jdGlvbiBmaW5kRmlyc3RGb2N1c2FibGU8VCBleHRlbmRzIEhUTUxFbGVtZW50Pihjb250YWluZXI6IFQpOiBUIHwgbnVsbCB7XG4gIHJldHVybiBjb250YWluZXIucXVlcnlTZWxlY3RvcihGT0NVU0FCTEVfQ1NTX1NFTEVDVE9SKTtcbn1cblxuZXhwb3J0IHR5cGUgVEFwcGxpZWRGaWx0ZXJWYWx1ZSA9IHtcbiAgdmFsdWU6IHN0cmluZztcbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbn07XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51UHJvcHMgPSB7XG4gIC8qKlxuICAgKiB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIGZpbHRlclxuICAgKi9cbiAgZmlsdGVyS2V5OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBmb3JtYXR0ZWQgbWVzc2FnZSB0byBkaXNwbGF5IHRoZSBmaWx0ZXIncyBuYW1lXG4gICAqL1xuICBsYWJlbDogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIHNlbGVjdHMgdmFsdWVzIGZvciB0aGUgZmlsdGVyXG4gICAqL1xuICByZW5kZXJNZW51Qm9keTogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIGNhbiBzZWxlY3Qgd2hpY2ggb3BlcmF0b3Igc2hvdWxkIGJlIHVzZWQgZm9yIHRoaXMgZmlsdGVyXG4gICAqL1xuICByZW5kZXJPcGVyYXRvcnNJbnB1dD86ICgpID0+IFJlYWN0Tm9kZTtcbiAgLyoqXG4gICAqIGZvcm1hdHRlZCBtZXNzYWdlIHRvIGRpc3BsYXkgdGhlIHNlbGVjdGVkIG9wZXJhdG9yIHZhbHVlXG4gICAqL1xuICBvcGVyYXRvckxhYmVsPzogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIHZhbHVlcyBhcHBsaWVkIHRvIHRoaXMgZmlsdGVyIGJ5IHRoZSB1c2VyXG4gICAqL1xuICBhcHBsaWVkRmlsdGVyVmFsdWVzOiBUQXBwbGllZEZpbHRlclZhbHVlW10gfCB1bmRlZmluZWQgfCBudWxsO1xuICAvKipcbiAgICogaW5kaWNhdGVzIHdoZXRoZXIgRmlsdGVyTWVudSBjYW4gYmUgcmVtb3ZlZCBmcm9tIHRoZSBmaWx0ZXJzTGlzdFxuICAgKi9cbiAgaXNQZXJzaXN0ZW50PzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIHdoZXRoZXIgb3Igbm90IHRoZSBmaWx0ZXIgaXMgZGlzYWJsZWRcbiAgICovXG4gIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgeGAgaW4gVHJpZ2dlciBCdXR0b24gaXMgZGlzcGxheWVkIC0gcmVxdWlyZWQgaWYgYGlzUGVyc2lzdGVudGAgaXMgYGZhbHNlYFxuICAgKi9cbiAgb25SZW1vdmVSZXF1ZXN0PzogKFxuICAgIGV2ZW50PzogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4gfCBLZXlib2FyZEV2ZW50PEhUTUxCdXR0b25FbGVtZW50PlxuICApID0+IHZvaWQ7XG4gIC8qKlxuICAgKiBvcHRpb25hbCBidXR0b24gdGhhdCBhbGxvd3MgdGhlIHVzZXIgdG8gYXBwbHkgc2VsZWN0ZWQgZmlsdGVyIHZhbHVlc1xuICAgKi9cbiAgcmVuZGVyQXBwbHlCdXR0b24/OiAoKSA9PiBSZWFjdE5vZGU7XG4gIC8qKlxuICAgKiBjb250cm9scyB3aGV0aGVyIGBjbGVhciBhbGxgIGJ1dHRvbiBpbiBNZW51IEJvZHkgRm9vdGVyIGlzIGRpc3BsYXllZFxuICAgKi9cbiAgb25DbGVhclJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgc29ydGAgYnV0dG9uIGluIE1lbnUgQm9keSBIZWFkZXIgaXMgZGlzcGxheWVkXG4gICAqL1xuICBvblNvcnRSZXF1ZXN0PzogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgLyoqXG4gICAqIGNvbnRyb2xzIHdoZXRoZXIgbWVudSBpcyBvcGVuIG9uIGluaXRpYWwgcmVuZGVyXG4gICAqL1xuICBkZWZhdWx0T3Blbj86IGJvb2xlYW47XG59O1xuXG5leHBvcnQgY29uc3QgbWVudVN0eWxlcyA9IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzMwfTtcbiAgd2lkdGg6ICR7ZGVzaWduVG9rZW5zLmNvbnN0cmFpbnQ2fTtcbiAgbWF4LWhlaWdodDogJHtkZXNpZ25Ub2tlbnMuY29uc3RyYWludDEwfTtcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzIwfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nMzB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXI6IDFweCBzb2xpZCAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM4fTtcbiAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93MTh9O1xuICBhbmltYXRpb24tZHVyYXRpb246ICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gIHdpbGwtY2hhbmdlOiAndHJhbnNmb3JtLCBvcGFjaXR5JztcbiAgbWFyZ2luLXRvcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB6LWluZGV4OiA1O1xuYDtcblxuZXhwb3J0IGNvbnN0IG1lbnVCb2R5U3R5bGUgPSBjc3NgXG4gIHdpZHRoOiAxMDAlO1xuXG4gIC8qKiBlbnN1cmUgdGhhdCBib2R5IHNjcm9sbHMgd2l0aCBvdmVyZmxvdyBub3cgdGhhdCB0aGVyZSBpcyBhIG1lbnUgbWF4LWhlaWdodCAqL1xuICBvdmVyZmxvdzogaGlkZGVuIGF1dG87XG5gO1xuXG5mdW5jdGlvbiBGaWx0ZXJNZW51KHByb3BzOiBURmlsdGVyTWVudVByb3BzKSB7XG4gIGNvbnN0IG1lbnVCb2R5UmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICBjb25zdCBmb2N1c01lbnVCb2R5ID0gdXNlQ2FsbGJhY2soXG4gICAgKGUpID0+IHtcbiAgICAgIGlmIChtZW51Qm9keVJlZi5jdXJyZW50KSB7XG4gICAgICAgIGNvbnN0IGZpcnN0Rm9jdXNhYmxlRWxlbWVudEluTWVudUJvZHkgPSBmaW5kRmlyc3RGb2N1c2FibGUoXG4gICAgICAgICAgbWVudUJvZHlSZWYuY3VycmVudFxuICAgICAgICApO1xuICAgICAgICBpZiAoZmlyc3RGb2N1c2FibGVFbGVtZW50SW5NZW51Qm9keSkge1xuICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICBmaXJzdEZvY3VzYWJsZUVsZW1lbnRJbk1lbnVCb2R5LmZvY3VzKCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9LFxuICAgIFttZW51Qm9keVJlZl1cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxQb3BvdmVyLlJvb3RcbiAgICAgIGRlZmF1bHRPcGVuPXtwcm9wcy5pc0Rpc2FibGVkID8gZmFsc2UgOiBwcm9wcy5kZWZhdWx0T3Blbn1cbiAgICAgIG9uT3BlbkNoYW5nZT17KG9wZW4pID0+IHtcbiAgICAgICAgaWYgKFxuICAgICAgICAgICFvcGVuICYmXG4gICAgICAgICAgIXByb3BzLmFwcGxpZWRGaWx0ZXJWYWx1ZXM/Lmxlbmd0aCAmJlxuICAgICAgICAgICFwcm9wcy5pc1BlcnNpc3RlbnQgJiZcbiAgICAgICAgICBwcm9wcy5vblJlbW92ZVJlcXVlc3RcbiAgICAgICAgKSB7XG4gICAgICAgICAgcHJvcHMub25SZW1vdmVSZXF1ZXN0KCk7XG4gICAgICAgIH1cbiAgICAgIH19XG4gICAgPlxuICAgICAgPFBvcG92ZXIuVHJpZ2dlciBhc0NoaWxkPlxuICAgICAgICA8VHJpZ2dlckJ1dHRvblxuICAgICAgICAgIGZpbHRlcktleT17cHJvcHMuZmlsdGVyS2V5fVxuICAgICAgICAgIGxhYmVsPXtwcm9wcy5sYWJlbH1cbiAgICAgICAgICBvcGVyYXRvckxhYmVsPXtwcm9wcy5vcGVyYXRvckxhYmVsfVxuICAgICAgICAgIGFwcGxpZWRGaWx0ZXJWYWx1ZXM9e3Byb3BzLmFwcGxpZWRGaWx0ZXJWYWx1ZXN9XG4gICAgICAgICAgaXNEaXNhYmxlZD17cHJvcHMuaXNEaXNhYmxlZH1cbiAgICAgICAgICBpc1BlcnNpc3RlbnQ9e3Byb3BzLmlzUGVyc2lzdGVudH1cbiAgICAgICAgICBvblJlbW92ZVJlcXVlc3Q9e3Byb3BzLm9uUmVtb3ZlUmVxdWVzdH1cbiAgICAgICAgLz5cbiAgICAgIDwvUG9wb3Zlci5UcmlnZ2VyPlxuICAgICAgPFBvcG92ZXIuUG9ydGFsPlxuICAgICAgICA8UG9wb3Zlci5Db250ZW50XG4gICAgICAgICAgc2lkZT1cImJvdHRvbVwiXG4gICAgICAgICAgYWxpZ249XCJzdGFydFwiXG4gICAgICAgICAgY3NzPXttZW51U3R5bGVzfVxuICAgICAgICAgIG9uT3BlbkF1dG9Gb2N1cz17Zm9jdXNNZW51Qm9keX1cbiAgICAgICAgPlxuICAgICAgICAgIDxIZWFkZXJcbiAgICAgICAgICAgIGxhYmVsPXtwcm9wcy5sYWJlbH1cbiAgICAgICAgICAgIHJlbmRlck9wZXJhdG9yc0lucHV0PXtwcm9wcy5yZW5kZXJPcGVyYXRvcnNJbnB1dH1cbiAgICAgICAgICAgIG9uU29ydFJlcXVlc3Q9e3Byb3BzLm9uU29ydFJlcXVlc3R9XG4gICAgICAgICAgLz5cbiAgICAgICAgICA8ZGl2IGNzcz17bWVudUJvZHlTdHlsZX0gcmVmPXttZW51Qm9keVJlZn0+XG4gICAgICAgICAgICB7cHJvcHMucmVuZGVyTWVudUJvZHkoKX1cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8Rm9vdGVyXG4gICAgICAgICAgICBvbkNsZWFyUmVxdWVzdD17cHJvcHMub25DbGVhclJlcXVlc3R9XG4gICAgICAgICAgICByZW5kZXJBcHBseUJ1dHRvbj17cHJvcHMucmVuZGVyQXBwbHlCdXR0b259XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9Qb3BvdmVyLkNvbnRlbnQ+XG4gICAgICA8L1BvcG92ZXIuUG9ydGFsPlxuICAgIDwvUG9wb3Zlci5Sb290PlxuICApO1xufVxuXG5leHBvcnQgZGVmYXVsdCBGaWx0ZXJNZW51O1xuIl19 */",
290
288
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
291
289
  };
292
290
  function FilterMenu(props) {
@@ -410,8 +408,7 @@ var _ref9 = process.env.NODE_ENV === "production" ? {
410
408
  styles: "display:inline-flex"
411
409
  } : {
412
410
  name: "irmyae-Filters",
413
- styles: "display:inline-flex;label:Filters;",
414
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AAwWuB","file":"filters.tsx","sourcesContent":["import {\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n  useRef,\n  useState,\n} from 'react';\nimport { css } from '@emotion/react';\nimport * as Popover from '@radix-ui/react-popover';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport SelectInput, {\n  TOption,\n  TOptionObject,\n} from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { useIntl } from 'react-intl';\nimport FilterMenu, {\n  menuStyles,\n  menuBodyStyle,\n  type TAppliedFilterValue,\n} from './filter-menu';\nimport messages from './messages';\nimport { Badge } from './badge';\n\ninterface TAddFilterSelectOption extends TOption {\n  isDisabled?: boolean;\n}\n\ninterface TAddFilterOptionGroup extends TOptionObject {\n  options: TAddFilterSelectOption[];\n  label: ReactNode;\n  key: string;\n}\n\nexport type TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\nexport type TFilterConfiguration = {\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n  /**\n   * formatted message to display the selected operator value\n   */\n  operatorLabel?: ReactNode;\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactNode;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactNode;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * indicates whether the filter is disabled\n   */\n  isDisabled?: boolean;\n};\n\nexport type TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   *\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   *\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n\n  /**\n   * controls the `clear all` (added filters) button from the menu list, meant to clear the parent application's filter state\n   */\n  onClearAllRequest: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * optional callback when the add filter button is clicked\n   */\n  onAddFilterRequest?: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: ReactNode;\n  /**\n   * controls whether the filters list is initially open\n   */\n  defaultOpen?: boolean;\n};\n\nconst horizontalDividerStyles = css`\n  color: ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral90};\n  width: 100%;\n  height: 1px;\n  border: 0;\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction getFilterOptions(\n  filters: TFilterConfiguration[],\n  filterGroups?: TFilterGroupConfiguration[]\n): (TAddFilterSelectOption | TAddFilterOptionGroup)[] {\n  let filterOptions: (TAddFilterSelectOption | TAddFilterOptionGroup)[] = [];\n  // define option groups\n  if (filterGroups) {\n    filterOptions = filterGroups.map((filterGroup) => ({\n      label: filterGroup.label,\n      key: filterGroup.key,\n      options: [],\n    }));\n  }\n  return filters.reduce((filterOptions, filter) => {\n    const formattedOption = {\n      value: filter.key,\n      label: filter.label,\n      isDisabled: filter.isDisabled,\n    };\n    //if theres a groupkey, filterGroups, and the groupKey matches a filterGroup, add option to its group\n    if (filter.groupKey && filterGroups) {\n      const optionGroup = filterOptions.find(\n        (option) => 'key' in option && option.key === filter.groupKey\n      );\n      if (optionGroup && 'options' in optionGroup) {\n        optionGroup.options.push(formattedOption);\n        return filterOptions;\n      }\n    }\n    // otherwise add option directly\n    return [formattedOption, ...filterOptions];\n  }, filterOptions);\n}\n\nfunction Filters({\n  appliedFilters,\n  filters,\n  filterGroups,\n  onClearAllRequest,\n  onAddFilterRequest,\n  renderSearchComponent,\n  defaultOpen = false,\n}: TFiltersProps) {\n  const intl = useIntl();\n  const [showFilterControls, setShowFilterControls] = useState(defaultOpen);\n\n  const handleFiltersClick = () => {\n    setShowFilterControls((currState) => !currState);\n  };\n  /**\n   * persisted filters: always visible\n   * applied filters: filters for which values have been selected\n   * visible filters = persisted + applied\n   *\n   * visibleFiltersFromProps = filters visible based on props\n   * localVisibleFilters = filters actually visible in component currently\n   */\n  const persistedFilterKeys = filters\n    .filter(({ isPersistent }) => isPersistent)\n    .map((filter) => filter.key);\n\n  const persistedFiltersRef = useRef<string[]>(persistedFilterKeys);\n\n  const appliedFilterKeys = appliedFilters.map(({ filterKey }) => filterKey);\n\n  // applied filters must have corresponding filter in `props.filters`,\n  const visibleFiltersFromProps = filters\n    .filter(({ key, isPersistent }) => {\n      const isVisible =\n        Boolean(isPersistent) || appliedFilterKeys.includes(key);\n      return isVisible;\n    })\n    // persistent filters should be first in filter list\n    .sort(({ isPersistent }) => (isPersistent ? -1 : 1));\n\n  // set initial state as visibleFiltersFromProps\n  const [localVisibleFilters, setLocalVisibleFilters] = useState<string[]>(\n    visibleFiltersFromProps.map(({ key }) => key)\n  );\n\n  //update localVisibleFilters if persisted filter count changes\n  if (persistedFiltersRef.current.length !== persistedFilterKeys.length) {\n    setLocalVisibleFilters(visibleFiltersFromProps.map(({ key }) => key));\n    persistedFiltersRef.current = persistedFilterKeys;\n  }\n\n  const removeFilter = (filterKey: string) =>\n    setLocalVisibleFilters((currentVisibleFilters) =>\n      currentVisibleFilters.filter(\n        (visibleFilterKey) => visibleFilterKey !== filterKey\n      )\n    );\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {renderSearchComponent}\n        </div>\n        <Spacings.Inline scale=\"s\" alignItems=\"center\">\n          <FlatButton\n            label={intl.formatMessage(messages.filtersButtonLabel)}\n            icon={<FilterIcon />}\n            onClick={handleFiltersClick}\n          />\n          {appliedFilters.length > 1 && !showFilterControls && (\n            <Badge\n              id={'uikit-filters-selected-filter-count'}\n              label={`${appliedFilters.length}`}\n            />\n          )}\n        </Spacings.Inline>\n      </Spacings.Inline>\n      <hr css={horizontalDividerStyles} />\n      <CollapsibleMotion\n        isClosed={!showFilterControls}\n        onToggle={() => setShowFilterControls(!showFilterControls)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div\n              ref={registerContentNode}\n              css={menuListStyles}\n              aria-live=\"polite\"\n            >\n              {localVisibleFilters.map((activeFilter) => {\n                const activeFilterConfig = filters.find(\n                  (filter) => filter.key === activeFilter\n                )!;\n                return (\n                  <FilterMenu\n                    key={activeFilterConfig.key}\n                    filterKey={activeFilterConfig.key}\n                    label={activeFilterConfig.label}\n                    operatorLabel={activeFilterConfig.operatorLabel}\n                    isPersistent={activeFilterConfig.isPersistent}\n                    isDisabled={activeFilterConfig.isDisabled}\n                    renderMenuBody={\n                      activeFilterConfig.filterMenuConfiguration.renderMenuBody\n                    }\n                    renderOperatorsInput={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderOperatorsInput\n                    }\n                    renderApplyButton={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderApplyButton\n                    }\n                    appliedFilterValues={\n                      appliedFilters.find(\n                        (appliedFilter) =>\n                          activeFilter === appliedFilter.filterKey\n                      )?.values\n                    }\n                    onClearRequest={\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest\n                    }\n                    onRemoveRequest={(e) => {\n                      removeFilter(activeFilter);\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest(\n                        e\n                      );\n                    }}\n                    onSortRequest={\n                      activeFilterConfig.filterMenuConfiguration.onSortRequest\n                    }\n                    defaultOpen={\n                      activeFilterConfig.isPersistent ||\n                      localVisibleFilters.length ===\n                        visibleFiltersFromProps.length\n                        ? false\n                        : true\n                    }\n                  />\n                );\n              })}\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={(e) => {\n                        if (onAddFilterRequest) {\n                          onAddFilterRequest(e);\n                        }\n                        setShowFilterControls(true);\n                      }}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content\n                    side=\"bottom\"\n                    align=\"start\"\n                    css={[menuStyles, menuBodyStyle]}\n                  >\n                    <SelectInput\n                      id=\"ui-kit-add-filters-select\"\n                      name=\"select filters\"\n                      aria-label=\"select filters\"\n                      appearance=\"filter\"\n                      options={\n                        getFilterOptions(filters, filterGroups) as TOption[]\n                      }\n                      onChange={(e) => {\n                        setLocalVisibleFilters(\n                          Array.prototype.concat(\n                            e.target.value ? e.target.value : []\n                          )\n                        );\n                      }}\n                      value={localVisibleFilters}\n                      isMulti={true}\n                      // @ts-ignore\n                      isOptionDisabled={(option: TAddFilterSelectOption) =>\n                        option.isDisabled\n                      }\n                    />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              {appliedFilters.length > 1 && (\n                <>\n                  <div css={verticalDividerStyles} />\n                  <FlatButton\n                    icon={<CloseBoldIcon />}\n                    label={intl.formatMessage(\n                      messages.clearAllFiltersButtonLabel\n                    )}\n                    onClick={(e) => {\n                      onClearAllRequest(e);\n                      setLocalVisibleFilters(persistedFilterKeys);\n                    }}\n                    tone=\"secondary\"\n                  />\n                </>\n              )}\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */",
411
+ styles: "display:inline-flex;label:Filters;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AAwWuB","file":"filters.tsx","sourcesContent":["import {\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n  useRef,\n  useState,\n} from 'react';\nimport { css } from '@emotion/react';\nimport * as Popover from '@radix-ui/react-popover';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport SelectInput, {\n  TOption,\n  TOptionObject,\n} from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { useIntl } from 'react-intl';\nimport FilterMenu, {\n  menuStyles,\n  menuBodyStyle,\n  type TAppliedFilterValue,\n} from './filter-menu';\nimport messages from './messages';\nimport { Badge } from './badge';\n\ninterface TAddFilterSelectOption extends TOption {\n  isDisabled?: boolean;\n}\n\ninterface TAddFilterOptionGroup extends TOptionObject {\n  options: TAddFilterSelectOption[];\n  label: ReactNode;\n  key: string;\n}\n\nexport type TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\nexport type TFilterConfiguration = {\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n  /**\n   * formatted message to display the selected operator value\n   */\n  operatorLabel?: ReactNode;\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactNode;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactNode;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * indicates whether the filter is disabled\n   */\n  isDisabled?: boolean;\n};\n\nexport type TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   *\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   *\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n\n  /**\n   * controls the `clear all` (added filters) button from the menu list, meant to clear the parent application's filter state\n   */\n  onClearAllRequest: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * optional callback when the add filter button is clicked\n   */\n  onAddFilterRequest?: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: ReactNode;\n  /**\n   * controls whether the filters list is initially open\n   */\n  defaultOpen?: boolean;\n};\n\nconst horizontalDividerStyles = css`\n  color: ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral90};\n  width: 100%;\n  height: 1px;\n  border: 0;\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction getFilterOptions(\n  filters: TFilterConfiguration[],\n  filterGroups?: TFilterGroupConfiguration[]\n): (TAddFilterSelectOption | TAddFilterOptionGroup)[] {\n  let filterOptions: (TAddFilterSelectOption | TAddFilterOptionGroup)[] = [];\n  // define option groups\n  if (filterGroups) {\n    filterOptions = filterGroups.map((filterGroup) => ({\n      label: filterGroup.label,\n      key: filterGroup.key,\n      options: [],\n    }));\n  }\n  return filters.reduce((filterOptions, filter) => {\n    const formattedOption = {\n      value: filter.key,\n      label: filter.label,\n      isDisabled: filter.isDisabled,\n    };\n    //if theres a groupkey, filterGroups, and the groupKey matches a filterGroup, add option to its group\n    if (filter.groupKey && filterGroups) {\n      const optionGroup = filterOptions.find(\n        (option) => 'key' in option && option.key === filter.groupKey\n      );\n      if (optionGroup && 'options' in optionGroup) {\n        optionGroup.options.push(formattedOption);\n        return filterOptions;\n      }\n    }\n    // otherwise add option directly\n    return [formattedOption, ...filterOptions];\n  }, filterOptions);\n}\n\nfunction Filters({\n  appliedFilters,\n  filters,\n  filterGroups,\n  onClearAllRequest,\n  onAddFilterRequest,\n  renderSearchComponent,\n  defaultOpen = false,\n}: TFiltersProps) {\n  const intl = useIntl();\n  const [showFilterControls, setShowFilterControls] = useState(defaultOpen);\n\n  const handleFiltersClick = () => {\n    setShowFilterControls((currState) => !currState);\n  };\n  /**\n   * persisted filters: always visible\n   * applied filters: filters for which values have been selected\n   * visible filters = persisted + applied\n   *\n   * visibleFiltersFromProps = filters visible based on props\n   * localVisibleFilters = filters actually visible in component currently\n   */\n  const persistedFilterKeys = filters\n    .filter(({ isPersistent }) => isPersistent)\n    .map((filter) => filter.key);\n\n  const persistedFiltersRef = useRef<string[]>(persistedFilterKeys);\n\n  const appliedFilterKeys = appliedFilters.map(({ filterKey }) => filterKey);\n\n  // applied filters must have corresponding filter in `props.filters`,\n  const visibleFiltersFromProps = filters\n    .filter(({ key, isPersistent }) => {\n      const isVisible =\n        Boolean(isPersistent) || appliedFilterKeys.includes(key);\n      return isVisible;\n    })\n    // persistent filters should be first in filter list\n    .sort(({ isPersistent }) => (isPersistent ? -1 : 1));\n\n  // set initial state as visibleFiltersFromProps\n  const [localVisibleFilters, setLocalVisibleFilters] = useState<string[]>(\n    visibleFiltersFromProps.map(({ key }) => key)\n  );\n\n  //update localVisibleFilters if persisted filter count changes\n  if (persistedFiltersRef.current.length !== persistedFilterKeys.length) {\n    setLocalVisibleFilters(visibleFiltersFromProps.map(({ key }) => key));\n    persistedFiltersRef.current = persistedFilterKeys;\n  }\n\n  const removeFilter = (filterKey: string) =>\n    setLocalVisibleFilters((currentVisibleFilters) =>\n      currentVisibleFilters.filter(\n        (visibleFilterKey) => visibleFilterKey !== filterKey\n      )\n    );\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {renderSearchComponent}\n        </div>\n        <Spacings.Inline scale=\"s\" alignItems=\"center\">\n          <FlatButton\n            label={intl.formatMessage(messages.filtersButtonLabel)}\n            icon={<FilterIcon />}\n            onClick={handleFiltersClick}\n          />\n          {appliedFilters.length > 1 && !showFilterControls && (\n            <Badge\n              id={'uikit-filters-selected-filter-count'}\n              label={`${appliedFilters.length}`}\n            />\n          )}\n        </Spacings.Inline>\n      </Spacings.Inline>\n      <hr css={horizontalDividerStyles} />\n      <CollapsibleMotion\n        isClosed={!showFilterControls}\n        onToggle={() => setShowFilterControls(!showFilterControls)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div\n              ref={registerContentNode}\n              css={menuListStyles}\n              aria-live=\"polite\"\n            >\n              {localVisibleFilters.map((activeFilter) => {\n                const activeFilterConfig = filters.find(\n                  (filter) => filter.key === activeFilter\n                )!;\n                return (\n                  <FilterMenu\n                    key={activeFilterConfig.key}\n                    filterKey={activeFilterConfig.key}\n                    label={activeFilterConfig.label}\n                    operatorLabel={activeFilterConfig.operatorLabel}\n                    isPersistent={activeFilterConfig.isPersistent}\n                    isDisabled={activeFilterConfig.isDisabled}\n                    renderMenuBody={\n                      activeFilterConfig.filterMenuConfiguration.renderMenuBody\n                    }\n                    renderOperatorsInput={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderOperatorsInput\n                    }\n                    renderApplyButton={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderApplyButton\n                    }\n                    appliedFilterValues={\n                      appliedFilters.find(\n                        (appliedFilter) =>\n                          activeFilter === appliedFilter.filterKey\n                      )?.values\n                    }\n                    onClearRequest={\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest\n                    }\n                    onRemoveRequest={(e) => {\n                      removeFilter(activeFilter);\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest(\n                        e\n                      );\n                    }}\n                    onSortRequest={\n                      activeFilterConfig.filterMenuConfiguration.onSortRequest\n                    }\n                    defaultOpen={\n                      activeFilterConfig.isPersistent ||\n                      localVisibleFilters.length ===\n                        visibleFiltersFromProps.length\n                        ? false\n                        : true\n                    }\n                  />\n                );\n              })}\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={(e) => {\n                        if (onAddFilterRequest) {\n                          onAddFilterRequest(e);\n                        }\n                        setShowFilterControls(true);\n                      }}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content\n                    side=\"bottom\"\n                    align=\"start\"\n                    css={[menuStyles, menuBodyStyle]}\n                  >\n                    <SelectInput\n                      id=\"ui-kit-add-filters-select\"\n                      name=\"select filters\"\n                      aria-label=\"select filters\"\n                      appearance=\"filter\"\n                      options={\n                        getFilterOptions(filters, filterGroups) as TOption[]\n                      }\n                      onChange={(e) => {\n                        setLocalVisibleFilters(\n                          Array.prototype.concat(\n                            e.target.value ? e.target.value : []\n                          )\n                        );\n                      }}\n                      value={localVisibleFilters}\n                      isMulti={true}\n                      // @ts-ignore\n                      isOptionDisabled={(option: TAddFilterSelectOption) =>\n                        option.isDisabled\n                      }\n                    />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              {appliedFilters.length > 1 && (\n                <>\n                  <div css={verticalDividerStyles} />\n                  <FlatButton\n                    icon={<CloseBoldIcon />}\n                    label={intl.formatMessage(\n                      messages.clearAllFiltersButtonLabel\n                    )}\n                    onClick={(e) => {\n                      onClearAllRequest(e);\n                      setLocalVisibleFilters(persistedFilterKeys);\n                    }}\n                    tone=\"secondary\"\n                  />\n                </>\n              )}\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */",
415
412
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
416
413
  };
417
414
  function Filters(_ref) {
@@ -626,6 +623,6 @@ Filters.propTypes = process.env.NODE_ENV !== "production" ? {
626
623
  Filters.displayName = 'Filters';
627
624
 
628
625
  // NOTE: This string will be replaced on build time with the package version.
629
- var version = "19.22.1";
626
+ var version = "19.22.3";
630
627
 
631
628
  export { Filters as default, version };
@@ -57,7 +57,7 @@ export type TFilterMenuProps = {
57
57
  */
58
58
  defaultOpen?: boolean;
59
59
  };
60
- export declare const menuStyles: import("@emotion/react").SerializedStyles;
61
- export declare const menuBodyStyle: import("@emotion/react").SerializedStyles;
60
+ export declare const menuStyles: import("@emotion/utils").SerializedStyles;
61
+ export declare const menuBodyStyle: import("@emotion/utils").SerializedStyles;
62
62
  declare function FilterMenu(props: TFilterMenuProps): import("@emotion/react/jsx-runtime").JSX.Element;
63
63
  export default FilterMenu;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@commercetools-uikit/filters",
3
3
  "description": "The `Filters` component displays filter controls.",
4
- "version": "19.22.1",
4
+ "version": "19.22.3",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -21,15 +21,15 @@
21
21
  "dependencies": {
22
22
  "@babel/runtime": "^7.20.13",
23
23
  "@babel/runtime-corejs3": "^7.20.13",
24
- "@commercetools-uikit/collapsible-motion": "19.22.1",
25
- "@commercetools-uikit/design-system": "19.22.1",
26
- "@commercetools-uikit/flat-button": "19.22.1",
27
- "@commercetools-uikit/icon-button": "19.22.1",
28
- "@commercetools-uikit/icons": "19.22.1",
29
- "@commercetools-uikit/secondary-icon-button": "19.22.1",
30
- "@commercetools-uikit/select-input": "19.22.1",
31
- "@commercetools-uikit/spacings": "19.22.1",
32
- "@commercetools-uikit/utils": "19.22.1",
24
+ "@commercetools-uikit/collapsible-motion": "19.22.3",
25
+ "@commercetools-uikit/design-system": "19.22.3",
26
+ "@commercetools-uikit/flat-button": "19.22.3",
27
+ "@commercetools-uikit/icon-button": "19.22.3",
28
+ "@commercetools-uikit/icons": "19.22.3",
29
+ "@commercetools-uikit/secondary-icon-button": "19.22.3",
30
+ "@commercetools-uikit/select-input": "19.22.3",
31
+ "@commercetools-uikit/spacings": "19.22.3",
32
+ "@commercetools-uikit/utils": "19.22.3",
33
33
  "@emotion/react": "^11.10.5",
34
34
  "@emotion/styled": "^11.10.5",
35
35
  "@radix-ui/react-popover": "^1.1.2",