@leanix/components 0.4.511 → 0.4.513

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.
package/esm2022/index.mjs CHANGED
@@ -22,6 +22,8 @@ export * from './lib/core-ui/directives/after-view-init.directive';
22
22
  export * from './lib/core-ui/directives/autoclose.directive';
23
23
  export * from './lib/core-ui/directives/autofocus.directive';
24
24
  // Components
25
+ export * from './lib/core-ui/components/avatar-group/avatar-group.component';
26
+ export * from './lib/core-ui/components/avatar/avatar.component';
25
27
  export * from './lib/core-ui/components/badge/badge.component';
26
28
  export * from './lib/core-ui/components/banner/banner.component';
27
29
  export * from './lib/core-ui/components/button-group/button-group.component';
@@ -45,10 +47,13 @@ export * from './lib/core-ui/components/tokenizer/tokenizer.component';
45
47
  export * from './lib/core-ui/tooltip/tooltip-position.interface';
46
48
  export * from './lib/core-ui/tooltip/tooltip.component';
47
49
  export * from './lib/core-ui/tooltip/tooltip.directive';
50
+ // Models
51
+ export * from './lib/core-ui/components/avatar/avatar.model';
48
52
  // Linkify
49
53
  export * from './lib/core-ui/linkify/linkify.pipe';
50
54
  export * from './lib/core-ui/linkify/unlinkify.pipe';
51
55
  // Functions
56
+ export * from './lib/core-ui/components/avatar/avatar.helpers';
52
57
  export * from './lib/core-ui/functions/core-css.helpers';
53
58
  export * from './lib/core-ui/functions/highlight-text.function';
54
59
  // Services
@@ -137,4 +142,4 @@ export * from './lib/popover-ui/directives/popover-hover.directive';
137
142
  export * from './lib/tab-ui/components/tab-group/tab-group.component';
138
143
  export * from './lib/tab-ui/components/tab/tab.component';
139
144
  export * from './lib/tab-ui/tab-ui.module';
140
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../libs/components/src/index.ts"],"names":[],"mappings":"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","sourcesContent":["/*----------------- core-ui -----------------*/\n\nexport * from './lib/core-ui/core-ui.constants';\nexport * from './lib/core-ui/core-ui.module';\n\n// Pipes\nexport * from './lib/core-ui/pipes/br.pipe';\nexport * from './lib/core-ui/pipes/contrast-color.pipe';\nexport * from './lib/core-ui/pipes/custom-date.pipe';\nexport * from './lib/core-ui/pipes/highlight-range.pipe';\nexport * from './lib/core-ui/pipes/highlight-term.pipe';\nexport * from './lib/core-ui/pipes/lx-is-uuid.pipe';\nexport * from './lib/core-ui/pipes/lx-time-ago.pipe';\nexport * from './lib/core-ui/pipes/lx-translate.pipe';\nexport * from './lib/core-ui/pipes/markdown.pipe';\nexport * from './lib/core-ui/pipes/nbsp.pipe';\nexport * from './lib/core-ui/pipes/sort.pipe';\nexport * from './lib/core-ui/pipes/translation-after.pipe';\nexport * from './lib/core-ui/pipes/translation-before.pipe';\nexport * from './lib/core-ui/pipes/translation-between.pipe';\nexport * from './lib/core-ui/pipes/unescape-curly-braces.pipe';\n\n// Directives\nexport * from './lib/core-ui/directives/after-view-init.directive';\nexport * from './lib/core-ui/directives/autoclose.directive';\nexport * from './lib/core-ui/directives/autofocus.directive';\n\n// Components\nexport * from './lib/core-ui/components/badge/badge.component';\nexport * from './lib/core-ui/components/banner/banner.component';\nexport * from './lib/core-ui/components/button-group/button-group.component';\nexport * from './lib/core-ui/components/button/button.component';\nexport * from './lib/core-ui/components/card/card.component';\nexport * from './lib/core-ui/components/collapsible/collapsible.component';\nexport * from './lib/core-ui/components/counter/counter.component';\nexport * from './lib/core-ui/components/ellipsis/ellipsis.component';\nexport * from './lib/core-ui/components/empty-state/empty-state.component';\nexport * from './lib/core-ui/components/icon-scale/icon-scale.component';\nexport * from './lib/core-ui/components/skeleton/skeleton.component';\nexport * from './lib/core-ui/components/spinner/spinner.component';\nexport * from './lib/core-ui/components/stepper/stepper.component';\nexport * from './lib/core-ui/components/table/table-header/table-header.component';\nexport * from './lib/core-ui/components/table/table.component';\nexport * from './lib/core-ui/components/tiny-spinner/tiny-spinner.component';\nexport * from './lib/core-ui/components/tokenizer/token/token.component';\nexport * from './lib/core-ui/components/tokenizer/tokenizer-overflow-popover/tokenizer-overflow-popover.component';\nexport * from './lib/core-ui/components/tokenizer/tokenizer.component';\n// Tooltip\nexport * from './lib/core-ui/tooltip/tooltip-position.interface';\nexport * from './lib/core-ui/tooltip/tooltip.component';\nexport * from './lib/core-ui/tooltip/tooltip.directive';\n\n// Linkify\nexport * from './lib/core-ui/linkify/linkify.pipe';\nexport * from './lib/core-ui/linkify/unlinkify.pipe';\n\n// Functions\nexport * from './lib/core-ui/functions/core-css.helpers';\nexport * from './lib/core-ui/functions/highlight-text.function';\n\n// Services\nexport * from './lib/core-ui/directives/autoclose-group.service';\nexport * from './lib/core-ui/services/resize-observer.service';\n/*----------------- forms-ui -----------------*/\n\nexport * from './lib/forms-ui/forms-ui.module';\n\n// Components\nexport * from './lib/forms-ui/components/basic-dropdown-item/basic-dropdown-item.component';\nexport * from './lib/forms-ui/components/basic-dropdown/basic-dropdown.component';\nexport * from './lib/forms-ui/components/breadcrumb/breadcrumb.component';\nexport * from './lib/forms-ui/components/cdk-options-dropdown/cdk-options-dropdown.component';\nexport * from './lib/forms-ui/components/cdk-options-sub-dropdown/cdk-options-sub-dropdown.component';\nexport * from './lib/forms-ui/components/currency/currency-input.component';\nexport * from './lib/forms-ui/components/currency/currency-symbol-map.constant';\nexport * from './lib/forms-ui/components/currency/currency-symbol.component';\nexport * from './lib/forms-ui/components/date-input/date-input.component';\nexport * from './lib/forms-ui/components/date-picker-ui/date-formatter';\nexport * from './lib/forms-ui/components/date-picker-ui/datepicker-ui.module';\nexport * from './lib/forms-ui/components/date-picker-ui/datepicker.component';\nexport * from './lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list-item/drag-and-drop-list-item.component';\nexport * from './lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list.component';\nexport * from './lib/forms-ui/components/error-message/error-message.component';\nexport * from './lib/forms-ui/components/expanded-dropdown/expanded-dropdown.component';\nexport * from './lib/forms-ui/components/form-error/form-error.component';\nexport * from './lib/forms-ui/components/icon/icon.component';\nexport * from './lib/forms-ui/components/input/input.component';\nexport * from './lib/forms-ui/components/multi-select/multi-select.component';\nexport * from './lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component';\nexport * from './lib/forms-ui/components/option-group/option-group.component';\nexport * from './lib/forms-ui/components/option/option.component';\nexport * from './lib/forms-ui/components/options-dropdown/options-dropdown.component';\nexport * from './lib/forms-ui/components/options-sub-dropdown/options-sub-dropdown.component';\nexport * from './lib/forms-ui/components/picker-option/picker-option.component';\nexport * from './lib/forms-ui/components/picker/picker.component';\nexport * from './lib/forms-ui/components/pill-item/pill-item.component';\nexport * from './lib/forms-ui/components/pill-list/pill-list.component';\nexport * from './lib/forms-ui/components/responsive-input/responsive-input.component';\nexport * from './lib/forms-ui/components/select-list/select-list.component';\nexport * from './lib/forms-ui/components/single-select/single-select.component';\nexport * from './lib/forms-ui/components/sorting-dropdown-trigger/sorting-dropdown-trigger.component';\nexport * from './lib/forms-ui/components/sorting-dropdown/sorting-dropdown.component';\nexport * from './lib/forms-ui/components/switch/switch.component';\n\n// Directives\nexport * from './lib/forms-ui/components/keyboard-select.directive';\nexport * from './lib/forms-ui/components/picker/picker-trigger.directive';\nexport * from './lib/forms-ui/directives/contenteditable.directive';\nexport * from './lib/forms-ui/directives/form-error.directive';\nexport * from './lib/forms-ui/directives/form-submit.directive';\nexport * from './lib/forms-ui/directives/keyboard-action-source.directive';\nexport * from './lib/forms-ui/directives/mark-invalid.directive';\nexport * from './lib/forms-ui/directives/max-length-counter.directive';\nexport * from './lib/forms-ui/directives/select-dropdown.directive';\nexport * from './lib/forms-ui/directives/selectable-item.directive';\nexport * from './lib/forms-ui/directives/selected-option.directive';\nexport * from './lib/forms-ui/models/base-select.directive';\n\n// Models\nexport * from './lib/forms-ui/models/single-select-padding.interface';\nexport * from './lib/forms-ui/models/sorting.interface';\n\n// Helpers\nexport * from './lib/forms-ui/components/date-picker-ui/datepicker.config';\nexport * from './lib/forms-ui/helpers/key-codes.constants';\n\n// Pipes\nexport * from './lib/forms-ui/pipes/filter-selection.pipe';\nexport * from './lib/forms-ui/pipes/filter-term.pipe';\nexport * from './lib/forms-ui/pipes/format-number.pipe';\n\n// Validators\nexport * from './lib/forms-ui/validators/date-in-foreseeable-future.validator';\nexport * from './lib/forms-ui/validators/string-not-in-array.validator';\n\n// Modules\nexport { LxDragAndDropListModule } from './lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list.module';\n\n/*----------------- modal-ui -----------------*/\n\nexport * from './lib/modal-ui/modal.constants';\nexport * from './lib/modal-ui/modal.module';\n\nexport * from './lib/modal-ui/components/modal-footer/modal-footer.component';\nexport * from './lib/modal-ui/components/modal-header/modal-header.component';\nexport * from './lib/modal-ui/components/modal/modal.component';\n\nexport * from './lib/modal-ui/directives/modal-content.directive';\n\n/*----------------- popover-ui -----------------*/\n\nexport * from './lib/popover-ui/popover-ui.module';\n\nexport * from './lib/popover-ui/components/popover/popover.component';\n\nexport * from './lib/popover-ui/directives/popover-click.directive';\nexport * from './lib/popover-ui/directives/popover-content.directive';\nexport * from './lib/popover-ui/directives/popover-hover.directive';\n\n/*----------------- tab-ui -----------------*/\n\nexport * from './lib/tab-ui/components/tab-group/tab-group.component';\nexport * from './lib/tab-ui/components/tab/tab.component';\nexport * from './lib/tab-ui/tab-ui.module';\n"]}
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../libs/components/src/index.ts"],"names":[],"mappings":"AAAA,+CAA+C;AAE/C,cAAc,iCAAiC,CAAC;AAChD,cAAc,8BAA8B,CAAC;AAE7C,QAAQ;AACR,cAAc,6BAA6B,CAAC;AAC5C,cAAc,yCAAyC,CAAC;AACxD,cAAc,sCAAsC,CAAC;AACrD,cAAc,0CAA0C,CAAC;AACzD,cAAc,yCAAyC,CAAC;AACxD,cAAc,qCAAqC,CAAC;AACpD,cAAc,sCAAsC,CAAC;AACrD,cAAc,uCAAuC,CAAC;AACtD,cAAc,mCAAmC,CAAC;AAClD,cAAc,+BAA+B,CAAC;AAC9C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,4CAA4C,CAAC;AAC3D,cAAc,6CAA6C,CAAC;AAC5D,cAAc,8CAA8C,CAAC;AAC7D,cAAc,gDAAgD,CAAC;AAE/D,aAAa;AACb,cAAc,oDAAoD,CAAC;AACnE,cAAc,8CAA8C,CAAC;AAC7D,cAAc,8CAA8C,CAAC;AAE7D,aAAa;AACb,cAAc,8DAA8D,CAAC;AAC7E,cAAc,kDAAkD,CAAC;AACjE,cAAc,gDAAgD,CAAC;AAC/D,cAAc,kDAAkD,CAAC;AACjE,cAAc,8DAA8D,CAAC;AAC7E,cAAc,kDAAkD,CAAC;AACjE,cAAc,8CAA8C,CAAC;AAC7D,cAAc,4DAA4D,CAAC;AAC3E,cAAc,oDAAoD,CAAC;AACnE,cAAc,sDAAsD,CAAC;AACrE,cAAc,4DAA4D,CAAC;AAC3E,cAAc,0DAA0D,CAAC;AACzE,cAAc,sDAAsD,CAAC;AACrE,cAAc,oDAAoD,CAAC;AACnE,cAAc,oDAAoD,CAAC;AACnE,cAAc,oEAAoE,CAAC;AACnF,cAAc,gDAAgD,CAAC;AAC/D,cAAc,8DAA8D,CAAC;AAC7E,cAAc,0DAA0D,CAAC;AACzE,cAAc,oGAAoG,CAAC;AACnH,cAAc,wDAAwD,CAAC;AACvE,UAAU;AACV,cAAc,kDAAkD,CAAC;AACjE,cAAc,yCAAyC,CAAC;AACxD,cAAc,yCAAyC,CAAC;AAExD,SAAS;AACT,cAAc,8CAA8C,CAAC;AAE7D,UAAU;AACV,cAAc,oCAAoC,CAAC;AACnD,cAAc,sCAAsC,CAAC;AAErD,YAAY;AACZ,cAAc,gDAAgD,CAAC;AAC/D,cAAc,0CAA0C,CAAC;AACzD,cAAc,iDAAiD,CAAC;AAEhE,WAAW;AACX,cAAc,kDAAkD,CAAC;AACjE,cAAc,gDAAgD,CAAC;AAC/D,gDAAgD;AAEhD,cAAc,gCAAgC,CAAC;AAE/C,aAAa;AACb,cAAc,6EAA6E,CAAC;AAC5F,cAAc,mEAAmE,CAAC;AAClF,cAAc,2DAA2D,CAAC;AAC1E,cAAc,+EAA+E,CAAC;AAC9F,cAAc,uFAAuF,CAAC;AACtG,cAAc,6DAA6D,CAAC;AAC5E,cAAc,iEAAiE,CAAC;AAChF,cAAc,8DAA8D,CAAC;AAC7E,cAAc,2DAA2D,CAAC;AAC1E,cAAc,yDAAyD,CAAC;AACxE,cAAc,+DAA+D,CAAC;AAC9E,cAAc,+DAA+D,CAAC;AAC9E,cAAc,wGAAwG,CAAC;AACvH,cAAc,2EAA2E,CAAC;AAC1F,cAAc,iEAAiE,CAAC;AAChF,cAAc,yEAAyE,CAAC;AACxF,cAAc,2DAA2D,CAAC;AAC1E,cAAc,+CAA+C,CAAC;AAC9D,cAAc,iDAAiD,CAAC;AAChE,cAAc,+DAA+D,CAAC;AAC9E,cAAc,iFAAiF,CAAC;AAChG,cAAc,+DAA+D,CAAC;AAC9E,cAAc,mDAAmD,CAAC;AAClE,cAAc,uEAAuE,CAAC;AACtF,cAAc,+EAA+E,CAAC;AAC9F,cAAc,iEAAiE,CAAC;AAChF,cAAc,mDAAmD,CAAC;AAClE,cAAc,yDAAyD,CAAC;AACxE,cAAc,yDAAyD,CAAC;AACxE,cAAc,uEAAuE,CAAC;AACtF,cAAc,6DAA6D,CAAC;AAC5E,cAAc,iEAAiE,CAAC;AAChF,cAAc,uFAAuF,CAAC;AACtG,cAAc,uEAAuE,CAAC;AACtF,cAAc,mDAAmD,CAAC;AAElE,aAAa;AACb,cAAc,qDAAqD,CAAC;AACpE,cAAc,2DAA2D,CAAC;AAC1E,cAAc,qDAAqD,CAAC;AACpE,cAAc,gDAAgD,CAAC;AAC/D,cAAc,iDAAiD,CAAC;AAChE,cAAc,4DAA4D,CAAC;AAC3E,cAAc,kDAAkD,CAAC;AACjE,cAAc,wDAAwD,CAAC;AACvE,cAAc,qDAAqD,CAAC;AACpE,cAAc,qDAAqD,CAAC;AACpE,cAAc,qDAAqD,CAAC;AACpE,cAAc,6CAA6C,CAAC;AAE5D,SAAS;AACT,cAAc,uDAAuD,CAAC;AACtE,cAAc,yCAAyC,CAAC;AAExD,UAAU;AACV,cAAc,4DAA4D,CAAC;AAC3E,cAAc,4CAA4C,CAAC;AAE3D,QAAQ;AACR,cAAc,4CAA4C,CAAC;AAC3D,cAAc,uCAAuC,CAAC;AACtD,cAAc,yCAAyC,CAAC;AAExD,aAAa;AACb,cAAc,gEAAgE,CAAC;AAC/E,cAAc,yDAAyD,CAAC;AAExE,UAAU;AACV,OAAO,EAAE,uBAAuB,EAAE,MAAM,wEAAwE,CAAC;AAEjH,gDAAgD;AAEhD,cAAc,gCAAgC,CAAC;AAC/C,cAAc,6BAA6B,CAAC;AAE5C,cAAc,+DAA+D,CAAC;AAC9E,cAAc,+DAA+D,CAAC;AAC9E,cAAc,iDAAiD,CAAC;AAEhE,cAAc,mDAAmD,CAAC;AAElE,kDAAkD;AAElD,cAAc,oCAAoC,CAAC;AAEnD,cAAc,uDAAuD,CAAC;AAEtE,cAAc,qDAAqD,CAAC;AACpE,cAAc,uDAAuD,CAAC;AACtE,cAAc,qDAAqD,CAAC;AAEpE,8CAA8C;AAE9C,cAAc,uDAAuD,CAAC;AACtE,cAAc,2CAA2C,CAAC;AAC1D,cAAc,4BAA4B,CAAC","sourcesContent":["/*----------------- core-ui -----------------*/\n\nexport * from './lib/core-ui/core-ui.constants';\nexport * from './lib/core-ui/core-ui.module';\n\n// Pipes\nexport * from './lib/core-ui/pipes/br.pipe';\nexport * from './lib/core-ui/pipes/contrast-color.pipe';\nexport * from './lib/core-ui/pipes/custom-date.pipe';\nexport * from './lib/core-ui/pipes/highlight-range.pipe';\nexport * from './lib/core-ui/pipes/highlight-term.pipe';\nexport * from './lib/core-ui/pipes/lx-is-uuid.pipe';\nexport * from './lib/core-ui/pipes/lx-time-ago.pipe';\nexport * from './lib/core-ui/pipes/lx-translate.pipe';\nexport * from './lib/core-ui/pipes/markdown.pipe';\nexport * from './lib/core-ui/pipes/nbsp.pipe';\nexport * from './lib/core-ui/pipes/sort.pipe';\nexport * from './lib/core-ui/pipes/translation-after.pipe';\nexport * from './lib/core-ui/pipes/translation-before.pipe';\nexport * from './lib/core-ui/pipes/translation-between.pipe';\nexport * from './lib/core-ui/pipes/unescape-curly-braces.pipe';\n\n// Directives\nexport * from './lib/core-ui/directives/after-view-init.directive';\nexport * from './lib/core-ui/directives/autoclose.directive';\nexport * from './lib/core-ui/directives/autofocus.directive';\n\n// Components\nexport * from './lib/core-ui/components/avatar-group/avatar-group.component';\nexport * from './lib/core-ui/components/avatar/avatar.component';\nexport * from './lib/core-ui/components/badge/badge.component';\nexport * from './lib/core-ui/components/banner/banner.component';\nexport * from './lib/core-ui/components/button-group/button-group.component';\nexport * from './lib/core-ui/components/button/button.component';\nexport * from './lib/core-ui/components/card/card.component';\nexport * from './lib/core-ui/components/collapsible/collapsible.component';\nexport * from './lib/core-ui/components/counter/counter.component';\nexport * from './lib/core-ui/components/ellipsis/ellipsis.component';\nexport * from './lib/core-ui/components/empty-state/empty-state.component';\nexport * from './lib/core-ui/components/icon-scale/icon-scale.component';\nexport * from './lib/core-ui/components/skeleton/skeleton.component';\nexport * from './lib/core-ui/components/spinner/spinner.component';\nexport * from './lib/core-ui/components/stepper/stepper.component';\nexport * from './lib/core-ui/components/table/table-header/table-header.component';\nexport * from './lib/core-ui/components/table/table.component';\nexport * from './lib/core-ui/components/tiny-spinner/tiny-spinner.component';\nexport * from './lib/core-ui/components/tokenizer/token/token.component';\nexport * from './lib/core-ui/components/tokenizer/tokenizer-overflow-popover/tokenizer-overflow-popover.component';\nexport * from './lib/core-ui/components/tokenizer/tokenizer.component';\n// Tooltip\nexport * from './lib/core-ui/tooltip/tooltip-position.interface';\nexport * from './lib/core-ui/tooltip/tooltip.component';\nexport * from './lib/core-ui/tooltip/tooltip.directive';\n\n// Models\nexport * from './lib/core-ui/components/avatar/avatar.model';\n\n// Linkify\nexport * from './lib/core-ui/linkify/linkify.pipe';\nexport * from './lib/core-ui/linkify/unlinkify.pipe';\n\n// Functions\nexport * from './lib/core-ui/components/avatar/avatar.helpers';\nexport * from './lib/core-ui/functions/core-css.helpers';\nexport * from './lib/core-ui/functions/highlight-text.function';\n\n// Services\nexport * from './lib/core-ui/directives/autoclose-group.service';\nexport * from './lib/core-ui/services/resize-observer.service';\n/*----------------- forms-ui -----------------*/\n\nexport * from './lib/forms-ui/forms-ui.module';\n\n// Components\nexport * from './lib/forms-ui/components/basic-dropdown-item/basic-dropdown-item.component';\nexport * from './lib/forms-ui/components/basic-dropdown/basic-dropdown.component';\nexport * from './lib/forms-ui/components/breadcrumb/breadcrumb.component';\nexport * from './lib/forms-ui/components/cdk-options-dropdown/cdk-options-dropdown.component';\nexport * from './lib/forms-ui/components/cdk-options-sub-dropdown/cdk-options-sub-dropdown.component';\nexport * from './lib/forms-ui/components/currency/currency-input.component';\nexport * from './lib/forms-ui/components/currency/currency-symbol-map.constant';\nexport * from './lib/forms-ui/components/currency/currency-symbol.component';\nexport * from './lib/forms-ui/components/date-input/date-input.component';\nexport * from './lib/forms-ui/components/date-picker-ui/date-formatter';\nexport * from './lib/forms-ui/components/date-picker-ui/datepicker-ui.module';\nexport * from './lib/forms-ui/components/date-picker-ui/datepicker.component';\nexport * from './lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list-item/drag-and-drop-list-item.component';\nexport * from './lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list.component';\nexport * from './lib/forms-ui/components/error-message/error-message.component';\nexport * from './lib/forms-ui/components/expanded-dropdown/expanded-dropdown.component';\nexport * from './lib/forms-ui/components/form-error/form-error.component';\nexport * from './lib/forms-ui/components/icon/icon.component';\nexport * from './lib/forms-ui/components/input/input.component';\nexport * from './lib/forms-ui/components/multi-select/multi-select.component';\nexport * from './lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component';\nexport * from './lib/forms-ui/components/option-group/option-group.component';\nexport * from './lib/forms-ui/components/option/option.component';\nexport * from './lib/forms-ui/components/options-dropdown/options-dropdown.component';\nexport * from './lib/forms-ui/components/options-sub-dropdown/options-sub-dropdown.component';\nexport * from './lib/forms-ui/components/picker-option/picker-option.component';\nexport * from './lib/forms-ui/components/picker/picker.component';\nexport * from './lib/forms-ui/components/pill-item/pill-item.component';\nexport * from './lib/forms-ui/components/pill-list/pill-list.component';\nexport * from './lib/forms-ui/components/responsive-input/responsive-input.component';\nexport * from './lib/forms-ui/components/select-list/select-list.component';\nexport * from './lib/forms-ui/components/single-select/single-select.component';\nexport * from './lib/forms-ui/components/sorting-dropdown-trigger/sorting-dropdown-trigger.component';\nexport * from './lib/forms-ui/components/sorting-dropdown/sorting-dropdown.component';\nexport * from './lib/forms-ui/components/switch/switch.component';\n\n// Directives\nexport * from './lib/forms-ui/components/keyboard-select.directive';\nexport * from './lib/forms-ui/components/picker/picker-trigger.directive';\nexport * from './lib/forms-ui/directives/contenteditable.directive';\nexport * from './lib/forms-ui/directives/form-error.directive';\nexport * from './lib/forms-ui/directives/form-submit.directive';\nexport * from './lib/forms-ui/directives/keyboard-action-source.directive';\nexport * from './lib/forms-ui/directives/mark-invalid.directive';\nexport * from './lib/forms-ui/directives/max-length-counter.directive';\nexport * from './lib/forms-ui/directives/select-dropdown.directive';\nexport * from './lib/forms-ui/directives/selectable-item.directive';\nexport * from './lib/forms-ui/directives/selected-option.directive';\nexport * from './lib/forms-ui/models/base-select.directive';\n\n// Models\nexport * from './lib/forms-ui/models/single-select-padding.interface';\nexport * from './lib/forms-ui/models/sorting.interface';\n\n// Helpers\nexport * from './lib/forms-ui/components/date-picker-ui/datepicker.config';\nexport * from './lib/forms-ui/helpers/key-codes.constants';\n\n// Pipes\nexport * from './lib/forms-ui/pipes/filter-selection.pipe';\nexport * from './lib/forms-ui/pipes/filter-term.pipe';\nexport * from './lib/forms-ui/pipes/format-number.pipe';\n\n// Validators\nexport * from './lib/forms-ui/validators/date-in-foreseeable-future.validator';\nexport * from './lib/forms-ui/validators/string-not-in-array.validator';\n\n// Modules\nexport { LxDragAndDropListModule } from './lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list.module';\n\n/*----------------- modal-ui -----------------*/\n\nexport * from './lib/modal-ui/modal.constants';\nexport * from './lib/modal-ui/modal.module';\n\nexport * from './lib/modal-ui/components/modal-footer/modal-footer.component';\nexport * from './lib/modal-ui/components/modal-header/modal-header.component';\nexport * from './lib/modal-ui/components/modal/modal.component';\n\nexport * from './lib/modal-ui/directives/modal-content.directive';\n\n/*----------------- popover-ui -----------------*/\n\nexport * from './lib/popover-ui/popover-ui.module';\n\nexport * from './lib/popover-ui/components/popover/popover.component';\n\nexport * from './lib/popover-ui/directives/popover-click.directive';\nexport * from './lib/popover-ui/directives/popover-content.directive';\nexport * from './lib/popover-ui/directives/popover-hover.directive';\n\n/*----------------- tab-ui -----------------*/\n\nexport * from './lib/tab-ui/components/tab-group/tab-group.component';\nexport * from './lib/tab-ui/components/tab/tab.component';\nexport * from './lib/tab-ui/tab-ui.module';\n"]}
@@ -0,0 +1,40 @@
1
+ import { AsyncPipe, NgClass, NgIf } from '@angular/common';
2
+ import { Component, Inject, Input } from '@angular/core';
3
+ import { TooltipDirective } from '../../tooltip/tooltip.directive';
4
+ import { DEFAULT_IMAGE_ID, IMAGE_READER } from './avatar.model';
5
+ import * as i0 from "@angular/core";
6
+ export class AvatarComponent {
7
+ constructor(imageReader) {
8
+ this.imageReader = imageReader;
9
+ this.size = 'M';
10
+ this.showMailToLink = true;
11
+ this.disabled = false;
12
+ this.NAME = 'AvatarComponent';
13
+ this.imageURL = this.imageReader.getAvatar(DEFAULT_IMAGE_ID, this.size, this.user?.displayName);
14
+ }
15
+ ngOnChanges(changes) {
16
+ const { user } = changes;
17
+ if (user && user.currentValue && !user.currentValue.technicalUser) {
18
+ const { id, displayName } = this.user || {};
19
+ this.imageURL = this.imageReader.getAvatar(id ?? undefined, this.size, displayName);
20
+ }
21
+ }
22
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AvatarComponent, deps: [{ token: IMAGE_READER }], target: i0.ɵɵFactoryTarget.Component }); }
23
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: AvatarComponent, isStandalone: true, selector: "lx-avatar", inputs: { user: "user", size: "size", showMailToLink: "showMailToLink", disabled: "disabled" }, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"imageURL | async; else loading\">\n <ng-container *ngIf=\"!user.technicalUser; else technicalUserIcon\">\n <a\n *ngIf=\"showMailToLink && user.email; else profilePicture\"\n class=\"userLink\"\n href=\"mailto:{{ user.email }}\"\n lxTooltip=\"{{ user.displayName }}\"\n >\n <img\n [src]=\"imageURL | async\"\n class=\"avatarImage\"\n [class]=\"size\"\n [class.disabled]=\"disabled\"\n role=\"presentation\"\n alt=\"{{ user.displayName }}\"\n />\n </a>\n <ng-template #profilePicture>\n <img\n [src]=\"imageURL | async\"\n class=\"avatarImage\"\n [class]=\"size\"\n [class.disabled]=\"disabled\"\n role=\"presentation\"\n alt=\"{{ user.displayName }}\"\n />\n </ng-template>\n </ng-container>\n <ng-template #technicalUserIcon>\n <i class=\"avatarImage fas fa-robot\" lxTooltip=\"{{ user.displayName }}\" [class]=\"size\" [class.disabled]=\"disabled\"></i>\n </ng-template>\n</ng-container>\n<ng-template #loading>\n <div class=\"avatarImage userLink loading\" [ngClass]=\"size\"></div>\n</ng-template>\n", styles: [".userLink{display:inline-block;width:fit-content;height:fit-content}.avatarImage{border-radius:50%}.avatarImage.disabled{opacity:.4}.loading{background:linear-gradient(270deg,#ccc,#eee,#ccc);background-size:200% 100%;animation:loading 1.5s infinite;object-fit:cover;vertical-align:middle}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.fa-robot{background-color:#b2bccc;color:#fff;vertical-align:middle;text-align:center}.fa-robot.XS{line-height:14px;font-size:10px}.fa-robot.S{line-height:22px;font-size:13px}.fa-robot.M{line-height:30px;font-size:18px}.fa-robot.L{line-height:38px;font-size:22px}.fa-robot.XL{line-height:62px;font-size:40px}.XS{width:16px;height:16px}.S{width:24px;height:24px}.M{width:32px;height:32px}.L{width:40px;height:40px}.XL{width:64px;height:64px}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: TooltipDirective, selector: "[lxTooltip]", inputs: ["lxTooltip", "lxTooltipPosition", "lxTooltipDelay", "lxTooltipIsHtmlContent"] }] }); }
24
+ }
25
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AvatarComponent, decorators: [{
26
+ type: Component,
27
+ args: [{ selector: 'lx-avatar', standalone: true, imports: [NgIf, AsyncPipe, NgClass, TooltipDirective], template: "<ng-container *ngIf=\"imageURL | async; else loading\">\n <ng-container *ngIf=\"!user.technicalUser; else technicalUserIcon\">\n <a\n *ngIf=\"showMailToLink && user.email; else profilePicture\"\n class=\"userLink\"\n href=\"mailto:{{ user.email }}\"\n lxTooltip=\"{{ user.displayName }}\"\n >\n <img\n [src]=\"imageURL | async\"\n class=\"avatarImage\"\n [class]=\"size\"\n [class.disabled]=\"disabled\"\n role=\"presentation\"\n alt=\"{{ user.displayName }}\"\n />\n </a>\n <ng-template #profilePicture>\n <img\n [src]=\"imageURL | async\"\n class=\"avatarImage\"\n [class]=\"size\"\n [class.disabled]=\"disabled\"\n role=\"presentation\"\n alt=\"{{ user.displayName }}\"\n />\n </ng-template>\n </ng-container>\n <ng-template #technicalUserIcon>\n <i class=\"avatarImage fas fa-robot\" lxTooltip=\"{{ user.displayName }}\" [class]=\"size\" [class.disabled]=\"disabled\"></i>\n </ng-template>\n</ng-container>\n<ng-template #loading>\n <div class=\"avatarImage userLink loading\" [ngClass]=\"size\"></div>\n</ng-template>\n", styles: [".userLink{display:inline-block;width:fit-content;height:fit-content}.avatarImage{border-radius:50%}.avatarImage.disabled{opacity:.4}.loading{background:linear-gradient(270deg,#ccc,#eee,#ccc);background-size:200% 100%;animation:loading 1.5s infinite;object-fit:cover;vertical-align:middle}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.fa-robot{background-color:#b2bccc;color:#fff;vertical-align:middle;text-align:center}.fa-robot.XS{line-height:14px;font-size:10px}.fa-robot.S{line-height:22px;font-size:13px}.fa-robot.M{line-height:30px;font-size:18px}.fa-robot.L{line-height:38px;font-size:22px}.fa-robot.XL{line-height:62px;font-size:40px}.XS{width:16px;height:16px}.S{width:24px;height:24px}.M{width:32px;height:32px}.L{width:40px;height:40px}.XL{width:64px;height:64px}\n"] }]
28
+ }], ctorParameters: () => [{ type: undefined, decorators: [{
29
+ type: Inject,
30
+ args: [IMAGE_READER]
31
+ }] }], propDecorators: { user: [{
32
+ type: Input
33
+ }], size: [{
34
+ type: Input
35
+ }], showMailToLink: [{
36
+ type: Input
37
+ }], disabled: [{
38
+ type: Input
39
+ }] } });
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhdGFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2NvcmUtdWkvY29tcG9uZW50cy9hdmF0YXIvYXZhdGFyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2NvcmUtdWkvY29tcG9uZW50cy9hdmF0YXIvYXZhdGFyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzNELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBNEIsTUFBTSxlQUFlLENBQUM7QUFDbkYsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDbkUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLFlBQVksRUFBcUMsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFTbkcsTUFBTSxPQUFPLGVBQWU7SUFVMUIsWUFBMEMsV0FBd0I7UUFBeEIsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFSekQsU0FBSSxHQUFtQixHQUFHLENBQUM7UUFDM0IsbUJBQWMsR0FBRyxJQUFJLENBQUM7UUFDdEIsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUVqQixTQUFJLEdBQUcsaUJBQWlCLENBQUM7UUFLaEMsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxnQkFBZ0IsRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDbEcsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxNQUFNLEVBQUUsSUFBSSxFQUFFLEdBQUcsT0FBTyxDQUFDO1FBRXpCLElBQUksSUFBSSxJQUFJLElBQUksQ0FBQyxZQUFZLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQ2xFLE1BQU0sRUFBRSxFQUFFLEVBQUUsV0FBVyxFQUFFLEdBQUcsSUFBSSxDQUFDLElBQUksSUFBSSxFQUFFLENBQUM7WUFDNUMsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxFQUFFLElBQUksU0FBUyxFQUFFLElBQUksQ0FBQyxJQUFJLEVBQUUsV0FBVyxDQUFDLENBQUM7UUFDdEYsQ0FBQztJQUNILENBQUM7OEdBckJVLGVBQWUsa0JBVU4sWUFBWTtrR0FWckIsZUFBZSwwTENaNUIscXBDQW1DQSxxMkJEekJZLElBQUksd0ZBQUUsU0FBUyw4Q0FBRSxPQUFPLG9GQUFFLGdCQUFnQjs7MkZBRXpDLGVBQWU7a0JBUDNCLFNBQVM7K0JBQ0UsV0FBVyxjQUdULElBQUksV0FDUCxDQUFDLElBQUksRUFBRSxTQUFTLEVBQUUsT0FBTyxFQUFFLGdCQUFnQixDQUFDOzswQkFZeEMsTUFBTTsyQkFBQyxZQUFZO3lDQVR2QixJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUNHLGNBQWM7c0JBQXRCLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFzeW5jUGlwZSwgTmdDbGFzcywgTmdJZiB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIEluamVjdCwgSW5wdXQsIE9uQ2hhbmdlcywgU2ltcGxlQ2hhbmdlcyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVG9vbHRpcERpcmVjdGl2ZSB9IGZyb20gJy4uLy4uL3Rvb2x0aXAvdG9vbHRpcC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgREVGQVVMVF9JTUFHRV9JRCwgSU1BR0VfUkVBREVSLCBJbWFnZVJlYWRlciwgVXNlciwgVXNlckF2YXRhclNpemUgfSBmcm9tICcuL2F2YXRhci5tb2RlbCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2x4LWF2YXRhcicsXG4gIHRlbXBsYXRlVXJsOiAnYXZhdGFyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmw6ICdhdmF0YXIuY29tcG9uZW50LnNjc3MnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbTmdJZiwgQXN5bmNQaXBlLCBOZ0NsYXNzLCBUb29sdGlwRGlyZWN0aXZlXVxufSlcbmV4cG9ydCBjbGFzcyBBdmF0YXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkNoYW5nZXMge1xuICBASW5wdXQoKSB1c2VyITogVXNlciAmIHsgdGVjaG5pY2FsVXNlcj86IGJvb2xlYW4gfTtcbiAgQElucHV0KCkgc2l6ZTogVXNlckF2YXRhclNpemUgPSAnTSc7XG4gIEBJbnB1dCgpIHNob3dNYWlsVG9MaW5rID0gdHJ1ZTtcbiAgQElucHV0KCkgZGlzYWJsZWQgPSBmYWxzZTtcblxuICByZWFkb25seSBOQU1FID0gJ0F2YXRhckNvbXBvbmVudCc7XG5cbiAgcHVibGljIGltYWdlVVJMOiBQcm9taXNlPHN0cmluZz47XG5cbiAgY29uc3RydWN0b3IoQEluamVjdChJTUFHRV9SRUFERVIpIHByaXZhdGUgaW1hZ2VSZWFkZXI6IEltYWdlUmVhZGVyKSB7XG4gICAgdGhpcy5pbWFnZVVSTCA9IHRoaXMuaW1hZ2VSZWFkZXIuZ2V0QXZhdGFyKERFRkFVTFRfSU1BR0VfSUQsIHRoaXMuc2l6ZSwgdGhpcy51c2VyPy5kaXNwbGF5TmFtZSk7XG4gIH1cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XG4gICAgY29uc3QgeyB1c2VyIH0gPSBjaGFuZ2VzO1xuXG4gICAgaWYgKHVzZXIgJiYgdXNlci5jdXJyZW50VmFsdWUgJiYgIXVzZXIuY3VycmVudFZhbHVlLnRlY2huaWNhbFVzZXIpIHtcbiAgICAgIGNvbnN0IHsgaWQsIGRpc3BsYXlOYW1lIH0gPSB0aGlzLnVzZXIgfHwge307XG4gICAgICB0aGlzLmltYWdlVVJMID0gdGhpcy5pbWFnZVJlYWRlci5nZXRBdmF0YXIoaWQgPz8gdW5kZWZpbmVkLCB0aGlzLnNpemUsIGRpc3BsYXlOYW1lKTtcbiAgICB9XG4gIH1cbn1cbiIsIjxuZy1jb250YWluZXIgKm5nSWY9XCJpbWFnZVVSTCB8IGFzeW5jOyBlbHNlIGxvYWRpbmdcIj5cbiAgPG5nLWNvbnRhaW5lciAqbmdJZj1cIiF1c2VyLnRlY2huaWNhbFVzZXI7IGVsc2UgdGVjaG5pY2FsVXNlckljb25cIj5cbiAgICA8YVxuICAgICAgKm5nSWY9XCJzaG93TWFpbFRvTGluayAmJiB1c2VyLmVtYWlsOyBlbHNlIHByb2ZpbGVQaWN0dXJlXCJcbiAgICAgIGNsYXNzPVwidXNlckxpbmtcIlxuICAgICAgaHJlZj1cIm1haWx0bzp7eyB1c2VyLmVtYWlsIH19XCJcbiAgICAgIGx4VG9vbHRpcD1cInt7IHVzZXIuZGlzcGxheU5hbWUgfX1cIlxuICAgID5cbiAgICAgIDxpbWdcbiAgICAgICAgW3NyY109XCJpbWFnZVVSTCB8IGFzeW5jXCJcbiAgICAgICAgY2xhc3M9XCJhdmF0YXJJbWFnZVwiXG4gICAgICAgIFtjbGFzc109XCJzaXplXCJcbiAgICAgICAgW2NsYXNzLmRpc2FibGVkXT1cImRpc2FibGVkXCJcbiAgICAgICAgcm9sZT1cInByZXNlbnRhdGlvblwiXG4gICAgICAgIGFsdD1cInt7IHVzZXIuZGlzcGxheU5hbWUgfX1cIlxuICAgICAgLz5cbiAgICA8L2E+XG4gICAgPG5nLXRlbXBsYXRlICNwcm9maWxlUGljdHVyZT5cbiAgICAgIDxpbWdcbiAgICAgICAgW3NyY109XCJpbWFnZVVSTCB8IGFzeW5jXCJcbiAgICAgICAgY2xhc3M9XCJhdmF0YXJJbWFnZVwiXG4gICAgICAgIFtjbGFzc109XCJzaXplXCJcbiAgICAgICAgW2NsYXNzLmRpc2FibGVkXT1cImRpc2FibGVkXCJcbiAgICAgICAgcm9sZT1cInByZXNlbnRhdGlvblwiXG4gICAgICAgIGFsdD1cInt7IHVzZXIuZGlzcGxheU5hbWUgfX1cIlxuICAgICAgLz5cbiAgICA8L25nLXRlbXBsYXRlPlxuICA8L25nLWNvbnRhaW5lcj5cbiAgPG5nLXRlbXBsYXRlICN0ZWNobmljYWxVc2VySWNvbj5cbiAgICA8aSBjbGFzcz1cImF2YXRhckltYWdlIGZhcyBmYS1yb2JvdFwiIGx4VG9vbHRpcD1cInt7IHVzZXIuZGlzcGxheU5hbWUgfX1cIiBbY2xhc3NdPVwic2l6ZVwiIFtjbGFzcy5kaXNhYmxlZF09XCJkaXNhYmxlZFwiPjwvaT5cbiAgPC9uZy10ZW1wbGF0ZT5cbjwvbmctY29udGFpbmVyPlxuPG5nLXRlbXBsYXRlICNsb2FkaW5nPlxuICA8ZGl2IGNsYXNzPVwiYXZhdGFySW1hZ2UgdXNlckxpbmsgbG9hZGluZ1wiIFtuZ0NsYXNzXT1cInNpemVcIj48L2Rpdj5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
@@ -0,0 +1,49 @@
1
+ import { AVATAR_COLORS, AVATAR_SIZE_MAPPING } from './avatar.model';
2
+ /**
3
+ * Generates an SVG for the avatar initials
4
+ * @param displayName The name of the user
5
+ * @param size The size of the avatar
6
+ * @returns A promise with the data URL of the generated SVG
7
+ */
8
+ export function getInitialsUrl(displayName, size) {
9
+ const twoWordsName = displayName.split(' ').slice(0, 2);
10
+ const initials = twoWordsName.length === 1 ? `${twoWordsName[0]?.[0]}` : `${twoWordsName[0]?.[0]}${twoWordsName[1]?.[0]}`;
11
+ const svg = generateInitialsSVG(initials.toUpperCase(), size && AVATAR_SIZE_MAPPING[size]);
12
+ const blob = new Blob([svg], { type: 'image/svg+xml' });
13
+ return blobToDataURL(blob);
14
+ }
15
+ function hashString(s) {
16
+ let hash = 0;
17
+ let i = 0;
18
+ const l = s.length;
19
+ if (l > 0)
20
+ while (i < l)
21
+ hash = ((hash << 5) - hash + s.charCodeAt(i++)) | 0;
22
+ return Math.abs(hash);
23
+ }
24
+ function getAvatarColorHex(initials) {
25
+ const tagNameHash = hashString(initials.toUpperCase());
26
+ return AVATAR_COLORS[(tagNameHash % 11) + 1];
27
+ }
28
+ function generateInitialsSVG(initials, size = 24) {
29
+ const fontSize = (size * 40) / 100;
30
+ const textY = (size * 63) / 100;
31
+ const svgTemplate = `
32
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 ${size} ${size}" width="${size}" height="${size}" preserveAspectRatio="xMidYMid meet">
33
+ <circle cx="${size / 2}" cy="${size / 2}" r="${size / 2}" fill="${getAvatarColorHex(initials)}"></circle>
34
+ <text x="${size / 2}" y="${textY}" font-family="Arial" font-size="${fontSize}" text-anchor="middle" fill="#ffffff" style="user-select:none;-webkit-user-select:none;-ms-user-select:none;-moz-user-select:none;">
35
+ ${initials}
36
+ </text>
37
+ </svg>`;
38
+ return svgTemplate;
39
+ }
40
+ function blobToDataURL(blob) {
41
+ return new Promise((resolve, reject) => {
42
+ const reader = new FileReader();
43
+ reader.onload = (_e) => resolve(reader.result);
44
+ reader.onerror = (_e) => reject(reader.error);
45
+ reader.onabort = (_e) => reject(new Error('Read aborted'));
46
+ reader.readAsDataURL(blob);
47
+ });
48
+ }
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhdGFyLmhlbHBlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9jb3JlLXVpL2NvbXBvbmVudHMvYXZhdGFyL2F2YXRhci5oZWxwZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsbUJBQW1CLEVBQWtCLE1BQU0sZ0JBQWdCLENBQUM7QUFFcEY7Ozs7O0dBS0c7QUFDSCxNQUFNLFVBQVUsY0FBYyxDQUFDLFdBQW1CLEVBQUUsSUFBcUI7SUFDdkUsTUFBTSxZQUFZLEdBQUcsV0FBVyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQ3hELE1BQU0sUUFBUSxHQUFHLFlBQVksQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLFlBQVksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUcsWUFBWSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUcsWUFBWSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztJQUMxSCxNQUFNLEdBQUcsR0FBRyxtQkFBbUIsQ0FBQyxRQUFRLENBQUMsV0FBVyxFQUFFLEVBQUUsSUFBSSxJQUFJLG1CQUFtQixDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7SUFDM0YsTUFBTSxJQUFJLEdBQUcsSUFBSSxJQUFJLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFBRSxFQUFFLElBQUksRUFBRSxlQUFlLEVBQUUsQ0FBQyxDQUFDO0lBRXhELE9BQU8sYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDO0FBQzdCLENBQUM7QUFFRCxTQUFTLFVBQVUsQ0FBQyxDQUFTO0lBQzNCLElBQUksSUFBSSxHQUFHLENBQUMsQ0FBQztJQUNiLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNWLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxNQUFNLENBQUM7SUFFbkIsSUFBSSxDQUFDLEdBQUcsQ0FBQztRQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUM7WUFBRSxJQUFJLEdBQUcsQ0FBQyxDQUFDLElBQUksSUFBSSxDQUFDLENBQUMsR0FBRyxJQUFJLEdBQUcsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzdFLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztBQUN4QixDQUFDO0FBRUQsU0FBUyxpQkFBaUIsQ0FBQyxRQUFnQjtJQUN6QyxNQUFNLFdBQVcsR0FBRyxVQUFVLENBQUMsUUFBUSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7SUFDdkQsT0FBTyxhQUFhLENBQUMsQ0FBQyxXQUFXLEdBQUcsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7QUFDL0MsQ0FBQztBQUVELFNBQVMsbUJBQW1CLENBQUMsUUFBZ0IsRUFBRSxPQUFlLEVBQUU7SUFDOUQsTUFBTSxRQUFRLEdBQUcsQ0FBQyxJQUFJLEdBQUcsRUFBRSxDQUFDLEdBQUcsR0FBRyxDQUFDO0lBQ25DLE1BQU0sS0FBSyxHQUFHLENBQUMsSUFBSSxHQUFHLEVBQUUsQ0FBQyxHQUFHLEdBQUcsQ0FBQztJQUVoQyxNQUFNLFdBQVcsR0FBRzsyREFDcUMsSUFBSSxJQUFJLElBQUksWUFBWSxJQUFJLGFBQWEsSUFBSTtvQkFDcEYsSUFBSSxHQUFHLENBQUMsU0FBUyxJQUFJLEdBQUcsQ0FBQyxRQUFRLElBQUksR0FBRyxDQUFDLFdBQVcsaUJBQWlCLENBQUMsUUFBUSxDQUFDO2lCQUUzRixJQUFJLEdBQUcsQ0FDVCxRQUFRLEtBQUssb0NBQW9DLFFBQVE7VUFDckQsUUFBUTs7V0FFUCxDQUFDO0lBRVYsT0FBTyxXQUFXLENBQUM7QUFDckIsQ0FBQztBQUVELFNBQVMsYUFBYSxDQUFDLElBQVU7SUFDL0IsT0FBTyxJQUFJLE9BQU8sQ0FBUyxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFBRTtRQUM3QyxNQUFNLE1BQU0sR0FBRyxJQUFJLFVBQVUsRUFBRSxDQUFDO1FBQ2hDLE1BQU0sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLEVBQUUsRUFBRSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsTUFBZ0IsQ0FBQyxDQUFDO1FBQ3pELE1BQU0sQ0FBQyxPQUFPLEdBQUcsQ0FBQyxFQUFFLEVBQUUsRUFBRSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDOUMsTUFBTSxDQUFDLE9BQU8sR0FBRyxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUMsTUFBTSxDQUFDLElBQUksS0FBSyxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUM7UUFDM0QsTUFBTSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUM3QixDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBVkFUQVJfQ09MT1JTLCBBVkFUQVJfU0laRV9NQVBQSU5HLCBVc2VyQXZhdGFyU2l6ZSB9IGZyb20gJy4vYXZhdGFyLm1vZGVsJztcblxuLyoqXG4gKiBHZW5lcmF0ZXMgYW4gU1ZHIGZvciB0aGUgYXZhdGFyIGluaXRpYWxzXG4gKiBAcGFyYW0gZGlzcGxheU5hbWUgVGhlIG5hbWUgb2YgdGhlIHVzZXJcbiAqIEBwYXJhbSBzaXplIFRoZSBzaXplIG9mIHRoZSBhdmF0YXJcbiAqIEByZXR1cm5zIEEgcHJvbWlzZSB3aXRoIHRoZSBkYXRhIFVSTCBvZiB0aGUgZ2VuZXJhdGVkIFNWR1xuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0SW5pdGlhbHNVcmwoZGlzcGxheU5hbWU6IHN0cmluZywgc2l6ZT86IFVzZXJBdmF0YXJTaXplKTogUHJvbWlzZTxzdHJpbmc+IHtcbiAgY29uc3QgdHdvV29yZHNOYW1lID0gZGlzcGxheU5hbWUuc3BsaXQoJyAnKS5zbGljZSgwLCAyKTtcbiAgY29uc3QgaW5pdGlhbHMgPSB0d29Xb3Jkc05hbWUubGVuZ3RoID09PSAxID8gYCR7dHdvV29yZHNOYW1lWzBdPy5bMF19YCA6IGAke3R3b1dvcmRzTmFtZVswXT8uWzBdfSR7dHdvV29yZHNOYW1lWzFdPy5bMF19YDtcbiAgY29uc3Qgc3ZnID0gZ2VuZXJhdGVJbml0aWFsc1NWRyhpbml0aWFscy50b1VwcGVyQ2FzZSgpLCBzaXplICYmIEFWQVRBUl9TSVpFX01BUFBJTkdbc2l6ZV0pO1xuICBjb25zdCBibG9iID0gbmV3IEJsb2IoW3N2Z10sIHsgdHlwZTogJ2ltYWdlL3N2Zyt4bWwnIH0pO1xuXG4gIHJldHVybiBibG9iVG9EYXRhVVJMKGJsb2IpO1xufVxuXG5mdW5jdGlvbiBoYXNoU3RyaW5nKHM6IHN0cmluZyk6IG51bWJlciB7XG4gIGxldCBoYXNoID0gMDtcbiAgbGV0IGkgPSAwO1xuICBjb25zdCBsID0gcy5sZW5ndGg7XG5cbiAgaWYgKGwgPiAwKSB3aGlsZSAoaSA8IGwpIGhhc2ggPSAoKGhhc2ggPDwgNSkgLSBoYXNoICsgcy5jaGFyQ29kZUF0KGkrKykpIHwgMDtcbiAgcmV0dXJuIE1hdGguYWJzKGhhc2gpO1xufVxuXG5mdW5jdGlvbiBnZXRBdmF0YXJDb2xvckhleChpbml0aWFsczogc3RyaW5nKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgY29uc3QgdGFnTmFtZUhhc2ggPSBoYXNoU3RyaW5nKGluaXRpYWxzLnRvVXBwZXJDYXNlKCkpO1xuICByZXR1cm4gQVZBVEFSX0NPTE9SU1sodGFnTmFtZUhhc2ggJSAxMSkgKyAxXTtcbn1cblxuZnVuY3Rpb24gZ2VuZXJhdGVJbml0aWFsc1NWRyhpbml0aWFsczogc3RyaW5nLCBzaXplOiBudW1iZXIgPSAyNCk6IHN0cmluZyB7XG4gIGNvbnN0IGZvbnRTaXplID0gKHNpemUgKiA0MCkgLyAxMDA7XG4gIGNvbnN0IHRleHRZID0gKHNpemUgKiA2MykgLyAxMDA7XG5cbiAgY29uc3Qgc3ZnVGVtcGxhdGUgPSBgXG4gICAgPHN2ZyB4bWxucz1cImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCIgdmlld0JveD1cIjAgMCAke3NpemV9ICR7c2l6ZX1cIiB3aWR0aD1cIiR7c2l6ZX1cIiBoZWlnaHQ9XCIke3NpemV9XCIgcHJlc2VydmVBc3BlY3RSYXRpbz1cInhNaWRZTWlkIG1lZXRcIj5cbiAgICAgIDxjaXJjbGUgY3g9XCIke3NpemUgLyAyfVwiIGN5PVwiJHtzaXplIC8gMn1cIiByPVwiJHtzaXplIC8gMn1cIiBmaWxsPVwiJHtnZXRBdmF0YXJDb2xvckhleChpbml0aWFscyl9XCI+PC9jaXJjbGU+XG4gICAgICA8dGV4dCB4PVwiJHtcbiAgICAgICAgc2l6ZSAvIDJcbiAgICAgIH1cIiB5PVwiJHt0ZXh0WX1cIiBmb250LWZhbWlseT1cIkFyaWFsXCIgZm9udC1zaXplPVwiJHtmb250U2l6ZX1cIiB0ZXh0LWFuY2hvcj1cIm1pZGRsZVwiIGZpbGw9XCIjZmZmZmZmXCIgc3R5bGU9XCJ1c2VyLXNlbGVjdDpub25lOy13ZWJraXQtdXNlci1zZWxlY3Q6bm9uZTstbXMtdXNlci1zZWxlY3Q6bm9uZTstbW96LXVzZXItc2VsZWN0Om5vbmU7XCI+XG4gICAgICAgICR7aW5pdGlhbHN9XG4gICAgICA8L3RleHQ+XG4gICAgPC9zdmc+YDtcblxuICByZXR1cm4gc3ZnVGVtcGxhdGU7XG59XG5cbmZ1bmN0aW9uIGJsb2JUb0RhdGFVUkwoYmxvYjogQmxvYik6IFByb21pc2U8c3RyaW5nPiB7XG4gIHJldHVybiBuZXcgUHJvbWlzZTxzdHJpbmc+KChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICBjb25zdCByZWFkZXIgPSBuZXcgRmlsZVJlYWRlcigpO1xuICAgIHJlYWRlci5vbmxvYWQgPSAoX2UpID0+IHJlc29sdmUocmVhZGVyLnJlc3VsdCBhcyBzdHJpbmcpO1xuICAgIHJlYWRlci5vbmVycm9yID0gKF9lKSA9PiByZWplY3QocmVhZGVyLmVycm9yKTtcbiAgICByZWFkZXIub25hYm9ydCA9IChfZSkgPT4gcmVqZWN0KG5ldyBFcnJvcignUmVhZCBhYm9ydGVkJykpO1xuICAgIHJlYWRlci5yZWFkQXNEYXRhVVJMKGJsb2IpO1xuICB9KTtcbn1cbiJdfQ==
@@ -0,0 +1,33 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ export const IMAGE_READER = new InjectionToken('IMAGE_READER');
3
+ export const DEFAULT_IMAGE_ID = '00000000-0000-4000-0000-000000000001';
4
+ const REFERENCE_SIZE_MAPPING = {
5
+ XS: 16,
6
+ S: 24,
7
+ M: 32,
8
+ L: 40,
9
+ XL: 64
10
+ };
11
+ // We want to use 2x bigger images for avatars to support high resolution displays
12
+ // So we want to draw them in their original size but use 2x the size as reference
13
+ export const AVATAR_SIZE_MAPPING = {
14
+ XS: REFERENCE_SIZE_MAPPING.XS * 2,
15
+ S: REFERENCE_SIZE_MAPPING.S * 2,
16
+ M: REFERENCE_SIZE_MAPPING.M * 2,
17
+ L: REFERENCE_SIZE_MAPPING.L * 2,
18
+ XL: REFERENCE_SIZE_MAPPING.XL * 2
19
+ };
20
+ export const AVATAR_COLORS = [
21
+ '#00a399',
22
+ '#0f7eb5',
23
+ '#18aece',
24
+ '#2889ff',
25
+ '#ff914d',
26
+ '#fad71e',
27
+ '#fe6690',
28
+ '#ab657a',
29
+ '#916b50',
30
+ '#9755cd',
31
+ '#fc9785'
32
+ ];
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhdGFyLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3NyYy9saWIvY29yZS11aS9jb21wb25lbnRzL2F2YXRhci9hdmF0YXIubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQXFCL0MsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLElBQUksY0FBYyxDQUFjLGNBQWMsQ0FBQyxDQUFDO0FBRTVFLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLHNDQUFzQyxDQUFDO0FBY3ZFLE1BQU0sc0JBQXNCLEdBQUc7SUFDN0IsRUFBRSxFQUFFLEVBQUU7SUFDTixDQUFDLEVBQUUsRUFBRTtJQUNMLENBQUMsRUFBRSxFQUFFO0lBQ0wsQ0FBQyxFQUFFLEVBQUU7SUFDTCxFQUFFLEVBQUUsRUFBRTtDQUNQLENBQUM7QUFFRixrRkFBa0Y7QUFDbEYsa0ZBQWtGO0FBQ2xGLE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHO0lBQ2pDLEVBQUUsRUFBRSxzQkFBc0IsQ0FBQyxFQUFFLEdBQUcsQ0FBQztJQUNqQyxDQUFDLEVBQUUsc0JBQXNCLENBQUMsQ0FBQyxHQUFHLENBQUM7SUFDL0IsQ0FBQyxFQUFFLHNCQUFzQixDQUFDLENBQUMsR0FBRyxDQUFDO0lBQy9CLENBQUMsRUFBRSxzQkFBc0IsQ0FBQyxDQUFDLEdBQUcsQ0FBQztJQUMvQixFQUFFLEVBQUUsc0JBQXNCLENBQUMsRUFBRSxHQUFHLENBQUM7Q0FDbEMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBYTtJQUNyQyxTQUFTO0lBQ1QsU0FBUztJQUNULFNBQVM7SUFDVCxTQUFTO0lBQ1QsU0FBUztJQUNULFNBQVM7SUFDVCxTQUFTO0lBQ1QsU0FBUztJQUNULFNBQVM7SUFDVCxTQUFTO0lBQ1QsU0FBUztDQUNWLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuXG4vKiogVGhpcyBpcyBhIHRlbXBvcmFyeSBzdG9yYWdlIGZvciBvdXIgdXNlciBhbmQgaW1hZ2UgcmVsYXRlZCBtb2RlbHMsIGJlZm9yZSB3ZSBmaW5kIGEgYmV0dGVyIHBsYWNlIGZvciB0aGVtXG4gKlxuICogV2UgcmVsb2NhdGVkIHRoZSBtb2RlbHMgaGVyZSB0byBmYWNpbGl0YXRlIG1vdmluZyB0aGUgYXZhdGFyIGFuZCBhdmF0YXIgZ3JvdXAgY29tcG9uZW50cyBvdXQgb2YgdGhlIHVzZXItdWkgZGlyZWN0b3J5LlxuICpcbiAqIFRoaXMgZW5zdXJlcyB3ZSBtYWludGFpbiBhIHNpbmdsZSBzb3VyY2Ugb2YgdHJ1dGggYW5kIGFkaGVyZSB0byB0aGUgY3VycmVudCBzdHJpY3Qgbm8tc2hhcmVkLW54IHBvbGljeSwgc2luY2UgYWxsXG4gKiBsaWJyYXJpZXMgYW5kIGFwcHMgYWxyZWFkeSBzdXBwb3J0IGltcG9ydGluZyBmcm9tIGBAbGVhbml4L2NvbXBvbmVudHNgIGFscmVhZHkuXG4gKi9cblxuZXhwb3J0IHR5cGUgVXNlckF2YXRhclNpemUgPSAnWFMnIHwgJ1MnIHwgJ00nIHwgJ0wnIHwgJ1hMJztcblxuZXhwb3J0IGludGVyZmFjZSBJbWFnZVJlYWRlciB7XG4gIGdldEF2YXRhcih1c2VySWQ/OiBzdHJpbmcsIHNpemU/OiBVc2VyQXZhdGFyU2l6ZSwgZGlzcGxheU5hbWU/OiBzdHJpbmcpOiBQcm9taXNlPHN0cmluZz47XG4gIGdldEF2YXRhclVybCh1c2VySWQ/OiBzdHJpbmcsIHNpemU/OiBVc2VyQXZhdGFyU2l6ZSk6IHN0cmluZztcbiAgZ2V0U3RvcmFnZVNlcnZpY2VBdmF0YXJVcmwodXNlcklkPzogc3RyaW5nLCBzaXplPzogVXNlckF2YXRhclNpemUpOiBzdHJpbmc7XG4gIGdldFRodW1ibmFpbFVybChpbWFnZUlkOiBzdHJpbmcpOiBzdHJpbmc7XG4gIGxvYWRUaHVtYm5haWwoaW1hZ2VJZDogc3RyaW5nKTogT2JzZXJ2YWJsZTxzdHJpbmc+O1xufVxuXG5leHBvcnQgY29uc3QgSU1BR0VfUkVBREVSID0gbmV3IEluamVjdGlvblRva2VuPEltYWdlUmVhZGVyPignSU1BR0VfUkVBREVSJyk7XG5cbmV4cG9ydCBjb25zdCBERUZBVUxUX0lNQUdFX0lEID0gJzAwMDAwMDAwLTAwMDAtNDAwMC0wMDAwLTAwMDAwMDAwMDAwMSc7XG5cbi8qKlxuICogVGhpcyBVc2VyIG1vZGVsIGluY2x1ZGVzIGNvbW1vbiBwcm9wZXJ0aWVzIHRoYXQgdGhlIHVpIGF2YXRhciBjb21wb25lbnRzIGNhcmUgYWJvdXQgaW4gb3JkZXIgdG8gcmVzcHJlc2VudCBhIHVzZXJcbiAqIGluIHRoZSBVSS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBVc2VyIHtcbiAgaWQ/OiBzdHJpbmc7XG4gIGRpc3BsYXlOYW1lPzogc3RyaW5nO1xuICBlbWFpbD86IHN0cmluZztcbiAgZmlyc3ROYW1lPzogc3RyaW5nO1xuICBsYXN0TmFtZT86IHN0cmluZztcbn1cblxuY29uc3QgUkVGRVJFTkNFX1NJWkVfTUFQUElORyA9IHtcbiAgWFM6IDE2LFxuICBTOiAyNCxcbiAgTTogMzIsXG4gIEw6IDQwLFxuICBYTDogNjRcbn07XG5cbi8vIFdlIHdhbnQgdG8gdXNlIDJ4IGJpZ2dlciBpbWFnZXMgZm9yIGF2YXRhcnMgdG8gc3VwcG9ydCBoaWdoIHJlc29sdXRpb24gZGlzcGxheXNcbi8vIFNvIHdlIHdhbnQgdG8gZHJhdyB0aGVtIGluIHRoZWlyIG9yaWdpbmFsIHNpemUgYnV0IHVzZSAyeCB0aGUgc2l6ZSBhcyByZWZlcmVuY2VcbmV4cG9ydCBjb25zdCBBVkFUQVJfU0laRV9NQVBQSU5HID0ge1xuICBYUzogUkVGRVJFTkNFX1NJWkVfTUFQUElORy5YUyAqIDIsXG4gIFM6IFJFRkVSRU5DRV9TSVpFX01BUFBJTkcuUyAqIDIsXG4gIE06IFJFRkVSRU5DRV9TSVpFX01BUFBJTkcuTSAqIDIsXG4gIEw6IFJFRkVSRU5DRV9TSVpFX01BUFBJTkcuTCAqIDIsXG4gIFhMOiBSRUZFUkVOQ0VfU0laRV9NQVBQSU5HLlhMICogMlxufTtcblxuZXhwb3J0IGNvbnN0IEFWQVRBUl9DT0xPUlM6IHN0cmluZ1tdID0gW1xuICAnIzAwYTM5OScsXG4gICcjMGY3ZWI1JyxcbiAgJyMxOGFlY2UnLFxuICAnIzI4ODlmZicsXG4gICcjZmY5MTRkJyxcbiAgJyNmYWQ3MWUnLFxuICAnI2ZlNjY5MCcsXG4gICcjYWI2NTdhJyxcbiAgJyM5MTZiNTAnLFxuICAnIzk3NTVjZCcsXG4gICcjZmM5Nzg1J1xuXTtcbiJdfQ==
@@ -0,0 +1,73 @@
1
+ import { CdkConnectedOverlay, CdkOverlayOrigin } from '@angular/cdk/overlay';
2
+ import { NgClass, NgFor, NgIf } from '@angular/common';
3
+ import { Component, Input, ViewChild } from '@angular/core';
4
+ import { DisplayAvatarsPipe } from '../../pipes/display-avatars.pipe';
5
+ import { TooltipDirective } from '../../tooltip/tooltip.directive';
6
+ import { AvatarComponent } from '../avatar/avatar.component';
7
+ import * as i0 from "@angular/core";
8
+ export class AvatarGroupComponent {
9
+ get userNames() {
10
+ return this.users
11
+ .map(({ displayName }) => displayName)
12
+ .sort()
13
+ .join('<br>');
14
+ }
15
+ constructor(cdr, zone) {
16
+ this.cdr = cdr;
17
+ this.zone = zone;
18
+ this.NAME = 'AvatarGroupComponent';
19
+ this.users = [];
20
+ this.size = 'M';
21
+ this.type = 'group';
22
+ this.maxLength = 0;
23
+ this.autoScale = false;
24
+ this.disabledUserIds = [];
25
+ this.overlayVisible = false;
26
+ this.resizeObserver = new ResizeObserver(() => {
27
+ this.zone.runOutsideAngular(() => {
28
+ this.zone.run(() => {
29
+ this.cdr.detectChanges();
30
+ });
31
+ });
32
+ });
33
+ }
34
+ ngAfterViewInit() {
35
+ this.resizeObserver.observe(this.userGroupElement.nativeElement);
36
+ }
37
+ handleClick(event) {
38
+ event.stopPropagation();
39
+ this.overlayVisible = true;
40
+ }
41
+ ngOnDestroy() {
42
+ if (this.resizeObserver && this.userGroupElement) {
43
+ this.resizeObserver.unobserve(this.userGroupElement.nativeElement);
44
+ }
45
+ }
46
+ isUserDisabled(user) {
47
+ return !!user.id && this.disabledUserIds.includes(user.id);
48
+ }
49
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AvatarGroupComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
50
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: AvatarGroupComponent, isStandalone: true, selector: "lx-avatar-group", inputs: { title: "title", users: "users", size: "size", type: "type", maxLength: "maxLength", autoScale: "autoScale", disabledUserIds: "disabledUserIds" }, viewQueries: [{ propertyName: "userGroupElement", first: true, predicate: ["userGroup"], descendants: true }], ngImport: i0, template: "<div\n #userGroup\n (click)=\"handleClick($event)\"\n (keydown.enter)=\"handleClick($event)\"\n (keydown.space)=\"handleClick($event)\"\n cdkOverlayOrigin\n #trigger=\"cdkOverlayOrigin\"\n [lxTooltip]=\"!overlayVisible ? userNames : null\"\n [lxTooltipIsHtmlContent]=\"true\"\n tabindex=\"0\"\n role=\"button\"\n aria-haspopup=\"dialog\"\n>\n <div *ngIf=\"users | displayAvatars: type : size : userGroup.offsetWidth : autoScale : maxLength as filteredUsers\" class=\"group-container\">\n <lx-avatar\n [user]=\"user\"\n [size]=\"size\"\n [showMailToLink]=\"false\"\n [disabled]=\"isUserDisabled(user)\"\n [ngClass]=\"[type === 'individual' ? 'individual' : 'group', size]\"\n *ngFor=\"let user of filteredUsers\"\n />\n <div\n *ngIf=\"filteredUsers.length < users.length\"\n [ngClass]=\"[type === 'individual' ? 'individual' : 'group', size]\"\n class=\"more-users-icon\"\n >\n +{{ users.length - filteredUsers.length }}\n </div>\n </div>\n</div>\n\n<ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayOpen]=\"overlayVisible\"\n (overlayOutsideClick)=\"overlayVisible = false\"\n>\n <div class=\"avatars-overlay\">\n <div *ngIf=\"title\" class=\"avatars-overlay-title\">{{ title }}</div>\n <div class=\"avatars-list\">\n <div *ngFor=\"let user of users\" class=\"individual\">\n <lx-avatar [user]=\"user\" [size]=\"size\" [showMailToLink]=\"true\" [disabled]=\"isUserDisabled(user)\" />\n </div>\n </div>\n </div>\n</ng-template>\n", styles: [".group-container{display:flex;align-items:center}.group-container lx-avatar{display:flex;align-items:center}.group-container .more-users-icon{color:#61779d;background-color:#fff;border:1px solid #c2c9d6;border-radius:50%;font-weight:700;-webkit-user-select:none;user-select:none}.individual{margin-right:2px!important}.avatars-overlay{max-width:360px;overflow:auto;margin-top:5px;border-radius:10px;background-color:#fff;border:1px solid #c2c9d6;box-shadow:0 6px 12px #0000002d}.avatars-overlay .avatars-list{display:flex;flex-wrap:wrap;padding:10px}.avatars-overlay .avatars-list lx-avatar{display:block;margin-bottom:5px}.avatars-overlay .avatars-overlay-title{border-bottom:1px solid #c2c9d6;padding:10px;font-weight:700}.XS{width:16px;height:16px;line-height:16px;font-size:8px}.XS.group:not(:first-child){margin-left:-8px}.S{width:24px;height:24px;line-height:24px;font-size:11.25px}.S.group:not(:first-child){margin-left:-12px}.M{width:32px;height:32px;line-height:32px;text-align:center;vertical-align:middle;font-size:15.5px}.M.group:not(:first-child){margin-left:-10px}.L{width:40px;height:40px;line-height:40px;text-align:center;vertical-align:middle;font-size:large}.L.group:not(:first-child){margin-left:-20px}.XL{width:64px;height:64px;line-height:64px;text-align:center;vertical-align:middle;font-size:large}.XL.group:not(:first-child){margin-left:-50px}\n"], dependencies: [{ kind: "directive", type: CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }, { kind: "directive", type: TooltipDirective, selector: "[lxTooltip]", inputs: ["lxTooltip", "lxTooltipPosition", "lxTooltipDelay", "lxTooltipIsHtmlContent"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: AvatarComponent, selector: "lx-avatar", inputs: ["user", "size", "showMailToLink", "disabled"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush", "cdkConnectedOverlayDisposeOnNavigation"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }, { kind: "pipe", type: DisplayAvatarsPipe, name: "displayAvatars" }] }); }
51
+ }
52
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AvatarGroupComponent, decorators: [{
53
+ type: Component,
54
+ args: [{ selector: 'lx-avatar-group', standalone: true, imports: [CdkOverlayOrigin, TooltipDirective, NgIf, NgFor, AvatarComponent, NgClass, CdkConnectedOverlay, DisplayAvatarsPipe], template: "<div\n #userGroup\n (click)=\"handleClick($event)\"\n (keydown.enter)=\"handleClick($event)\"\n (keydown.space)=\"handleClick($event)\"\n cdkOverlayOrigin\n #trigger=\"cdkOverlayOrigin\"\n [lxTooltip]=\"!overlayVisible ? userNames : null\"\n [lxTooltipIsHtmlContent]=\"true\"\n tabindex=\"0\"\n role=\"button\"\n aria-haspopup=\"dialog\"\n>\n <div *ngIf=\"users | displayAvatars: type : size : userGroup.offsetWidth : autoScale : maxLength as filteredUsers\" class=\"group-container\">\n <lx-avatar\n [user]=\"user\"\n [size]=\"size\"\n [showMailToLink]=\"false\"\n [disabled]=\"isUserDisabled(user)\"\n [ngClass]=\"[type === 'individual' ? 'individual' : 'group', size]\"\n *ngFor=\"let user of filteredUsers\"\n />\n <div\n *ngIf=\"filteredUsers.length < users.length\"\n [ngClass]=\"[type === 'individual' ? 'individual' : 'group', size]\"\n class=\"more-users-icon\"\n >\n +{{ users.length - filteredUsers.length }}\n </div>\n </div>\n</div>\n\n<ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayOpen]=\"overlayVisible\"\n (overlayOutsideClick)=\"overlayVisible = false\"\n>\n <div class=\"avatars-overlay\">\n <div *ngIf=\"title\" class=\"avatars-overlay-title\">{{ title }}</div>\n <div class=\"avatars-list\">\n <div *ngFor=\"let user of users\" class=\"individual\">\n <lx-avatar [user]=\"user\" [size]=\"size\" [showMailToLink]=\"true\" [disabled]=\"isUserDisabled(user)\" />\n </div>\n </div>\n </div>\n</ng-template>\n", styles: [".group-container{display:flex;align-items:center}.group-container lx-avatar{display:flex;align-items:center}.group-container .more-users-icon{color:#61779d;background-color:#fff;border:1px solid #c2c9d6;border-radius:50%;font-weight:700;-webkit-user-select:none;user-select:none}.individual{margin-right:2px!important}.avatars-overlay{max-width:360px;overflow:auto;margin-top:5px;border-radius:10px;background-color:#fff;border:1px solid #c2c9d6;box-shadow:0 6px 12px #0000002d}.avatars-overlay .avatars-list{display:flex;flex-wrap:wrap;padding:10px}.avatars-overlay .avatars-list lx-avatar{display:block;margin-bottom:5px}.avatars-overlay .avatars-overlay-title{border-bottom:1px solid #c2c9d6;padding:10px;font-weight:700}.XS{width:16px;height:16px;line-height:16px;font-size:8px}.XS.group:not(:first-child){margin-left:-8px}.S{width:24px;height:24px;line-height:24px;font-size:11.25px}.S.group:not(:first-child){margin-left:-12px}.M{width:32px;height:32px;line-height:32px;text-align:center;vertical-align:middle;font-size:15.5px}.M.group:not(:first-child){margin-left:-10px}.L{width:40px;height:40px;line-height:40px;text-align:center;vertical-align:middle;font-size:large}.L.group:not(:first-child){margin-left:-20px}.XL{width:64px;height:64px;line-height:64px;text-align:center;vertical-align:middle;font-size:large}.XL.group:not(:first-child){margin-left:-50px}\n"] }]
55
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.NgZone }], propDecorators: { title: [{
56
+ type: Input
57
+ }], users: [{
58
+ type: Input
59
+ }], size: [{
60
+ type: Input
61
+ }], type: [{
62
+ type: Input
63
+ }], maxLength: [{
64
+ type: Input
65
+ }], autoScale: [{
66
+ type: Input
67
+ }], disabledUserIds: [{
68
+ type: Input
69
+ }], userGroupElement: [{
70
+ type: ViewChild,
71
+ args: ['userGroup']
72
+ }] } });
73
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar-group.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/core-ui/components/avatar-group/avatar-group.component.ts","../../../../../../../../libs/components/src/lib/core-ui/components/avatar-group/avatar-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkConnectedOverlay, CdkOverlayOrigin } from '@angular/cdk/overlay';\nimport { NgClass, NgFor, NgIf } from '@angular/common';\nimport { AfterViewInit, ChangeDetectorRef, Component, ElementRef, Input, NgZone, OnDestroy, ViewChild } from '@angular/core';\nimport { DisplayAvatarsPipe } from '../../pipes/display-avatars.pipe';\nimport { TooltipDirective } from '../../tooltip/tooltip.directive';\nimport { AvatarComponent } from '../avatar/avatar.component';\nimport { User, UserAvatarSize } from '../avatar/avatar.model';\n\n@Component({\n  selector: 'lx-avatar-group',\n  templateUrl: 'avatar-group.component.html',\n  styleUrls: ['avatar-group.component.scss'],\n  standalone: true,\n  imports: [CdkOverlayOrigin, TooltipDirective, NgIf, NgFor, AvatarComponent, NgClass, CdkConnectedOverlay, DisplayAvatarsPipe]\n})\nexport class AvatarGroupComponent implements AfterViewInit, OnDestroy {\n  readonly NAME = 'AvatarGroupComponent';\n\n  @Input() title?: string;\n  @Input() users: (User & { technicalUser?: boolean })[] = [];\n  @Input() size: UserAvatarSize = 'M';\n  @Input() type: 'individual' | 'group' = 'group';\n  @Input() maxLength: number = 0;\n  @Input() autoScale: boolean = false;\n  @Input() disabledUserIds: string[] = [];\n\n  @ViewChild('userGroup') userGroupElement!: ElementRef<HTMLElement>;\n\n  get userNames() {\n    return this.users\n      .map(({ displayName }) => displayName)\n      .sort()\n      .join('<br>');\n  }\n\n  public overlayVisible = false;\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private zone: NgZone\n  ) {}\n\n  ngAfterViewInit(): void {\n    this.resizeObserver.observe(this.userGroupElement.nativeElement);\n  }\n\n  resizeObserver = new ResizeObserver(() => {\n    this.zone.runOutsideAngular(() => {\n      this.zone.run(() => {\n        this.cdr.detectChanges();\n      });\n    });\n  });\n\n  handleClick(event: Event) {\n    event.stopPropagation();\n    this.overlayVisible = true;\n  }\n\n  ngOnDestroy(): void {\n    if (this.resizeObserver && this.userGroupElement) {\n      this.resizeObserver.unobserve(this.userGroupElement.nativeElement);\n    }\n  }\n\n  isUserDisabled(user: User): boolean {\n    return !!user.id && this.disabledUserIds.includes(user.id);\n  }\n}\n","<div\n  #userGroup\n  (click)=\"handleClick($event)\"\n  (keydown.enter)=\"handleClick($event)\"\n  (keydown.space)=\"handleClick($event)\"\n  cdkOverlayOrigin\n  #trigger=\"cdkOverlayOrigin\"\n  [lxTooltip]=\"!overlayVisible ? userNames : null\"\n  [lxTooltipIsHtmlContent]=\"true\"\n  tabindex=\"0\"\n  role=\"button\"\n  aria-haspopup=\"dialog\"\n>\n  <div *ngIf=\"users | displayAvatars: type : size : userGroup.offsetWidth : autoScale : maxLength as filteredUsers\" class=\"group-container\">\n    <lx-avatar\n      [user]=\"user\"\n      [size]=\"size\"\n      [showMailToLink]=\"false\"\n      [disabled]=\"isUserDisabled(user)\"\n      [ngClass]=\"[type === 'individual' ? 'individual' : 'group', size]\"\n      *ngFor=\"let user of filteredUsers\"\n    />\n    <div\n      *ngIf=\"filteredUsers.length < users.length\"\n      [ngClass]=\"[type === 'individual' ? 'individual' : 'group', size]\"\n      class=\"more-users-icon\"\n    >\n      +{{ users.length - filteredUsers.length }}\n    </div>\n  </div>\n</div>\n\n<ng-template\n  cdkConnectedOverlay\n  [cdkConnectedOverlayOrigin]=\"trigger\"\n  [cdkConnectedOverlayOpen]=\"overlayVisible\"\n  (overlayOutsideClick)=\"overlayVisible = false\"\n>\n  <div class=\"avatars-overlay\">\n    <div *ngIf=\"title\" class=\"avatars-overlay-title\">{{ title }}</div>\n    <div class=\"avatars-list\">\n      <div *ngFor=\"let user of users\" class=\"individual\">\n        <lx-avatar [user]=\"user\" [size]=\"size\" [showMailToLink]=\"true\" [disabled]=\"isUserDisabled(user)\" />\n      </div>\n    </div>\n  </div>\n</ng-template>\n"]}
@@ -0,0 +1,37 @@
1
+ import { Pipe } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class DisplayAvatarsPipe {
4
+ transform(users, type, size, userGroupWidth, autoScale, maxLength) {
5
+ if (maxLength) {
6
+ return users.slice(0, maxLength);
7
+ }
8
+ if (autoScale) {
9
+ if (type === 'group') {
10
+ const usersToShow = Math.floor((userGroupWidth - 2 * SIZES[size]) / ((SIZES[size] * 2) / 3)) + 1;
11
+ return users.slice(0, usersToShow);
12
+ }
13
+ else {
14
+ const usersToShow = Math.floor(userGroupWidth / (SIZES[size] + 2)) - 1;
15
+ return users.slice(0, usersToShow);
16
+ }
17
+ }
18
+ return users;
19
+ }
20
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: DisplayAvatarsPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
21
+ static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.8", ngImport: i0, type: DisplayAvatarsPipe, isStandalone: true, name: "displayAvatars" }); }
22
+ }
23
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: DisplayAvatarsPipe, decorators: [{
24
+ type: Pipe,
25
+ args: [{
26
+ name: 'displayAvatars',
27
+ standalone: true
28
+ }]
29
+ }] });
30
+ const SIZES = {
31
+ XS: 16,
32
+ S: 24,
33
+ M: 32,
34
+ L: 40,
35
+ XL: 64
36
+ };
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzcGxheS1hdmF0YXJzLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9jb3JlLXVpL3BpcGVzL2Rpc3BsYXktYXZhdGFycy5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOztBQU9wRCxNQUFNLE9BQU8sa0JBQWtCO0lBQzdCLFNBQVMsQ0FDUCxLQUE2QyxFQUM3QyxJQUE0QixFQUM1QixJQUFvQixFQUNwQixjQUFzQixFQUN0QixTQUFrQixFQUNsQixTQUFpQjtRQUVqQixJQUFJLFNBQVMsRUFBRSxDQUFDO1lBQ2QsT0FBTyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxTQUFTLENBQUMsQ0FBQztRQUNuQyxDQUFDO1FBQ0QsSUFBSSxTQUFTLEVBQUUsQ0FBQztZQUNkLElBQUksSUFBSSxLQUFLLE9BQU8sRUFBRSxDQUFDO2dCQUNyQixNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsY0FBYyxHQUFHLENBQUMsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO2dCQUNqRyxPQUFPLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLFdBQVcsQ0FBQyxDQUFDO1lBQ3JDLENBQUM7aUJBQU0sQ0FBQztnQkFDTixNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLGNBQWMsR0FBRyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQztnQkFDdkUsT0FBTyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxXQUFXLENBQUMsQ0FBQztZQUNyQyxDQUFDO1FBQ0gsQ0FBQztRQUNELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQzs4R0F0QlUsa0JBQWtCOzRHQUFsQixrQkFBa0I7OzJGQUFsQixrQkFBa0I7a0JBSjlCLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLGdCQUFnQjtvQkFDdEIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOztBQTRCRCxNQUFNLEtBQUssR0FBWTtJQUNyQixFQUFFLEVBQUUsRUFBRTtJQUNOLENBQUMsRUFBRSxFQUFFO0lBQ0wsQ0FBQyxFQUFFLEVBQUU7SUFDTCxDQUFDLEVBQUUsRUFBRTtJQUNMLEVBQUUsRUFBRSxFQUFFO0NBQ1AsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFVzZXIsIFVzZXJBdmF0YXJTaXplIH0gZnJvbSAnLi4vY29tcG9uZW50cy9hdmF0YXIvYXZhdGFyLm1vZGVsJztcblxuQFBpcGUoe1xuICBuYW1lOiAnZGlzcGxheUF2YXRhcnMnLFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIERpc3BsYXlBdmF0YXJzUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICB0cmFuc2Zvcm0oXG4gICAgdXNlcnM6IChVc2VyICYgeyB0ZWNobmljYWxVc2VyPzogYm9vbGVhbiB9KVtdLFxuICAgIHR5cGU6ICdpbmRpdmlkdWFsJyB8ICdncm91cCcsXG4gICAgc2l6ZTogVXNlckF2YXRhclNpemUsXG4gICAgdXNlckdyb3VwV2lkdGg6IG51bWJlcixcbiAgICBhdXRvU2NhbGU6IGJvb2xlYW4sXG4gICAgbWF4TGVuZ3RoOiBudW1iZXJcbiAgKTogKFVzZXIgJiB7IHRlY2huaWNhbFVzZXI/OiBib29sZWFuIH0pW10ge1xuICAgIGlmIChtYXhMZW5ndGgpIHtcbiAgICAgIHJldHVybiB1c2Vycy5zbGljZSgwLCBtYXhMZW5ndGgpO1xuICAgIH1cbiAgICBpZiAoYXV0b1NjYWxlKSB7XG4gICAgICBpZiAodHlwZSA9PT0gJ2dyb3VwJykge1xuICAgICAgICBjb25zdCB1c2Vyc1RvU2hvdyA9IE1hdGguZmxvb3IoKHVzZXJHcm91cFdpZHRoIC0gMiAqIFNJWkVTW3NpemVdKSAvICgoU0laRVNbc2l6ZV0gKiAyKSAvIDMpKSArIDE7XG4gICAgICAgIHJldHVybiB1c2Vycy5zbGljZSgwLCB1c2Vyc1RvU2hvdyk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBjb25zdCB1c2Vyc1RvU2hvdyA9IE1hdGguZmxvb3IodXNlckdyb3VwV2lkdGggLyAoU0laRVNbc2l6ZV0gKyAyKSkgLSAxO1xuICAgICAgICByZXR1cm4gdXNlcnMuc2xpY2UoMCwgdXNlcnNUb1Nob3cpO1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gdXNlcnM7XG4gIH1cbn1cblxudHlwZSBTaXplTWFwID0geyBbSyBpbiBVc2VyQXZhdGFyU2l6ZV06IG51bWJlciB9O1xuXG5jb25zdCBTSVpFUzogU2l6ZU1hcCA9IHtcbiAgWFM6IDE2LFxuICBTOiAyNCxcbiAgTTogMzIsXG4gIEw6IDQwLFxuICBYTDogNjRcbn07XG4iXX0=