@ethlete/cdk 4.46.1 → 4.47.0
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/CHANGELOG.md +6 -0
- package/esm2022/lib/components/accordion/components/accordion/accordion.component.mjs +3 -3
- package/esm2022/lib/components/accordion/components/accordion-group/accordion-group.component.mjs +3 -3
- package/esm2022/lib/components/accordion/partials/accordion-hint/accordion-hint.directive.mjs +3 -3
- package/esm2022/lib/components/accordion/partials/accordion-hint-wrapper/accordion-hint-wrapper.directive.mjs +3 -3
- package/esm2022/lib/components/accordion/partials/accordion-label/accordion-label.directive.mjs +3 -3
- package/esm2022/lib/components/accordion/partials/accordion-label-wrapper/accordion-label-wrapper.directive.mjs +3 -3
- package/esm2022/lib/components/bracket/components/bracket/bracket.component.mjs +3 -3
- package/esm2022/lib/components/bracket/components/new-bracket/bracket-new.mjs +287 -126
- package/esm2022/lib/components/bracket/components/new-bracket/draw-man.mjs +129 -41
- package/esm2022/lib/components/bracket/components/new-bracket/grid-placements.mjs +4 -1
- package/esm2022/lib/components/bracket/components/new-bracket/new-bracket-default-match.component.mjs +3 -3
- package/esm2022/lib/components/bracket/components/new-bracket/new-bracket-default-round-header.component.mjs +3 -3
- package/esm2022/lib/components/bracket/components/new-bracket/new-bracket.component.mjs +23 -8
- package/esm2022/lib/components/bracket/directives/bracket-match/bracket-match.directive.mjs +3 -3
- package/esm2022/lib/components/bracket/directives/bracket-round/bracket-round.directive.mjs +3 -3
- package/esm2022/lib/components/bracket/partials/bracket-match/bracket-match.component.mjs +3 -3
- package/esm2022/lib/components/bracket/partials/bracket-round-header/bracket-round-header.component.mjs +3 -3
- package/esm2022/lib/components/button/components/button/button.component.mjs +3 -3
- package/esm2022/lib/components/button/components/query-button/query-button.component.mjs +3 -3
- package/esm2022/lib/components/button/directives/button/button.directive.mjs +3 -3
- package/esm2022/lib/components/button/directives/query-button/query-button.directive.mjs +3 -3
- package/esm2022/lib/components/carousel/carousel.component.mjs +3 -3
- package/esm2022/lib/components/carousel/carousel.directive.mjs +3 -3
- package/esm2022/lib/components/carousel/controls/carousel-item-nav.component.mjs +3 -3
- package/esm2022/lib/components/carousel/controls/carousel-item-nav.directive.mjs +3 -3
- package/esm2022/lib/components/carousel/controls/carousel-next-button.directive.mjs +3 -3
- package/esm2022/lib/components/carousel/controls/carousel-previous-button.directive.mjs +3 -3
- package/esm2022/lib/components/carousel/controls/carousel-toggle-auto-play-button.directive.mjs +3 -3
- package/esm2022/lib/components/carousel/et-carousel-item.component.mjs +3 -3
- package/esm2022/lib/components/carousel/et-carousel-item.directive.mjs +3 -3
- package/esm2022/lib/components/filter/rich-filter/components/rich-filter-host/rich-filter-host.component.mjs +3 -3
- package/esm2022/lib/components/filter/rich-filter/directives/rich-filter-button/rich-filter-button.directive.mjs +3 -3
- package/esm2022/lib/components/filter/rich-filter/directives/rich-filter-button-slot/rich-filter-button-slot.directive.mjs +3 -3
- package/esm2022/lib/components/filter/rich-filter/directives/rich-filter-content/rich-filter-content.directive.mjs +3 -3
- package/esm2022/lib/components/filter/rich-filter/directives/rich-filter-top/rich-filter-top.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/checkbox/components/checkbox/checkbox.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/checkbox/components/checkbox-field/checkbox-field.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/checkbox/components/checkbox-group/checkbox-group.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/checkbox/directives/checkbox/checkbox.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/checkbox/directives/checkbox-field/checkbox-field.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/checkbox/directives/checkbox-group/checkbox-group.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/checkbox/directives/checkbox-group-control/checkbox-group-control.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/error/components/error/error.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/components/color-input/color-input.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/components/date-input/date-input.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/components/date-time-input/date-time-input.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/components/email-input/email-input.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/components/input-field/input-field.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/components/number-input/number-input.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/components/password-input/password-input.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/components/search-input/search-input.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/components/tel-input/tel-input.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/components/text-input/text-input.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/components/textarea-input/textarea-input.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/components/time-input/time-input.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/directives/autosize-textarea/autosize-textarea.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/directives/color-input/color-input.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/directives/date-input/date-input.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/directives/date-time-input/date-time-input.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/directives/email-input/email-input.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/directives/if-supports-show-picker/if-supports-show-picker.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/directives/number-input/number-input.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/directives/password-input/password-input.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/directives/search-input/search-input.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/directives/show-picker-trigger/show-picker-trigger.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/directives/tel-input/tel-input.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/directives/text-input/text-input.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/directives/textarea-input/textarea-input.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/directives/time-input/time-input.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/partials/password-input-toggle/password-input-toggle.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/input/partials/search-input-clear/search-input-clear.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/label/components/label/label.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/label/directives/label-suffix/label-suffix.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/radio/components/radio/radio.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/radio/components/radio-field/radio-field.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/radio/components/radio-group/radio-group.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/radio/directives/radio/radio.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/radio/directives/radio-field/radio-field.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/radio/directives/radio-group/radio-group.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/segmented-button/components/segmented-button/segmented-button.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/segmented-button/components/segmented-button-field/segmented-button-field.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/segmented-button/components/segmented-button-group/segmented-button-group.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/segmented-button/directives/segmented-button/segmented-button.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/segmented-button/directives/segmented-button-field/segmented-button-field.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/segmented-button/directives/segmented-button-group/segmented-button-group.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/combobox/components/combobox/combobox.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox/combobox.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-body-empty-template/combobox-body-empty-template.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-body-error-template/combobox-body-error-template.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-body-loading-template/combobox-body-loading-template.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-body-more-items-hint-template/combobox-body-more-items-hint-template.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-option-template/combobox-option-template.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-selected-option-template/combobox-selected-option-template.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/combobox/partials/combobox-body/combobox-body.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/combobox/partials/combobox-option/combobox-option.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/native-select/components/native-select/native-select.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/native-select/directives/native-select-input/native-select-input.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/native-select/directives/native-select-option/native-select-option.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/native-select/partials/native-select-option/native-select-option.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/select/components/select/select.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/select/directives/select/select.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/select/directives/select-body/select-body.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/select/directives/select-option/select-option.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/select/partials/select-body/select-body.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/select/partials/select-option/select-option.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/select-field/select-field.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/directives/select-field/select-field.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/selection-list/components/selection-list-field/selection-list-field.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/selection-list/components/selection-list-option/selection-list-option.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/selection-list/directives/selection-list-field/selection-list-field.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/selection-list/directives/selection-list-option/selection-list-option.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/slide-toggle/components/slide-toggle/slide-toggle.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/slide-toggle/components/slide-toggle-field/slide-toggle-field.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/slide-toggle/directives/slide-toggle/slide-toggle.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/slider/components/slider/slider.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/slider/components/slider-field/slider-field.component.mjs +3 -3
- package/esm2022/lib/components/forms/directives/dynamic-form-field/dynamic-form-field.directive.mjs +3 -3
- package/esm2022/lib/components/forms/directives/dynamic-form-group/dynamic-form-group.directive.mjs +3 -3
- package/esm2022/lib/components/forms/directives/expose-input-vars/expose-input-vars.directive.mjs +3 -3
- package/esm2022/lib/components/forms/directives/if-input-empty/if-input-empty.directive.mjs +3 -3
- package/esm2022/lib/components/forms/directives/if-input-filled/if-input-filled.directive.mjs +3 -3
- package/esm2022/lib/components/forms/directives/input/input.directive.mjs +3 -3
- package/esm2022/lib/components/forms/directives/input-prefix/input-prefix.directive.mjs +3 -3
- package/esm2022/lib/components/forms/directives/input-suffix/input-suffix.directive.mjs +3 -3
- package/esm2022/lib/components/forms/directives/native-input-ref/native-input-ref.directive.mjs +3 -3
- package/esm2022/lib/components/forms/directives/static-form-field/static-form-field.directive.mjs +3 -3
- package/esm2022/lib/components/forms/directives/static-form-group/static-form-group.directive.mjs +3 -3
- package/esm2022/lib/components/forms/directives/writeable-input/writeable-input.directive.mjs +3 -3
- package/esm2022/lib/components/forms/services/default-validator-errors.service.mjs +3 -3
- package/esm2022/lib/components/forms/services/form-field-state.service.mjs +3 -3
- package/esm2022/lib/components/forms/services/form-group-state.service.mjs +3 -3
- package/esm2022/lib/components/forms/services/input-state.service.mjs +3 -3
- package/esm2022/lib/components/forms/utils/decorated-form-field.base.mjs +3 -3
- package/esm2022/lib/components/forms/utils/decorated-input.base.mjs +3 -3
- package/esm2022/lib/components/forms/utils/input.base.mjs +3 -3
- package/esm2022/lib/components/icons/chevron-icon/chevron-icon.component.mjs +3 -3
- package/esm2022/lib/components/icons/times-icon/times-icon.component.mjs +3 -3
- package/esm2022/lib/components/masonry/components/masonry/masonry.component.mjs +3 -3
- package/esm2022/lib/components/masonry/partials/masonry-item/masonry-item.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/bottom-sheet/components/bottom-sheet-container/bottom-sheet-container.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/bottom-sheet/partials/bottom-sheet-container-base/bottom-sheet-container-base.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/bottom-sheet/partials/bottom-sheet-drag-handle/bottom-sheet-drag-handle.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/bottom-sheet/partials/bottom-sheet-title/bottom-sheet-title.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/bottom-sheet/services/bottom-sheet-base.service.mjs +3 -3
- package/esm2022/lib/components/overlay/components/bottom-sheet/services/bottom-sheet-swipe-handler.service.mjs +3 -3
- package/esm2022/lib/components/overlay/components/bottom-sheet/services/bottom-sheet.service.mjs +3 -3
- package/esm2022/lib/components/overlay/components/dialog/components/dialog-container/dialog-container.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/dialog/partials/dialog-close/dialog-close.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/dialog/partials/dialog-container-base/dialog-container-base.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/dialog/partials/dialog-title/dialog-title.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/dialog/services/dialog-base.service.mjs +3 -3
- package/esm2022/lib/components/overlay/components/dialog/services/dialog.service.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu/components/menu/menu.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu/components/menu-checkbox-item/menu-checkbox-item.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu/components/menu-container/menu-container.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu/components/menu-radio-item/menu-radio-item.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu/directives/menu-checkbox-group/menu-checkbox-group.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu/directives/menu-group/menu-group.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu/directives/menu-group-title/menu-group-title.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu/directives/menu-item/menu-item.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu/directives/menu-radio-group/menu-radio-group.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu/directives/menu-search-template/menu-search-template.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu/directives/menu-trigger/menu-trigger.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu-deprecated/context-menu-trigger.mjs +6 -6
- package/esm2022/lib/components/overlay/components/menu-deprecated/menu-aim.mjs +6 -6
- package/esm2022/lib/components/overlay/components/menu-deprecated/menu-bar.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu-deprecated/menu-base.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu-deprecated/menu-group.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu-deprecated/menu-item-checkbox.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu-deprecated/menu-item-radio.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu-deprecated/menu-item-selectable.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu-deprecated/menu-item.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu-deprecated/menu-module.mjs +4 -4
- package/esm2022/lib/components/overlay/components/menu-deprecated/menu-stack.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu-deprecated/menu-trigger-base.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu-deprecated/menu-trigger.mjs +3 -3
- package/esm2022/lib/components/overlay/components/menu-deprecated/menu.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/components/overlay-container/overlay-container.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-back-or-close/overlay-back-or-close.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-body/overlay-body.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-close/overlay-close.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-footer/overlay-footer.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-header/overlay-header.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-header-template/overlay-header-template.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-main/overlay-main.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-route-header-template-outlet/overlay-route-header-template-outlet.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-router-link/overlay-router-link.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-router-outlet/overlay-router-outlet.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-router-outlet-disabled-template/overlay-router-outlet-disabled-template.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-shared-route-template/overlay-shared-route-template.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-shared-route-template-outlet/overlay-shared-route-template-outlet.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-sidebar/overlay-sidebar.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-sidebar-page/overlay-sidebar-page.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-title/overlay-title.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/services/overlay.service.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/utils/filter-overlay.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/utils/overlay-handler-link.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/toggletip/components/toggletip/toggletip.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/toggletip/directives/toggletip/toggletip.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/toggletip/partials/toggletip-close/toggletip-close.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/tooltip/components/tooltip/tooltip.component.mjs +3 -3
- package/esm2022/lib/components/overlay/components/tooltip/directives/tooltip/tooltip.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/directives/dynamic-overlay-title/dynamic-overlay-title.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/directives/overlay-close-auto-blocker/overlay-close-auto-blocker.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/services/dynamic-overlay.service.mjs +3 -3
- package/esm2022/lib/components/pagination/components/pagination/pagination.component.mjs +3 -3
- package/esm2022/lib/components/pagination/partials/pagination-link/pagination-link.directive.mjs +3 -3
- package/esm2022/lib/components/pagination/services/pagination-head.service.mjs +3 -3
- package/esm2022/lib/components/picture/components/picture/picture.component.mjs +3 -3
- package/esm2022/lib/components/progress-spinner/progress-spinner.component.mjs +3 -3
- package/esm2022/lib/components/query-error/components/query-error/query-error.component.mjs +3 -3
- package/esm2022/lib/components/query-error/directives/query-error/query-error.directive.mjs +3 -3
- package/esm2022/lib/components/scrollable/components/scrollable/scrollable.component.mjs +3 -3
- package/esm2022/lib/components/scrollable/components/scrollable-placeholder/scrollable-placeholder.component.mjs +3 -3
- package/esm2022/lib/components/scrollable/directives/scrollable-ignore-child/scrollable-ignore-child.directive.mjs +3 -3
- package/esm2022/lib/components/scrollable/directives/scrollable-is-active-child/scrollable-is-active-child.directive.mjs +3 -3
- package/esm2022/lib/components/scrollable/directives/scrollable-loading-template/scrollable-loading-template.directive.mjs +3 -3
- package/esm2022/lib/components/scrollable/directives/scrollable-placeholder-item-template/scrollable-placeholder-item-template.directive.mjs +3 -3
- package/esm2022/lib/components/scrollable/directives/scrollable-placeholder-overlay-template/scrollable-placeholder-overlay-template.directive.mjs +3 -3
- package/esm2022/lib/components/skeleton/components/skeleton/skeleton.component.mjs +3 -3
- package/esm2022/lib/components/skeleton/partials/skeleton-item/skeleton-item.component.mjs +3 -3
- package/esm2022/lib/components/sort/components/sort-header/sort-header.component.mjs +3 -3
- package/esm2022/lib/components/sort/partials/sort/sort.directive.mjs +3 -3
- package/esm2022/lib/components/sort/services/sort-header-intl.mjs +3 -3
- package/esm2022/lib/components/table/components/table/table.component.mjs +3 -3
- package/esm2022/lib/components/table/partials/cells/cell/cell.directive.mjs +3 -3
- package/esm2022/lib/components/table/partials/cells/cell-def/cell-def.directive.mjs +3 -3
- package/esm2022/lib/components/table/partials/cells/column-def/column-def.directive.mjs +3 -3
- package/esm2022/lib/components/table/partials/cells/footer-cell/footer-cell.directive.mjs +3 -3
- package/esm2022/lib/components/table/partials/cells/footer-cell-def/footer-cell-def.directive.mjs +3 -3
- package/esm2022/lib/components/table/partials/cells/header-cell/header-cell.directive.mjs +3 -3
- package/esm2022/lib/components/table/partials/cells/header-cell-def/header-cell-def.directive.mjs +3 -3
- package/esm2022/lib/components/table/partials/cells/text-column/text-column.component.mjs +3 -3
- package/esm2022/lib/components/table/partials/rows/footer-row/footer-row.component.mjs +3 -3
- package/esm2022/lib/components/table/partials/rows/footer-row-def/footer-row-def.directive.mjs +3 -3
- package/esm2022/lib/components/table/partials/rows/header-row/header-row.component.mjs +3 -3
- package/esm2022/lib/components/table/partials/rows/header-row-def/header-row-def.directive.mjs +3 -3
- package/esm2022/lib/components/table/partials/rows/no-data-row/no-data-row.directive.mjs +3 -3
- package/esm2022/lib/components/table/partials/rows/recycle-rows/recycle-rows.directive.mjs +3 -3
- package/esm2022/lib/components/table/partials/rows/row/row.component.mjs +3 -3
- package/esm2022/lib/components/table/partials/rows/row-def/row-def.directive.mjs +3 -3
- package/esm2022/lib/components/table/partials/table-busy/table-busy.directive.mjs +3 -3
- package/esm2022/lib/components/table/partials/table-busy-outlet/table-busy-outlet.directive.mjs +3 -3
- package/esm2022/lib/components/tabs/components/inline-tabs/inline-tabs.component.mjs +3 -3
- package/esm2022/lib/components/tabs/components/nav-tabs/nav-tabs.component.mjs +3 -3
- package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab/inline-tab.component.mjs +3 -3
- package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-body/inline-tab-body.component.mjs +3 -3
- package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-body-host/inline-tab-body-host.directive.mjs +3 -3
- package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-content/inline-tab-content.directive.mjs +3 -3
- package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-header/inline-tab-header.component.mjs +3 -3
- package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-label/inline-tab-label.directive.mjs +3 -3
- package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-label-wrapper/inline-tab-label-wrapper.directive.mjs +3 -3
- package/esm2022/lib/components/tabs/partials/nav-tabs/nav-tab-link/nav-tab-link.directive.mjs +3 -3
- package/esm2022/lib/components/tabs/partials/nav-tabs/nav-tabs-outlet/nav-tabs-outlet.component.mjs +3 -3
- package/esm2022/lib/components/tabs/utils/active-tab-underline.util.mjs +3 -3
- package/esm2022/lib/components/tabs/utils/paginated-tab-header.directive.mjs +3 -3
- package/esm2022/lib/services/swipe-handler.service.mjs +3 -3
- package/fesm2022/ethlete-cdk.mjs +1209 -937
- package/fesm2022/ethlete-cdk.mjs.map +1 -1
- package/lib/components/bracket/components/new-bracket/bracket-new.d.ts +69 -3
- package/lib/components/bracket/components/new-bracket/draw-man.d.ts +14 -2
- package/lib/components/bracket/components/new-bracket/grid-placements.d.ts +3 -0
- package/lib/components/bracket/components/new-bracket/new-bracket.component.d.ts +10 -3
- package/package.json +1 -1
|
@@ -1,66 +1,154 @@
|
|
|
1
|
-
|
|
2
|
-
const path = (d) => `<path d="${d}" stroke="
|
|
3
|
-
|
|
4
|
-
const
|
|
1
|
+
import { BRACKET_ROUND_MIRROR_TYPE, DOUBLE_ELIMINATION_BRACKET_ROUND_TYPE, FIRST_ROUNDS_TYPE, } from './bracket-new';
|
|
2
|
+
const path = (d, options) => `<path d="${d}" stroke="currentColor" fill="none" stroke-width="${options.width}" stroke-dasharray="${options.dashArray}" stroke-dashoffset="${options.dashOffset}" />`;
|
|
3
|
+
const curve = (from, to, direction, options) => {
|
|
4
|
+
const fromInline = from.inline.end;
|
|
5
|
+
const fromBlock = from.block.center;
|
|
6
|
+
const toInline = to.inline.start;
|
|
7
|
+
const toBlock = to.block.center;
|
|
8
|
+
const curveAmount = options.curveAmount;
|
|
9
|
+
const totalSpace = toInline - fromInline;
|
|
10
|
+
const totalSpaceMinusCurve = totalSpace - curveAmount * 2;
|
|
11
|
+
const lineLength = totalSpaceMinusCurve / 2;
|
|
12
|
+
const straightLeftEnd = fromInline + lineLength;
|
|
13
|
+
const straightRightStart = toInline - lineLength;
|
|
14
|
+
// first 90 degree curve down
|
|
15
|
+
const firstCurveStartX = straightLeftEnd;
|
|
16
|
+
const firstCurveEndX = straightLeftEnd + curveAmount;
|
|
17
|
+
const firstCurveEndY = direction === 'down' ? fromBlock + curveAmount : fromBlock - curveAmount;
|
|
18
|
+
const firstCurveBezierX = straightLeftEnd + curveAmount;
|
|
19
|
+
const firstCurveBezierY = fromBlock;
|
|
20
|
+
// second 90 degree curve to the right
|
|
21
|
+
const secondCurveStartY = direction === 'down' ? toBlock - curveAmount : toBlock + curveAmount;
|
|
22
|
+
const secondCurveEndX = straightRightStart;
|
|
23
|
+
const secondCurveEndY = toBlock;
|
|
24
|
+
const secondCurveBezierX = straightRightStart - curveAmount;
|
|
25
|
+
const secondCurveBezierY = toBlock;
|
|
26
|
+
const pathStr = `
|
|
27
|
+
M ${fromInline} ${fromBlock}
|
|
28
|
+
H ${firstCurveStartX}
|
|
29
|
+
Q ${firstCurveBezierX} ${firstCurveBezierY}, ${firstCurveEndX} ${firstCurveEndY}
|
|
30
|
+
V ${secondCurveStartY}
|
|
31
|
+
Q ${secondCurveBezierX} ${secondCurveBezierY}, ${secondCurveEndX} ${secondCurveEndY}
|
|
32
|
+
H ${toInline}
|
|
33
|
+
`.replace(/\s+/g, ' ');
|
|
34
|
+
return path(pathStr, options.path);
|
|
35
|
+
};
|
|
36
|
+
const line = (from, to, options) => {
|
|
37
|
+
return path(`M ${from.inline.end} ${from.block.center} L ${to.inline.start} ${to.block.center}`, options.path);
|
|
38
|
+
};
|
|
39
|
+
const getMatchPosition = (roundItem, matchId, staticMeasurements) => {
|
|
40
|
+
if (!roundItem)
|
|
41
|
+
throw new Error('Item is missing');
|
|
42
|
+
if (!matchId)
|
|
43
|
+
throw new Error('Match is missing');
|
|
44
|
+
const match = roundItem.items.get(matchId);
|
|
45
|
+
if (!match || match.type !== 'match')
|
|
46
|
+
throw new Error('Match is missing');
|
|
47
|
+
const matchHalf = staticMeasurements.matchHeight / 2;
|
|
48
|
+
const roundFactor = staticMeasurements.baseRoundMatchCount / roundItem.roundRelation.currentRound.matchCount;
|
|
49
|
+
const remainingRowGapCount = roundItem.roundRelation.currentRound.matchCount - 1;
|
|
50
|
+
const matchIncludedRowGapTotal = staticMeasurements.baseRoundMatchCount - 1 - remainingRowGapCount;
|
|
51
|
+
const matchIncludedRowGapPerMatch = matchIncludedRowGapTotal / roundItem.roundRelation.currentRound.matchCount;
|
|
52
|
+
const matchRoundItemHeight = staticMeasurements.matchHeight * roundFactor + matchIncludedRowGapPerMatch * staticMeasurements.rowGap;
|
|
53
|
+
const matchesAbove = match.matchRelation.currentMatch.indexInRound;
|
|
54
|
+
const rowOffset = matchesAbove * staticMeasurements.rowGap + matchesAbove * matchRoundItemHeight;
|
|
55
|
+
const matchRowOffset = (matchRoundItemHeight - staticMeasurements.matchHeight) / 2;
|
|
56
|
+
const blockStart = rowOffset + matchRowOffset + staticMeasurements.baseOffsetY + staticMeasurements.doubleEliminationMergeOffset;
|
|
57
|
+
const block = {
|
|
58
|
+
start: blockStart,
|
|
59
|
+
end: blockStart + staticMeasurements.matchHeight,
|
|
60
|
+
center: blockStart + matchHalf,
|
|
61
|
+
};
|
|
62
|
+
const inlineStart = (roundItem.columnStart - 1) * staticMeasurements.columnWidth +
|
|
63
|
+
(roundItem.columnStart - 1) * staticMeasurements.columnGap;
|
|
64
|
+
const inline = {
|
|
65
|
+
start: inlineStart,
|
|
66
|
+
end: inlineStart + staticMeasurements.columnWidth,
|
|
67
|
+
center: inlineStart + staticMeasurements.columnWidth / 2,
|
|
68
|
+
};
|
|
69
|
+
return { inline, block };
|
|
70
|
+
};
|
|
71
|
+
export const drawMan = (items, firstRounds, dimensions) => {
|
|
72
|
+
const { columnWidth, matchHeight, rowGap, columnGap, roundHeaderHeight } = dimensions;
|
|
5
73
|
const roundHeaderRowGap = roundHeaderHeight ? rowGap : 0;
|
|
6
74
|
const baseOffsetY = roundHeaderHeight + roundHeaderRowGap;
|
|
7
|
-
const columnGapCenter = columnGap / 2;
|
|
8
|
-
const totalHeight = (gridDefinitions.rowCount - 1) * matchHeight + (gridDefinitions.rowCount - 1) * rowGap + roundHeaderHeight; // TODO: This is not correct in double elimination
|
|
9
75
|
const svgParts = [];
|
|
10
|
-
// a nothing to one draws nothing
|
|
11
|
-
// a one to nothing draws nothing
|
|
12
|
-
// a one to one draws a line
|
|
13
|
-
// a one to two draws a line that splits into in the middle
|
|
14
|
-
// a two to one draws two lines that merge into one in the middle
|
|
15
|
-
// WE ONLY EVER DRAW THE LEFT SIDE (on-to, nothing-to, two-to)
|
|
16
76
|
for (const round of items.values()) {
|
|
17
|
-
const rows = round.roundRelation.currentRound.matchCount;
|
|
18
|
-
const rowGaps = rows - 1;
|
|
19
|
-
const rowHeight = (totalHeight - baseOffsetY) / rows - rowGaps * rowGap;
|
|
20
|
-
const rowWhitespace = (rowHeight - matchHeight) / 2;
|
|
21
|
-
const matchHeightOffset = rowWhitespace + matchHeight / 2; // the vertical middle of a match in this row
|
|
22
77
|
for (const item of round.items.values()) {
|
|
23
78
|
if (item.type === 'round')
|
|
24
79
|
continue; // we don't draw lines for round headers
|
|
80
|
+
let baseRoundMatchCount = null;
|
|
81
|
+
let doubleEliminationMergeOffset = 0;
|
|
82
|
+
if (firstRounds.type === FIRST_ROUNDS_TYPE.SINGLE) {
|
|
83
|
+
baseRoundMatchCount = firstRounds.first.matchCount;
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
if (item.roundRelation.currentRound.type === DOUBLE_ELIMINATION_BRACKET_ROUND_TYPE.UPPER_BRACKET) {
|
|
87
|
+
baseRoundMatchCount = firstRounds.upper.matchCount;
|
|
88
|
+
}
|
|
89
|
+
else if (item.roundRelation.currentRound.type === DOUBLE_ELIMINATION_BRACKET_ROUND_TYPE.LOWER_BRACKET) {
|
|
90
|
+
baseRoundMatchCount = firstRounds.lower.matchCount;
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
baseRoundMatchCount = firstRounds.upper.matchCount + firstRounds.lower.matchCount;
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
if (item.roundRelation.currentRound.type === DOUBLE_ELIMINATION_BRACKET_ROUND_TYPE.LOWER_BRACKET) {
|
|
97
|
+
doubleEliminationMergeOffset = roundHeaderHeight + roundHeaderRowGap;
|
|
98
|
+
// TODO:
|
|
99
|
+
// baseOffsetY = baseOffsetY * 2 (2 round headers and gaps) + (firstRounds.upper.matchCount * matchHeight) + (firstRounds.upper.matchCount - 1 * rowGap)
|
|
100
|
+
// baseOffsetY
|
|
101
|
+
}
|
|
102
|
+
const staticMeasurements = {
|
|
103
|
+
baseOffsetY,
|
|
104
|
+
baseRoundMatchCount,
|
|
105
|
+
columnGap,
|
|
106
|
+
columnWidth,
|
|
107
|
+
doubleEliminationMergeOffset,
|
|
108
|
+
matchHeight,
|
|
109
|
+
rowGap,
|
|
110
|
+
};
|
|
111
|
+
// TODO: No lines for now
|
|
112
|
+
if (item.matchRelation.currentRound.mirrorRoundType === BRACKET_ROUND_MIRROR_TYPE.RIGHT) {
|
|
113
|
+
continue;
|
|
114
|
+
}
|
|
115
|
+
// We only draw the left side of the match relation
|
|
25
116
|
switch (item.matchRelation.type) {
|
|
26
117
|
case 'nothing-to-one': {
|
|
27
118
|
continue;
|
|
28
119
|
}
|
|
29
120
|
case 'one-to-nothing':
|
|
30
121
|
case 'one-to-one': {
|
|
122
|
+
const previous = getMatchPosition(items.get(item.matchRelation.previousRound.id), item.matchRelation.previousMatch.id, staticMeasurements);
|
|
123
|
+
const current = getMatchPosition(round, item.matchRelation.currentMatch.id, staticMeasurements);
|
|
31
124
|
// draw a straight line
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
const
|
|
39
|
-
const
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
const fromX = previousRound.columnStart * columnWidth + (round.columnStart - 2) * columnGap;
|
|
44
|
-
const toX = (round.columnStart - 1) * columnWidth + (round.columnStart - 1) * columnGap;
|
|
45
|
-
const fromY = previousMatch.matchRelation.currentMatch.indexInRound * previousRoundRowWhitespace +
|
|
46
|
-
previousMatch.matchRelation.currentMatch.indexInRound * rowGap +
|
|
47
|
-
baseOffsetY +
|
|
48
|
-
previousRoundMatchHeightOffset;
|
|
49
|
-
const toY = item.matchRelation.currentMatch.indexInRound * rowWhitespace +
|
|
50
|
-
item.matchRelation.currentMatch.indexInRound * rowGap +
|
|
51
|
-
baseOffsetY +
|
|
52
|
-
matchHeightOffset;
|
|
53
|
-
svgParts.push(path(`M ${fromX} ${fromY} L ${toX} ${toY}`));
|
|
125
|
+
svgParts.push(line(previous, current, { path: dimensions.path }));
|
|
126
|
+
break;
|
|
127
|
+
}
|
|
128
|
+
case 'one-to-two': {
|
|
129
|
+
const nextUpper = getMatchPosition(items.get(item.matchRelation.nextUpperRound.id), item.matchRelation.nextUpperMatch.id, staticMeasurements);
|
|
130
|
+
const nextLower = getMatchPosition(items.get(item.matchRelation.nextLowerRound.id), item.matchRelation.nextLowerMatch.id, staticMeasurements);
|
|
131
|
+
const current = getMatchPosition(round, item.matchRelation.currentMatch.id, staticMeasurements);
|
|
132
|
+
// const curveOptions: CurveOptions = { ...dimensions.curve, path: dimensions.path };
|
|
133
|
+
// // draw two lines that merge into one in the middle
|
|
134
|
+
// svgParts.push(curve(nextUpper, current, 'down', curveOptions));
|
|
135
|
+
// svgParts.push(curve(nextLower, current, 'up', curveOptions));
|
|
54
136
|
break;
|
|
55
137
|
}
|
|
56
138
|
case 'two-to-nothing':
|
|
57
139
|
case 'two-to-one': {
|
|
140
|
+
const previousUpper = getMatchPosition(items.get(item.matchRelation.previousUpperRound.id), item.matchRelation.previousUpperMatch.id, staticMeasurements);
|
|
141
|
+
const previousLower = getMatchPosition(items.get(item.matchRelation.previousLowerRound.id), item.matchRelation.previousLowerMatch.id, staticMeasurements);
|
|
142
|
+
const current = getMatchPosition(round, item.matchRelation.currentMatch.id, staticMeasurements);
|
|
143
|
+
const curveOptions = { ...dimensions.curve, path: dimensions.path };
|
|
58
144
|
// draw two lines that merge into one in the middle
|
|
145
|
+
svgParts.push(curve(previousUpper, current, 'down', curveOptions));
|
|
146
|
+
svgParts.push(curve(previousLower, current, 'up', curveOptions));
|
|
59
147
|
break;
|
|
60
148
|
}
|
|
61
149
|
}
|
|
62
150
|
}
|
|
63
151
|
}
|
|
64
|
-
return svgParts.join('
|
|
152
|
+
return svgParts.join('');
|
|
65
153
|
};
|
|
66
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"draw-man.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/bracket/components/new-bracket/draw-man.ts"],"names":[],"mappings":"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","sourcesContent":["import { BracketRoundId, BracketRoundRelations } from './bracket-new';\nimport { BracketGridDefinitions } from './grid-definitions';\nimport { BracketGridRoundItem } from './grid-placements';\n\nexport type DrawManDimensions = {\n  columnWidth: number;\n  matchHeight: number;\n  roundHeaderHeight: number;\n  columnGap: number;\n  rowGap: number;\n  gridDefinitions: BracketGridDefinitions;\n};\n\nconst LINE_WIDTH = 1;\n\nconst path = (d: string) => `<path d=\"${d}\" stroke=\"red\" fill=\"none\" stroke-width=\"${LINE_WIDTH}\" />`;\n\nexport const drawMan = <TRoundData, TMatchData>(\n  items: Map<BracketRoundId, BracketGridRoundItem<TRoundData, TMatchData>>,\n  roundRelations: BracketRoundRelations<TRoundData, TMatchData>,\n  dimensions: DrawManDimensions,\n) => {\n  const { columnWidth, matchHeight, rowGap, columnGap, roundHeaderHeight, gridDefinitions } = dimensions;\n  const roundHeaderRowGap = roundHeaderHeight ? rowGap : 0;\n  const baseOffsetY = roundHeaderHeight + roundHeaderRowGap;\n\n  const columnGapCenter = columnGap / 2;\n  const totalHeight =\n    (gridDefinitions.rowCount - 1) * matchHeight + (gridDefinitions.rowCount - 1) * rowGap + roundHeaderHeight; // TODO: This is not correct in double elimination\n  const svgParts: string[] = [];\n\n  // a nothing to one draws nothing\n  // a one to nothing draws nothing\n  // a one to one draws a line\n  // a one to two draws a line that splits into in the middle\n  // a two to one draws two lines that merge into one in the middle\n\n  // WE ONLY EVER DRAW THE LEFT SIDE (on-to, nothing-to, two-to)\n\n  for (const round of items.values()) {\n    const rows = round.roundRelation.currentRound.matchCount;\n    const rowGaps = rows - 1;\n    const rowHeight = (totalHeight - baseOffsetY) / rows - rowGaps * rowGap;\n    const rowWhitespace = (rowHeight - matchHeight) / 2;\n    const matchHeightOffset = rowWhitespace + matchHeight / 2; // the vertical middle of a match in this row\n\n    for (const item of round.items.values()) {\n      if (item.type === 'round') continue; // we don't draw lines for round headers\n\n      switch (item.matchRelation.type) {\n        case 'nothing-to-one': {\n          continue;\n        }\n        case 'one-to-nothing':\n        case 'one-to-one': {\n          // draw a straight line\n          const previousRound = items.get(item.matchRelation.previousRound.id);\n          if (!previousRound) throw new Error('Previous round or match is missing');\n          const previousMatch = previousRound.items.get(item.matchRelation.previousMatch.id);\n          if (!previousMatch || previousMatch.type !== 'match') throw new Error('Previous round or match is missing');\n\n          const previousRoundRows = previousRound.roundRelation.currentRound.matchCount;\n          const previousRoundRowGaps = previousRoundRows - 1;\n\n          const previousRoundRowHeight =\n            (totalHeight - baseOffsetY) / previousRoundRows - previousRoundRowGaps * rowGap;\n\n          const previousRoundRowWhitespace = (previousRoundRowHeight - matchHeight) / 2;\n          const previousRoundMatchHeightOffset = previousRoundRowWhitespace + matchHeight / 2;\n\n          const fromX = previousRound.columnStart * columnWidth + (round.columnStart - 2) * columnGap;\n          const toX = (round.columnStart - 1) * columnWidth + (round.columnStart - 1) * columnGap;\n\n          const fromY =\n            previousMatch.matchRelation.currentMatch.indexInRound * previousRoundRowWhitespace +\n            previousMatch.matchRelation.currentMatch.indexInRound * rowGap +\n            baseOffsetY +\n            previousRoundMatchHeightOffset;\n          const toY =\n            item.matchRelation.currentMatch.indexInRound * rowWhitespace +\n            item.matchRelation.currentMatch.indexInRound * rowGap +\n            baseOffsetY +\n            matchHeightOffset;\n\n          svgParts.push(path(`M ${fromX} ${fromY} L ${toX} ${toY}`));\n\n          break;\n        }\n        case 'two-to-nothing':\n        case 'two-to-one': {\n          // draw two lines that merge into one in the middle\n\n          break;\n        }\n      }\n    }\n  }\n\n  return svgParts.join(' /n');\n};\n"]}
|
|
154
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"draw-man.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/bracket/components/new-bracket/draw-man.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BRACKET_ROUND_MIRROR_TYPE,\n  BracketMatchId,\n  BracketRoundId,\n  DOUBLE_ELIMINATION_BRACKET_ROUND_TYPE,\n  FIRST_ROUNDS_TYPE,\n  FirstRounds,\n} from './bracket-new';\nimport { BracketGridDefinitions } from './grid-definitions';\nimport { BracketGridRoundItem } from './grid-placements';\n\nexport type DrawManDimensions = {\n  columnWidth: number;\n  matchHeight: number;\n  roundHeaderHeight: number;\n  columnGap: number;\n  rowGap: number;\n  gridDefinitions: BracketGridDefinitions;\n  path: PathOptions;\n  curve: Omit<CurveOptions, 'path'>;\n};\n\ntype PathOptions = {\n  width: number;\n  dashArray: number;\n  dashOffset: number;\n};\n\nconst path = (d: string, options: PathOptions) =>\n  `<path d=\"${d}\" stroke=\"currentColor\" fill=\"none\" stroke-width=\"${options.width}\" stroke-dasharray=\"${options.dashArray}\" stroke-dashoffset=\"${options.dashOffset}\" />`;\n\ntype CurveOptions = {\n  curveAmount: number;\n  path: PathOptions;\n};\n\nconst curve = (from: BracketPosition, to: BracketPosition, direction: 'up' | 'down', options: CurveOptions) => {\n  const fromInline = from.inline.end;\n  const fromBlock = from.block.center;\n\n  const toInline = to.inline.start;\n  const toBlock = to.block.center;\n\n  const curveAmount = options.curveAmount;\n\n  const totalSpace = toInline - fromInline;\n  const totalSpaceMinusCurve = totalSpace - curveAmount * 2;\n  const lineLength = totalSpaceMinusCurve / 2;\n\n  const straightLeftEnd = fromInline + lineLength;\n  const straightRightStart = toInline - lineLength;\n\n  // first 90 degree curve down\n  const firstCurveStartX = straightLeftEnd;\n  const firstCurveEndX = straightLeftEnd + curveAmount;\n  const firstCurveEndY = direction === 'down' ? fromBlock + curveAmount : fromBlock - curveAmount;\n\n  const firstCurveBezierX = straightLeftEnd + curveAmount;\n  const firstCurveBezierY = fromBlock;\n\n  // second 90 degree curve to the right\n  const secondCurveStartY = direction === 'down' ? toBlock - curveAmount : toBlock + curveAmount;\n  const secondCurveEndX = straightRightStart;\n  const secondCurveEndY = toBlock;\n\n  const secondCurveBezierX = straightRightStart - curveAmount;\n  const secondCurveBezierY = toBlock;\n\n  const pathStr = `\n    M ${fromInline} ${fromBlock} \n    H ${firstCurveStartX} \n    Q ${firstCurveBezierX} ${firstCurveBezierY}, ${firstCurveEndX} ${firstCurveEndY} \n    V ${secondCurveStartY} \n    Q ${secondCurveBezierX} ${secondCurveBezierY}, ${secondCurveEndX} ${secondCurveEndY} \n    H ${toInline}\n  `.replace(/\\s+/g, ' ');\n\n  return path(pathStr, options.path);\n};\n\ntype LineOptions = {\n  path: PathOptions;\n};\n\nconst line = (from: BracketPosition, to: BracketPosition, options: LineOptions) => {\n  return path(`M ${from.inline.end} ${from.block.center} L ${to.inline.start} ${to.block.center}`, options.path);\n};\n\ntype StaticMeasurements = {\n  /** Width of one column */\n  columnWidth: number;\n\n  /** Height of one match */\n  matchHeight: number;\n\n  /** Gap between rows */\n  rowGap: number;\n\n  /** Gap between columns */\n  columnGap: number;\n\n  /**\n   * Offset from the top.\n   * Will be 0 if e.g. there is no round header and we are displaying a single elimination bracket.\n   * Will be some value if there is a round header or if we want to display the lower bracket of a double elimination bracket.\n   */\n  baseOffsetY: number;\n\n  /**\n   * The number of matches in the first round.\n   * For double elimination brackets, this is the number of matches in the upper bracket or the lower bracket.\n   * For double elimination matches after the upper and lower bracket have been merged, this is the sum of matches in the first round of the upper and lower bracket.\n   */\n  baseRoundMatchCount: number;\n\n  /**\n   * Will be round header height + row gap if we are merging the upper and lower bracket of a double elimination bracket, 0 otherwise.\n   * This value will be added to the available whitespace for the match to be displayed in the middle of.\n   */\n  doubleEliminationMergeOffset: number;\n};\n\ntype BracketPosition = {\n  inline: { start: number; end: number; center: number }; // the left, right and center of the match\n  block: { start: number; end: number; center: number }; // the top, bottom and center of the match\n};\n\nconst getMatchPosition = <TRoundData, TMatchData>(\n  roundItem: BracketGridRoundItem<TRoundData, TMatchData> | undefined,\n  matchId: BracketMatchId | undefined,\n  staticMeasurements: StaticMeasurements,\n): BracketPosition => {\n  if (!roundItem) throw new Error('Item is missing');\n  if (!matchId) throw new Error('Match is missing');\n\n  const match = roundItem.items.get(matchId);\n\n  if (!match || match.type !== 'match') throw new Error('Match is missing');\n\n  const matchHalf = staticMeasurements.matchHeight / 2;\n\n  const roundFactor = staticMeasurements.baseRoundMatchCount / roundItem.roundRelation.currentRound.matchCount;\n  const remainingRowGapCount = roundItem.roundRelation.currentRound.matchCount - 1;\n  const matchIncludedRowGapTotal = staticMeasurements.baseRoundMatchCount - 1 - remainingRowGapCount;\n  const matchIncludedRowGapPerMatch = matchIncludedRowGapTotal / roundItem.roundRelation.currentRound.matchCount;\n  const matchRoundItemHeight =\n    staticMeasurements.matchHeight * roundFactor + matchIncludedRowGapPerMatch * staticMeasurements.rowGap;\n\n  const matchesAbove = match.matchRelation.currentMatch.indexInRound;\n  const rowOffset = matchesAbove * staticMeasurements.rowGap + matchesAbove * matchRoundItemHeight;\n\n  const matchRowOffset = (matchRoundItemHeight - staticMeasurements.matchHeight) / 2;\n\n  const blockStart =\n    rowOffset + matchRowOffset + staticMeasurements.baseOffsetY + staticMeasurements.doubleEliminationMergeOffset;\n\n  const block = {\n    start: blockStart,\n    end: blockStart + staticMeasurements.matchHeight,\n    center: blockStart + matchHalf,\n  };\n\n  const inlineStart =\n    (roundItem.columnStart - 1) * staticMeasurements.columnWidth +\n    (roundItem.columnStart - 1) * staticMeasurements.columnGap;\n\n  const inline = {\n    start: inlineStart,\n    end: inlineStart + staticMeasurements.columnWidth,\n    center: inlineStart + staticMeasurements.columnWidth / 2,\n  };\n\n  return { inline, block };\n};\n\nexport const drawMan = <TRoundData, TMatchData>(\n  items: Map<BracketRoundId, BracketGridRoundItem<TRoundData, TMatchData>>,\n  firstRounds: FirstRounds<TRoundData, TMatchData>,\n  dimensions: DrawManDimensions,\n) => {\n  const { columnWidth, matchHeight, rowGap, columnGap, roundHeaderHeight } = dimensions;\n  const roundHeaderRowGap = roundHeaderHeight ? rowGap : 0;\n  const baseOffsetY = roundHeaderHeight + roundHeaderRowGap;\n\n  const svgParts: string[] = [];\n\n  for (const round of items.values()) {\n    for (const item of round.items.values()) {\n      if (item.type === 'round') continue; // we don't draw lines for round headers\n\n      let baseRoundMatchCount: number | null = null;\n      let doubleEliminationMergeOffset = 0;\n\n      if (firstRounds.type === FIRST_ROUNDS_TYPE.SINGLE) {\n        baseRoundMatchCount = firstRounds.first.matchCount;\n      } else {\n        if (item.roundRelation.currentRound.type === DOUBLE_ELIMINATION_BRACKET_ROUND_TYPE.UPPER_BRACKET) {\n          baseRoundMatchCount = firstRounds.upper.matchCount;\n        } else if (item.roundRelation.currentRound.type === DOUBLE_ELIMINATION_BRACKET_ROUND_TYPE.LOWER_BRACKET) {\n          baseRoundMatchCount = firstRounds.lower.matchCount;\n        } else {\n          baseRoundMatchCount = firstRounds.upper.matchCount + firstRounds.lower.matchCount;\n        }\n      }\n\n      if (item.roundRelation.currentRound.type === DOUBLE_ELIMINATION_BRACKET_ROUND_TYPE.LOWER_BRACKET) {\n        doubleEliminationMergeOffset = roundHeaderHeight + roundHeaderRowGap;\n        // TODO:\n        // baseOffsetY = baseOffsetY * 2 (2 round headers and gaps) + (firstRounds.upper.matchCount * matchHeight) + (firstRounds.upper.matchCount - 1 * rowGap)\n        // baseOffsetY\n      }\n\n      const staticMeasurements: StaticMeasurements = {\n        baseOffsetY,\n        baseRoundMatchCount,\n        columnGap,\n        columnWidth,\n        doubleEliminationMergeOffset,\n        matchHeight,\n        rowGap,\n      };\n\n      // TODO: No lines for now\n      if (item.matchRelation.currentRound.mirrorRoundType === BRACKET_ROUND_MIRROR_TYPE.RIGHT) {\n        continue;\n      }\n\n      // We only draw the left side of the match relation\n      switch (item.matchRelation.type) {\n        case 'nothing-to-one': {\n          continue;\n        }\n        case 'one-to-nothing':\n        case 'one-to-one': {\n          const previous = getMatchPosition(\n            items.get(item.matchRelation.previousRound.id),\n            item.matchRelation.previousMatch.id,\n            staticMeasurements,\n          );\n          const current = getMatchPosition(round, item.matchRelation.currentMatch.id, staticMeasurements);\n\n          // draw a straight line\n          svgParts.push(line(previous, current, { path: dimensions.path }));\n\n          break;\n        }\n        case 'one-to-two': {\n          const nextUpper = getMatchPosition(\n            items.get(item.matchRelation.nextUpperRound.id),\n            item.matchRelation.nextUpperMatch.id,\n            staticMeasurements,\n          );\n\n          const nextLower = getMatchPosition(\n            items.get(item.matchRelation.nextLowerRound.id),\n            item.matchRelation.nextLowerMatch.id,\n            staticMeasurements,\n          );\n\n          const current = getMatchPosition(round, item.matchRelation.currentMatch.id, staticMeasurements);\n\n          // const curveOptions: CurveOptions = { ...dimensions.curve, path: dimensions.path };\n\n          // // draw two lines that merge into one in the middle\n          // svgParts.push(curve(nextUpper, current, 'down', curveOptions));\n          // svgParts.push(curve(nextLower, current, 'up', curveOptions));\n\n          break;\n        }\n        case 'two-to-nothing':\n        case 'two-to-one': {\n          const previousUpper = getMatchPosition(\n            items.get(item.matchRelation.previousUpperRound.id),\n            item.matchRelation.previousUpperMatch.id,\n            staticMeasurements,\n          );\n\n          const previousLower = getMatchPosition(\n            items.get(item.matchRelation.previousLowerRound.id),\n            item.matchRelation.previousLowerMatch.id,\n            staticMeasurements,\n          );\n\n          const current = getMatchPosition(round, item.matchRelation.currentMatch.id, staticMeasurements);\n          const curveOptions: CurveOptions = { ...dimensions.curve, path: dimensions.path };\n\n          // draw two lines that merge into one in the middle\n          svgParts.push(curve(previousUpper, current, 'down', curveOptions));\n          svgParts.push(curve(previousLower, current, 'up', curveOptions));\n          break;\n        }\n      }\n    }\n  }\n\n  return svgParts.join('');\n};\n"]}
|
|
@@ -40,6 +40,7 @@ const generateGenericGridPlacements = (bracketData, roundTypeMap, roundRelations
|
|
|
40
40
|
}
|
|
41
41
|
const roundItem = {
|
|
42
42
|
id: round.id,
|
|
43
|
+
layoutId: `${round.id}-layout`,
|
|
43
44
|
columnStart,
|
|
44
45
|
columnEnd,
|
|
45
46
|
roundRelation,
|
|
@@ -49,6 +50,7 @@ const generateGenericGridPlacements = (bracketData, roundTypeMap, roundRelations
|
|
|
49
50
|
const roundHeaderItem = {
|
|
50
51
|
type: 'round',
|
|
51
52
|
id: round.id,
|
|
53
|
+
layoutId: `${round.id}-layout`,
|
|
52
54
|
rowStart: currentMatchRow,
|
|
53
55
|
rowEnd: ++currentMatchRow,
|
|
54
56
|
component: options.headerComponent,
|
|
@@ -70,6 +72,7 @@ const generateGenericGridPlacements = (bracketData, roundTypeMap, roundRelations
|
|
|
70
72
|
const matchItem = {
|
|
71
73
|
type: 'match',
|
|
72
74
|
id: match.id,
|
|
75
|
+
layoutId: `${match.id}-layout`,
|
|
73
76
|
rowStart: baseRow + currentMatchRow,
|
|
74
77
|
rowEnd: baseRow + currentMatchRow + matchHeight,
|
|
75
78
|
component: options.matchComponent,
|
|
@@ -94,4 +97,4 @@ const generateSwissWithEliminationGridPlacements = (bracketData, roundTypeMap, s
|
|
|
94
97
|
const gridItems = new Map();
|
|
95
98
|
return gridItems;
|
|
96
99
|
};
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-placements.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/bracket/components/new-bracket/grid-placements.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentType } from '@angular/cdk/portal';\nimport { InputSignal } from '@angular/core';\nimport {\n  BracketData,\n  BracketMatch,\n  BracketMatchId,\n  BracketMatchRelation,\n  BracketMatchRelationsMap,\n  BracketRound,\n  BracketRoundId,\n  BracketRoundMapWithSwissData,\n  BracketRoundRelation,\n  BracketRoundRelations,\n  BracketRoundTypeMap,\n  TOURNAMENT_MODE,\n} from './bracket-new';\nimport { NewBracketDefaultMatchComponent } from './new-bracket-default-match.component';\nimport { NewBracketDefaultRoundHeaderComponent } from './new-bracket-default-round-header.component';\n\nexport type BracketRoundHeaderComponent<TRoundData, TMatchData> = ComponentType<{\n  bracketRound: InputSignal<BracketRound<TRoundData, TMatchData>>;\n}>;\n\nexport type ComponentInputValue<T> = () => {\n  [P in keyof T]: T[P] extends InputSignal<infer U> ? U : never;\n};\n\nexport type BracketMatchComponent<TRoundData, TMatchData> = ComponentType<{\n  bracketRound: InputSignal<BracketRound<TRoundData, TMatchData>>;\n  bracketMatch: InputSignal<BracketMatch<TRoundData, TMatchData>>;\n}>;\n\nexport type BracketGridRoundItem<TRoundData, TMatchData> = {\n  id: string;\n  columnStart: number;\n  columnEnd: number;\n  roundRelation: BracketRoundRelation<TRoundData, TMatchData>;\n  items: Map<BracketRoundId | BracketMatchId, BracketGridItem<TRoundData, TMatchData>>;\n};\n\nexport type BracketGridRoundHeaderItem<TRoundData, TMatchData> = {\n  type: 'round';\n  id: string;\n  rowStart: number;\n  rowEnd: number;\n  component: BracketRoundHeaderComponent<TRoundData, TMatchData>;\n  roundRelation: BracketRoundRelation<TRoundData, TMatchData>;\n  data: {\n    bracketRound: BracketRound<TRoundData, TMatchData>;\n  };\n};\n\nexport type BracketGridMatchItem<TRoundData, TMatchData> = {\n  type: 'match';\n  id: string;\n  rowStart: number;\n  rowEnd: number;\n  component: BracketMatchComponent<TRoundData, TMatchData>;\n  matchRelation: BracketMatchRelation<TRoundData, TMatchData>;\n  roundRelation: BracketRoundRelation<TRoundData, TMatchData>;\n  data: {\n    bracketRound: BracketRound<TRoundData, TMatchData>;\n    bracketMatch: BracketMatch<TRoundData, TMatchData>;\n  };\n};\n\nexport type BracketGridItem<TRoundData, TMatchData> =\n  | BracketGridRoundHeaderItem<TRoundData, TMatchData>\n  | BracketGridMatchItem<TRoundData, TMatchData>;\n\nexport type GenerateBracketGridItemsOptions<TRoundData, TMatchData> = {\n  includeRoundHeaders: boolean;\n  headerComponent?: BracketRoundHeaderComponent<TRoundData, TMatchData>;\n  matchComponent?: BracketMatchComponent<TRoundData, TMatchData>;\n};\n\nexport type GenerateBracketGridItemsOptionsWithDefaults<TRoundData, TMatchData> = {\n  includeRoundHeaders: boolean;\n  headerComponent: BracketRoundHeaderComponent<TRoundData, TMatchData>;\n  matchComponent: BracketMatchComponent<TRoundData, TMatchData>;\n};\n\nexport const generateBracketGridItems = <TRoundData, TMatchData>(\n  bracketData: BracketData<TRoundData, TMatchData>,\n  roundTypeMap: BracketRoundTypeMap<TRoundData, TMatchData>,\n  swissGroups: BracketRoundMapWithSwissData<TRoundData, TMatchData> | null,\n  roundRelations: BracketRoundRelations<TRoundData, TMatchData>,\n  matchRelations: BracketMatchRelationsMap<TRoundData, TMatchData>,\n  options: GenerateBracketGridItemsOptions<TRoundData, TMatchData>,\n) => {\n  const roundHeaderComponent = options.headerComponent ?? NewBracketDefaultRoundHeaderComponent;\n  const matchComponent = options.matchComponent ?? NewBracketDefaultMatchComponent;\n\n  const optionsWithDefaults: GenerateBracketGridItemsOptionsWithDefaults<TRoundData, TMatchData> = {\n    ...options,\n    headerComponent: roundHeaderComponent,\n    matchComponent: matchComponent,\n  };\n\n  switch (bracketData.mode) {\n    case TOURNAMENT_MODE.DOUBLE_ELIMINATION:\n      return generateDoubleEliminationGridPlacements(\n        bracketData,\n        roundTypeMap,\n        roundRelations,\n        matchRelations,\n        optionsWithDefaults,\n      );\n    case TOURNAMENT_MODE.SWISS_WITH_ELIMINATION: {\n      if (!swissGroups) throw new Error('Swiss groups are required for swiss with elimination mode');\n\n      return generateSwissWithEliminationGridPlacements(\n        bracketData,\n        roundTypeMap,\n        swissGroups,\n        roundRelations,\n        matchRelations,\n        optionsWithDefaults,\n      );\n    }\n\n    default:\n      return generateGenericGridPlacements(\n        bracketData,\n        roundTypeMap,\n        roundRelations,\n        matchRelations,\n        optionsWithDefaults,\n      );\n  }\n};\n\nconst generateGenericGridPlacements = <TRoundData, TMatchData>(\n  bracketData: BracketData<TRoundData, TMatchData>,\n  roundTypeMap: BracketRoundTypeMap<TRoundData, TMatchData>,\n  roundRelations: BracketRoundRelations<TRoundData, TMatchData>,\n  matchRelations: BracketMatchRelationsMap<TRoundData, TMatchData>,\n  options: GenerateBracketGridItemsOptionsWithDefaults<TRoundData, TMatchData>,\n) => {\n  const gridItems: Map<BracketRoundId, BracketGridRoundItem<TRoundData, TMatchData>> = new Map();\n  const firstRound = bracketData.rounds.values().next().value;\n\n  if (!firstRound) {\n    throw new Error('First round is missing');\n  }\n\n  for (const round of bracketData.rounds.values()) {\n    const roundRelation = roundRelations.get(round.id);\n\n    let currentMatchRow = 1;\n\n    const columnStart = round.index + 1;\n    const columnEnd = columnStart + 1;\n\n    if (!roundRelation) {\n      throw new Error('Round relation is missing');\n    }\n\n    if (roundRelation.type === 'two-to-nothing' || roundRelation.type === 'two-to-one') {\n      throw new Error(`Invalid relation type ${roundRelation.type}`);\n    }\n\n    const roundItem: BracketGridRoundItem<TRoundData, TMatchData> = {\n      id: round.id,\n      columnStart,\n      columnEnd,\n      roundRelation,\n      items: new Map(),\n    };\n\n    if (options.includeRoundHeaders) {\n      const roundHeaderItem: BracketGridRoundHeaderItem<TRoundData, TMatchData> = {\n        type: 'round',\n        id: round.id,\n        rowStart: currentMatchRow,\n        rowEnd: ++currentMatchRow,\n        component: options.headerComponent,\n        roundRelation,\n        data: {\n          bracketRound: round,\n        },\n      };\n\n      roundItem.items.set(round.id, roundHeaderItem);\n    }\n\n    const rootRoundMatchFactor = roundRelation.type !== 'nothing-to-one' ? roundRelation.rootRoundMatchFactor : null;\n    const matchHeight = rootRoundMatchFactor ? rootRoundMatchFactor : 1;\n\n    for (const match of round.matches.values()) {\n      const matchRelation = matchRelations.get(match.id);\n\n      if (!matchRelation) {\n        throw new Error('Match relation is missing');\n      }\n\n      const baseRow = match.indexInRound * matchHeight;\n\n      const matchItem: BracketGridMatchItem<TRoundData, TMatchData> = {\n        type: 'match',\n        id: match.id,\n        rowStart: baseRow + currentMatchRow,\n        rowEnd: baseRow + currentMatchRow + matchHeight,\n        component: options.matchComponent,\n        matchRelation,\n        roundRelation,\n        data: {\n          bracketRound: round,\n          bracketMatch: match,\n        },\n      };\n\n      roundItem.items.set(match.id, matchItem);\n    }\n\n    gridItems.set(round.id, roundItem);\n  }\n\n  return gridItems;\n};\n\nconst generateDoubleEliminationGridPlacements = <TRoundData, TMatchData>(\n  bracketData: BracketData<TRoundData, TMatchData>,\n  roundTypeMap: BracketRoundTypeMap<TRoundData, TMatchData>,\n  roundRelations: BracketRoundRelations<TRoundData, TMatchData>,\n  matchRelations: BracketMatchRelationsMap<TRoundData, TMatchData>,\n  options: GenerateBracketGridItemsOptionsWithDefaults<TRoundData, TMatchData>,\n) => {\n  const gridItems: Map<BracketRoundId, BracketGridRoundItem<TRoundData, TMatchData>> = new Map();\n\n  return gridItems;\n};\n\nconst generateSwissWithEliminationGridPlacements = <TRoundData, TMatchData>(\n  bracketData: BracketData<TRoundData, TMatchData>,\n  roundTypeMap: BracketRoundTypeMap<TRoundData, TMatchData>,\n  swissGroups: BracketRoundMapWithSwissData<TRoundData, TMatchData>,\n  roundRelations: BracketRoundRelations<TRoundData, TMatchData>,\n  matchRelations: BracketMatchRelationsMap<TRoundData, TMatchData>,\n  options: GenerateBracketGridItemsOptionsWithDefaults<TRoundData, TMatchData>,\n) => {\n  const gridItems: Map<BracketRoundId, BracketGridRoundItem<TRoundData, TMatchData>> = new Map();\n\n  return gridItems;\n};\n"]}
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-placements.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/bracket/components/new-bracket/grid-placements.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentType } from '@angular/cdk/portal';\nimport { InputSignal } from '@angular/core';\nimport {\n  BracketData,\n  BracketMatch,\n  BracketMatchId,\n  BracketMatchRelation,\n  BracketMatchRelationsMap,\n  BracketRound,\n  BracketRoundId,\n  BracketRoundMapWithSwissData,\n  BracketRoundRelation,\n  BracketRoundRelations,\n  BracketRoundTypeMap,\n  TOURNAMENT_MODE,\n} from './bracket-new';\nimport { NewBracketDefaultMatchComponent } from './new-bracket-default-match.component';\nimport { NewBracketDefaultRoundHeaderComponent } from './new-bracket-default-round-header.component';\n\nexport type BracketRoundHeaderComponent<TRoundData, TMatchData> = ComponentType<{\n  bracketRound: InputSignal<BracketRound<TRoundData, TMatchData>>;\n}>;\n\nexport type ComponentInputValue<T> = () => {\n  [P in keyof T]: T[P] extends InputSignal<infer U> ? U : never;\n};\n\nexport type BracketMatchComponent<TRoundData, TMatchData> = ComponentType<{\n  bracketRound: InputSignal<BracketRound<TRoundData, TMatchData>>;\n  bracketMatch: InputSignal<BracketMatch<TRoundData, TMatchData>>;\n}>;\n\nexport type BracketGridRoundItem<TRoundData, TMatchData> = {\n  id: string;\n  layoutId: string;\n  columnStart: number;\n  columnEnd: number;\n  roundRelation: BracketRoundRelation<TRoundData, TMatchData>;\n  items: Map<BracketRoundId | BracketMatchId, BracketGridItem<TRoundData, TMatchData>>;\n};\n\nexport type BracketGridRoundHeaderItem<TRoundData, TMatchData> = {\n  type: 'round';\n  id: string;\n  layoutId: string;\n  rowStart: number;\n  rowEnd: number;\n  component: BracketRoundHeaderComponent<TRoundData, TMatchData>;\n  roundRelation: BracketRoundRelation<TRoundData, TMatchData>;\n  data: {\n    bracketRound: BracketRound<TRoundData, TMatchData>;\n  };\n};\n\nexport type BracketGridMatchItem<TRoundData, TMatchData> = {\n  type: 'match';\n  id: string;\n  layoutId: string;\n  rowStart: number;\n  rowEnd: number;\n  component: BracketMatchComponent<TRoundData, TMatchData>;\n  matchRelation: BracketMatchRelation<TRoundData, TMatchData>;\n  roundRelation: BracketRoundRelation<TRoundData, TMatchData>;\n  data: {\n    bracketRound: BracketRound<TRoundData, TMatchData>;\n    bracketMatch: BracketMatch<TRoundData, TMatchData>;\n  };\n};\n\nexport type BracketGridItem<TRoundData, TMatchData> =\n  | BracketGridRoundHeaderItem<TRoundData, TMatchData>\n  | BracketGridMatchItem<TRoundData, TMatchData>;\n\nexport type GenerateBracketGridItemsOptions<TRoundData, TMatchData> = {\n  includeRoundHeaders: boolean;\n  headerComponent?: BracketRoundHeaderComponent<TRoundData, TMatchData>;\n  matchComponent?: BracketMatchComponent<TRoundData, TMatchData>;\n};\n\nexport type GenerateBracketGridItemsOptionsWithDefaults<TRoundData, TMatchData> = {\n  includeRoundHeaders: boolean;\n  headerComponent: BracketRoundHeaderComponent<TRoundData, TMatchData>;\n  matchComponent: BracketMatchComponent<TRoundData, TMatchData>;\n};\n\nexport const generateBracketGridItems = <TRoundData, TMatchData>(\n  bracketData: BracketData<TRoundData, TMatchData>,\n  roundTypeMap: BracketRoundTypeMap<TRoundData, TMatchData>,\n  swissGroups: BracketRoundMapWithSwissData<TRoundData, TMatchData> | null,\n  roundRelations: BracketRoundRelations<TRoundData, TMatchData>,\n  matchRelations: BracketMatchRelationsMap<TRoundData, TMatchData>,\n  options: GenerateBracketGridItemsOptions<TRoundData, TMatchData>,\n) => {\n  const roundHeaderComponent = options.headerComponent ?? NewBracketDefaultRoundHeaderComponent;\n  const matchComponent = options.matchComponent ?? NewBracketDefaultMatchComponent;\n\n  const optionsWithDefaults: GenerateBracketGridItemsOptionsWithDefaults<TRoundData, TMatchData> = {\n    ...options,\n    headerComponent: roundHeaderComponent,\n    matchComponent: matchComponent,\n  };\n\n  switch (bracketData.mode) {\n    case TOURNAMENT_MODE.DOUBLE_ELIMINATION:\n      return generateDoubleEliminationGridPlacements(\n        bracketData,\n        roundTypeMap,\n        roundRelations,\n        matchRelations,\n        optionsWithDefaults,\n      );\n    case TOURNAMENT_MODE.SWISS_WITH_ELIMINATION: {\n      if (!swissGroups) throw new Error('Swiss groups are required for swiss with elimination mode');\n\n      return generateSwissWithEliminationGridPlacements(\n        bracketData,\n        roundTypeMap,\n        swissGroups,\n        roundRelations,\n        matchRelations,\n        optionsWithDefaults,\n      );\n    }\n\n    default:\n      return generateGenericGridPlacements(\n        bracketData,\n        roundTypeMap,\n        roundRelations,\n        matchRelations,\n        optionsWithDefaults,\n      );\n  }\n};\n\nconst generateGenericGridPlacements = <TRoundData, TMatchData>(\n  bracketData: BracketData<TRoundData, TMatchData>,\n  roundTypeMap: BracketRoundTypeMap<TRoundData, TMatchData>,\n  roundRelations: BracketRoundRelations<TRoundData, TMatchData>,\n  matchRelations: BracketMatchRelationsMap<TRoundData, TMatchData>,\n  options: GenerateBracketGridItemsOptionsWithDefaults<TRoundData, TMatchData>,\n) => {\n  const gridItems: Map<BracketRoundId, BracketGridRoundItem<TRoundData, TMatchData>> = new Map();\n  const firstRound = bracketData.rounds.values().next().value;\n\n  if (!firstRound) {\n    throw new Error('First round is missing');\n  }\n\n  for (const round of bracketData.rounds.values()) {\n    const roundRelation = roundRelations.get(round.id);\n\n    let currentMatchRow = 1;\n\n    const columnStart = round.index + 1;\n    const columnEnd = columnStart + 1;\n\n    if (!roundRelation) {\n      throw new Error('Round relation is missing');\n    }\n\n    if (roundRelation.type === 'two-to-nothing' || roundRelation.type === 'two-to-one') {\n      throw new Error(`Invalid relation type ${roundRelation.type}`);\n    }\n\n    const roundItem: BracketGridRoundItem<TRoundData, TMatchData> = {\n      id: round.id,\n      layoutId: `${round.id}-layout`,\n      columnStart,\n      columnEnd,\n      roundRelation,\n      items: new Map(),\n    };\n\n    if (options.includeRoundHeaders) {\n      const roundHeaderItem: BracketGridRoundHeaderItem<TRoundData, TMatchData> = {\n        type: 'round',\n        id: round.id,\n        layoutId: `${round.id}-layout`,\n        rowStart: currentMatchRow,\n        rowEnd: ++currentMatchRow,\n        component: options.headerComponent,\n        roundRelation,\n        data: {\n          bracketRound: round,\n        },\n      };\n\n      roundItem.items.set(round.id, roundHeaderItem);\n    }\n\n    const rootRoundMatchFactor = roundRelation.type !== 'nothing-to-one' ? roundRelation.rootRoundMatchFactor : null;\n    const matchHeight = rootRoundMatchFactor ? rootRoundMatchFactor : 1;\n\n    for (const match of round.matches.values()) {\n      const matchRelation = matchRelations.get(match.id);\n\n      if (!matchRelation) {\n        throw new Error('Match relation is missing');\n      }\n\n      const baseRow = match.indexInRound * matchHeight;\n\n      const matchItem: BracketGridMatchItem<TRoundData, TMatchData> = {\n        type: 'match',\n        id: match.id,\n        layoutId: `${match.id}-layout`,\n        rowStart: baseRow + currentMatchRow,\n        rowEnd: baseRow + currentMatchRow + matchHeight,\n        component: options.matchComponent,\n        matchRelation,\n        roundRelation,\n        data: {\n          bracketRound: round,\n          bracketMatch: match,\n        },\n      };\n\n      roundItem.items.set(match.id, matchItem);\n    }\n\n    gridItems.set(round.id, roundItem);\n  }\n\n  return gridItems;\n};\n\nconst generateDoubleEliminationGridPlacements = <TRoundData, TMatchData>(\n  bracketData: BracketData<TRoundData, TMatchData>,\n  roundTypeMap: BracketRoundTypeMap<TRoundData, TMatchData>,\n  roundRelations: BracketRoundRelations<TRoundData, TMatchData>,\n  matchRelations: BracketMatchRelationsMap<TRoundData, TMatchData>,\n  options: GenerateBracketGridItemsOptionsWithDefaults<TRoundData, TMatchData>,\n) => {\n  const gridItems: Map<BracketRoundId, BracketGridRoundItem<TRoundData, TMatchData>> = new Map();\n\n  return gridItems;\n};\n\nconst generateSwissWithEliminationGridPlacements = <TRoundData, TMatchData>(\n  bracketData: BracketData<TRoundData, TMatchData>,\n  roundTypeMap: BracketRoundTypeMap<TRoundData, TMatchData>,\n  swissGroups: BracketRoundMapWithSwissData<TRoundData, TMatchData>,\n  roundRelations: BracketRoundRelations<TRoundData, TMatchData>,\n  matchRelations: BracketMatchRelationsMap<TRoundData, TMatchData>,\n  options: GenerateBracketGridItemsOptionsWithDefaults<TRoundData, TMatchData>,\n) => {\n  const gridItems: Map<BracketRoundId, BracketGridRoundItem<TRoundData, TMatchData>> = new Map();\n\n  return gridItems;\n};\n"]}
|
|
@@ -5,10 +5,10 @@ export class NewBracketDefaultMatchComponent {
|
|
|
5
5
|
this.bracketRound = input.required();
|
|
6
6
|
this.bracketMatch = input.required();
|
|
7
7
|
}
|
|
8
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.
|
|
9
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NewBracketDefaultMatchComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
9
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.12", type: NewBracketDefaultMatchComponent, isStandalone: true, selector: "et-new-bracket-default-match", inputs: { bracketRound: { classPropertyName: "bracketRound", publicName: "bracketRound", isSignal: true, isRequired: true, transformFunction: null }, bracketMatch: { classPropertyName: "bracketMatch", publicName: "bracketMatch", isSignal: true, isRequired: true, transformFunction: null } }, host: { classAttribute: "et-new-bracket-default-match-host" }, ngImport: i0, template: ` {{ bracketMatch().id }} `, isInline: true, styles: [".et-new-bracket-default-match-host{display:block;padding:8px;border:1px solid yellow;inline-size:250px;block-size:75px;display:flex;justify-content:center;align-items:center;box-sizing:border-box;font-size:12px}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
10
10
|
}
|
|
11
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NewBracketDefaultMatchComponent, decorators: [{
|
|
12
12
|
type: Component,
|
|
13
13
|
args: [{ selector: 'et-new-bracket-default-match', template: ` {{ bracketMatch().id }} `, standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
|
|
14
14
|
class: 'et-new-bracket-default-match-host',
|
|
@@ -4,10 +4,10 @@ export class NewBracketDefaultRoundHeaderComponent {
|
|
|
4
4
|
constructor() {
|
|
5
5
|
this.bracketRound = input.required();
|
|
6
6
|
}
|
|
7
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.
|
|
8
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.
|
|
7
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NewBracketDefaultRoundHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
8
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.12", type: NewBracketDefaultRoundHeaderComponent, isStandalone: true, selector: "et-new-bracket-default-round-header", inputs: { bracketRound: { classPropertyName: "bracketRound", publicName: "bracketRound", isSignal: true, isRequired: true, transformFunction: null } }, host: { classAttribute: "et-new-bracket-default-round-header-host" }, ngImport: i0, template: ` {{ bracketRound().name }} `, isInline: true, styles: [".et-new-bracket-default-round-header-host{display:block;padding:8px;border:1px solid green;inline-size:250px;block-size:50px;display:flex;justify-content:center;align-items:center;box-sizing:border-box}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
9
9
|
}
|
|
10
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NewBracketDefaultRoundHeaderComponent, decorators: [{
|
|
11
11
|
type: Component,
|
|
12
12
|
args: [{ selector: 'et-new-bracket-default-round-header', template: ` {{ bracketRound().name }} `, standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
|
|
13
13
|
class: 'et-new-bracket-default-round-header-host',
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { NgComponentOutlet } from '@angular/common';
|
|
2
2
|
import { booleanAttribute, ChangeDetectionStrategy, Component, computed, inject, input, numberAttribute, ViewEncapsulation, } from '@angular/core';
|
|
3
3
|
import { DomSanitizer } from '@angular/platform-browser';
|
|
4
|
-
import { generateBracketRoundSwissGroupMaps, generateBracketRoundTypeMap, generateMatchParticipantMap, generateMatchPositionMaps, generateMatchRelations, generateRoundRelations, } from './bracket-new';
|
|
4
|
+
import { BRACKET_DATA_LAYOUT, generateBracketData, generateBracketRoundSwissGroupMaps, generateBracketRoundTypeMap, generateMatchParticipantMap, generateMatchPositionMaps, generateMatchRelations, generateRoundRelations, getFirstRounds, } from './bracket-new';
|
|
5
5
|
import { drawMan } from './draw-man';
|
|
6
6
|
import { generateBracketGridDefinitions } from './grid-definitions';
|
|
7
7
|
import { generateBracketGridItems } from './grid-placements';
|
|
@@ -9,15 +9,21 @@ import * as i0 from "@angular/core";
|
|
|
9
9
|
export class NewBracketComponent {
|
|
10
10
|
constructor() {
|
|
11
11
|
this.#domSanitizer = inject(DomSanitizer);
|
|
12
|
-
this.
|
|
12
|
+
this.source = input.required();
|
|
13
13
|
this.columnWidth = input(250, { transform: numberAttribute });
|
|
14
14
|
this.matchHeight = input(75, { transform: numberAttribute });
|
|
15
15
|
this.roundHeaderHeight = input(50, { transform: numberAttribute });
|
|
16
16
|
this.columnGap = input(60, { transform: numberAttribute });
|
|
17
17
|
this.rowGap = input(30, { transform: numberAttribute });
|
|
18
|
+
this.curveAmount = input(20, { transform: numberAttribute });
|
|
19
|
+
this.lineWidth = input(2, { transform: numberAttribute });
|
|
20
|
+
this.lineDashArray = input(0, { transform: numberAttribute });
|
|
21
|
+
this.lineDashOffset = input(0, { transform: numberAttribute });
|
|
22
|
+
this.layout = input(BRACKET_DATA_LAYOUT.LEFT_TO_RIGHT);
|
|
18
23
|
this.hideRoundHeaders = input(false, { transform: booleanAttribute });
|
|
19
24
|
this.roundHeaderComponent = input();
|
|
20
25
|
this.matchComponent = input();
|
|
26
|
+
this.bracketData = computed(() => generateBracketData(this.source(), { layout: this.layout() }));
|
|
21
27
|
this.roundTypeMap = computed(() => generateBracketRoundTypeMap(this.bracketData()));
|
|
22
28
|
this.matchParticipantMap = computed(() => generateMatchParticipantMap(this.bracketData()));
|
|
23
29
|
this.matchPositionsMap = computed(() => generateMatchPositionMaps(this.bracketData()));
|
|
@@ -32,23 +38,32 @@ export class NewBracketComponent {
|
|
|
32
38
|
this.definitions = computed(() => generateBracketGridDefinitions(this.bracketData(), this.roundTypeMap(), {
|
|
33
39
|
includeRoundHeaders: !this.hideRoundHeaders(),
|
|
34
40
|
}));
|
|
35
|
-
this.
|
|
41
|
+
this.firstRounds = computed(() => getFirstRounds(this.bracketData(), this.roundTypeMap()));
|
|
42
|
+
this.drawManData = computed(() => this.#domSanitizer.bypassSecurityTrustHtml(drawMan(this.items(), this.firstRounds(), {
|
|
36
43
|
columnGap: this.columnGap(),
|
|
37
44
|
columnWidth: this.columnWidth(),
|
|
38
45
|
matchHeight: this.matchHeight(),
|
|
39
46
|
roundHeaderHeight: this.hideRoundHeaders() ? 0 : this.roundHeaderHeight(),
|
|
40
47
|
rowGap: this.rowGap(),
|
|
41
48
|
gridDefinitions: this.definitions(),
|
|
49
|
+
curve: {
|
|
50
|
+
curveAmount: this.curveAmount(),
|
|
51
|
+
},
|
|
52
|
+
path: {
|
|
53
|
+
dashArray: this.lineDashArray(),
|
|
54
|
+
dashOffset: this.lineDashOffset(),
|
|
55
|
+
width: this.lineWidth(),
|
|
56
|
+
},
|
|
42
57
|
})));
|
|
43
58
|
}
|
|
44
59
|
#domSanitizer;
|
|
45
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.
|
|
46
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.
|
|
60
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NewBracketComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
61
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.12", type: NewBracketComponent, isStandalone: true, selector: "et-new-bracket", inputs: { source: { classPropertyName: "source", publicName: "source", isSignal: true, isRequired: true, transformFunction: null }, columnWidth: { classPropertyName: "columnWidth", publicName: "columnWidth", isSignal: true, isRequired: false, transformFunction: null }, matchHeight: { classPropertyName: "matchHeight", publicName: "matchHeight", isSignal: true, isRequired: false, transformFunction: null }, roundHeaderHeight: { classPropertyName: "roundHeaderHeight", publicName: "roundHeaderHeight", isSignal: true, isRequired: false, transformFunction: null }, columnGap: { classPropertyName: "columnGap", publicName: "columnGap", isSignal: true, isRequired: false, transformFunction: null }, rowGap: { classPropertyName: "rowGap", publicName: "rowGap", isSignal: true, isRequired: false, transformFunction: null }, curveAmount: { classPropertyName: "curveAmount", publicName: "curveAmount", isSignal: true, isRequired: false, transformFunction: null }, lineWidth: { classPropertyName: "lineWidth", publicName: "lineWidth", isSignal: true, isRequired: false, transformFunction: null }, lineDashArray: { classPropertyName: "lineDashArray", publicName: "lineDashArray", isSignal: true, isRequired: false, transformFunction: null }, lineDashOffset: { classPropertyName: "lineDashOffset", publicName: "lineDashOffset", isSignal: true, isRequired: false, transformFunction: null }, layout: { classPropertyName: "layout", publicName: "layout", isSignal: true, isRequired: false, transformFunction: null }, hideRoundHeaders: { classPropertyName: "hideRoundHeaders", publicName: "hideRoundHeaders", isSignal: true, isRequired: false, transformFunction: null }, roundHeaderComponent: { classPropertyName: "roundHeaderComponent", publicName: "roundHeaderComponent", isSignal: true, isRequired: false, transformFunction: null }, matchComponent: { classPropertyName: "matchComponent", publicName: "matchComponent", isSignal: true, isRequired: false, transformFunction: null } }, host: { classAttribute: "et-new-bracket-host" }, ngImport: i0, template: "<section\n [style.--_cw.px]=\"columnWidth()\"\n [style.--_mh.px]=\"matchHeight()\"\n [style.--_rhh.px]=\"roundHeaderHeight()\"\n [style.--_cg.px]=\"columnGap()\"\n [style.--_rg.px]=\"rowGap()\"\n [style.--_bcc]=\"definitions().columnCount\"\n [style.--_brc]=\"definitions().rowCount\"\n class=\"et-bracket-new\"\n>\n <svg [innerHTML]=\"drawManData()\" class=\"et-bracket-new-svg\" xmlns=\"http://www.w3.org/2000/svg\" />\n\n @for (round of items().values(); track round.layoutId) {\n <ul [style.--_c]=\"round.columnStart + ' / ' + round.columnEnd\" class=\"et-bracket-new-round\">\n @for (item of round.items.values(); track item.layoutId) {\n <li [style.--_r]=\"item.rowStart + ' / ' + item.rowEnd\" class=\"et-bracket-new-item\">\n <ng-container *ngComponentOutlet=\"item.component; inputs: item.data\" />\n </li>\n }\n </ul>\n }\n</section>\n", styles: [".et-bracket-new{display:grid;gap:var(--_cg);grid-auto-columns:var(--_cw);--bracket-line-color: red}.et-bracket-new-round{display:grid;grid-column:var(--_c);grid-row:1;list-style:none;margin:0;padding:0;gap:var(--_rg);grid-template-rows:var(--_rhh);grid-auto-rows:var(--_mh)}.et-bracket-new-item{grid-row:var(--_r);place-self:center}.et-bracket-new-svg{grid-column:1/calc(var(--_bcc) + 1);grid-row:1/2;inline-size:100%;block-size:100%}.et-bracket-new-svg path{color:var(--bracket-line-color)}\n"], dependencies: [{ kind: "directive", type: NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
47
62
|
}
|
|
48
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.
|
|
63
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NewBracketComponent, decorators: [{
|
|
49
64
|
type: Component,
|
|
50
65
|
args: [{ selector: 'et-new-bracket', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
|
|
51
66
|
class: 'et-new-bracket-host',
|
|
52
|
-
}, imports: [NgComponentOutlet], template: "<section\n [style.--_cw.px]=\"columnWidth()\"\n [style.--_mh.px]=\"matchHeight()\"\n [style.--_rhh.px]=\"roundHeaderHeight()\"\n [style.--_cg.px]=\"columnGap()\"\n [style.--_rg.px]=\"rowGap()\"\n [style.--_bcc]=\"definitions().columnCount\"\n [style.--_brc]=\"definitions().rowCount\"\n class=\"et-bracket-new\"\n>\n <svg [innerHTML]=\"drawManData()\" class=\"et-bracket-new-svg\" xmlns=\"http://www.w3.org/2000/svg\" />\n\n @for (round of items().values(); track round.
|
|
67
|
+
}, imports: [NgComponentOutlet], template: "<section\n [style.--_cw.px]=\"columnWidth()\"\n [style.--_mh.px]=\"matchHeight()\"\n [style.--_rhh.px]=\"roundHeaderHeight()\"\n [style.--_cg.px]=\"columnGap()\"\n [style.--_rg.px]=\"rowGap()\"\n [style.--_bcc]=\"definitions().columnCount\"\n [style.--_brc]=\"definitions().rowCount\"\n class=\"et-bracket-new\"\n>\n <svg [innerHTML]=\"drawManData()\" class=\"et-bracket-new-svg\" xmlns=\"http://www.w3.org/2000/svg\" />\n\n @for (round of items().values(); track round.layoutId) {\n <ul [style.--_c]=\"round.columnStart + ' / ' + round.columnEnd\" class=\"et-bracket-new-round\">\n @for (item of round.items.values(); track item.layoutId) {\n <li [style.--_r]=\"item.rowStart + ' / ' + item.rowEnd\" class=\"et-bracket-new-item\">\n <ng-container *ngComponentOutlet=\"item.component; inputs: item.data\" />\n </li>\n }\n </ul>\n }\n</section>\n", styles: [".et-bracket-new{display:grid;gap:var(--_cg);grid-auto-columns:var(--_cw);--bracket-line-color: red}.et-bracket-new-round{display:grid;grid-column:var(--_c);grid-row:1;list-style:none;margin:0;padding:0;gap:var(--_rg);grid-template-rows:var(--_rhh);grid-auto-rows:var(--_mh)}.et-bracket-new-item{grid-row:var(--_r);place-self:center}.et-bracket-new-svg{grid-column:1/calc(var(--_bcc) + 1);grid-row:1/2;inline-size:100%;block-size:100%}.et-bracket-new-svg path{color:var(--bracket-line-color)}\n"] }]
|
|
53
68
|
}] });
|
|
54
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"new-bracket.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/bracket/components/new-bracket/new-bracket.component.ts","../../../../../../../../../libs/cdk/src/lib/components/bracket/components/new-bracket/new-bracket.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgComponentOutlet } from '@angular/common';\nimport {\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  Component,\n  computed,\n  inject,\n  input,\n  numberAttribute,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport {\n  BracketData,\n  generateBracketRoundSwissGroupMaps,\n  generateBracketRoundTypeMap,\n  generateMatchParticipantMap,\n  generateMatchPositionMaps,\n  generateMatchRelations,\n  generateRoundRelations,\n} from './bracket-new';\nimport { drawMan } from './draw-man';\nimport { generateBracketGridDefinitions } from './grid-definitions';\nimport { BracketMatchComponent, BracketRoundHeaderComponent, generateBracketGridItems } from './grid-placements';\n\n@Component({\n  selector: 'et-new-bracket',\n  templateUrl: './new-bracket.component.html',\n  styleUrl: './new-bracket.component.scss',\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    class: 'et-new-bracket-host',\n  },\n  imports: [NgComponentOutlet],\n})\nexport class NewBracketComponent<TRoundData = unknown, TMatchData = unknown> {\n  #domSanitizer = inject(DomSanitizer);\n  bracketData = input.required<BracketData<TRoundData, TMatchData>>();\n\n  columnWidth = input(250, { transform: numberAttribute });\n  matchHeight = input(75, { transform: numberAttribute });\n  roundHeaderHeight = input(50, { transform: numberAttribute });\n  columnGap = input(60, { transform: numberAttribute });\n  rowGap = input(30, { transform: numberAttribute });\n\n  hideRoundHeaders = input(false, { transform: booleanAttribute });\n\n  roundHeaderComponent = input<BracketRoundHeaderComponent<TRoundData, TMatchData> | undefined>();\n  matchComponent = input<BracketMatchComponent<TRoundData, TMatchData> | undefined>();\n\n  roundTypeMap = computed(() => generateBracketRoundTypeMap(this.bracketData()));\n  matchParticipantMap = computed(() => generateMatchParticipantMap(this.bracketData()));\n  matchPositionsMap = computed(() => generateMatchPositionMaps(this.bracketData()));\n\n  roundRelations = computed(() => generateRoundRelations(this.bracketData()));\n  matchRelations = computed(() =>\n    generateMatchRelations(this.bracketData(), this.roundRelations(), this.matchPositionsMap()),\n  );\n\n  swissGroups = computed(() => generateBracketRoundSwissGroupMaps(this.bracketData(), this.matchParticipantMap()));\n\n  items = computed(() =>\n    generateBracketGridItems(\n      this.bracketData(),\n      this.roundTypeMap(),\n      this.swissGroups(),\n      this.roundRelations(),\n      this.matchRelations(),\n      {\n        includeRoundHeaders: !this.hideRoundHeaders(),\n        headerComponent: this.roundHeaderComponent(),\n        matchComponent: this.matchComponent(),\n      },\n    ),\n  );\n\n  definitions = computed(() =>\n    generateBracketGridDefinitions(this.bracketData(), this.roundTypeMap(), {\n      includeRoundHeaders: !this.hideRoundHeaders(),\n    }),\n  );\n\n  drawManData = computed(() =>\n    this.#domSanitizer.bypassSecurityTrustHtml(\n      drawMan(this.items(), this.roundRelations(), {\n        columnGap: this.columnGap(),\n        columnWidth: this.columnWidth(),\n        matchHeight: this.matchHeight(),\n        roundHeaderHeight: this.hideRoundHeaders() ? 0 : this.roundHeaderHeight(),\n        rowGap: this.rowGap(),\n        gridDefinitions: this.definitions(),\n      }),\n    ),\n  );\n}\n","<section\n  [style.--_cw.px]=\"columnWidth()\"\n  [style.--_mh.px]=\"matchHeight()\"\n  [style.--_rhh.px]=\"roundHeaderHeight()\"\n  [style.--_cg.px]=\"columnGap()\"\n  [style.--_rg.px]=\"rowGap()\"\n  [style.--_bcc]=\"definitions().columnCount\"\n  [style.--_brc]=\"definitions().rowCount\"\n  class=\"et-bracket-new\"\n>\n  <svg [innerHTML]=\"drawManData()\" class=\"et-bracket-new-svg\" xmlns=\"http://www.w3.org/2000/svg\" />\n\n  @for (round of items().values(); track round.id) {\n    <ul [style.--_c]=\"round.columnStart + ' / ' + round.columnEnd\" class=\"et-bracket-new-round\">\n      @for (item of round.items.values(); track item.id) {\n        <li [style.--_r]=\"item.rowStart + ' / ' + item.rowEnd\" class=\"et-bracket-new-item\">\n          <ng-container *ngComponentOutlet=\"item.component; inputs: item.data\" />\n        </li>\n      }\n    </ul>\n  }\n</section>\n"]}
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"new-bracket.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/bracket/components/new-bracket/new-bracket.component.ts","../../../../../../../../../libs/cdk/src/lib/components/bracket/components/new-bracket/new-bracket.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgComponentOutlet } from '@angular/common';\nimport {\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  Component,\n  computed,\n  inject,\n  input,\n  numberAttribute,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport {\n  BRACKET_DATA_LAYOUT,\n  BracketDataLayout,\n  BracketDataSource,\n  generateBracketData,\n  generateBracketRoundSwissGroupMaps,\n  generateBracketRoundTypeMap,\n  generateMatchParticipantMap,\n  generateMatchPositionMaps,\n  generateMatchRelations,\n  generateRoundRelations,\n  getFirstRounds,\n} from './bracket-new';\nimport { drawMan } from './draw-man';\nimport { generateBracketGridDefinitions } from './grid-definitions';\nimport { BracketMatchComponent, BracketRoundHeaderComponent, generateBracketGridItems } from './grid-placements';\n\n@Component({\n  selector: 'et-new-bracket',\n  templateUrl: './new-bracket.component.html',\n  styleUrl: './new-bracket.component.scss',\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    class: 'et-new-bracket-host',\n  },\n  imports: [NgComponentOutlet],\n})\nexport class NewBracketComponent<TRoundData = unknown, TMatchData = unknown> {\n  #domSanitizer = inject(DomSanitizer);\n\n  source = input.required<BracketDataSource<TRoundData, TMatchData>>();\n\n  columnWidth = input(250, { transform: numberAttribute });\n  matchHeight = input(75, { transform: numberAttribute });\n  roundHeaderHeight = input(50, { transform: numberAttribute });\n  columnGap = input(60, { transform: numberAttribute });\n  rowGap = input(30, { transform: numberAttribute });\n  curveAmount = input(20, { transform: numberAttribute });\n  lineWidth = input(2, { transform: numberAttribute });\n  lineDashArray = input(0, { transform: numberAttribute });\n  lineDashOffset = input(0, { transform: numberAttribute });\n\n  layout = input<BracketDataLayout>(BRACKET_DATA_LAYOUT.LEFT_TO_RIGHT);\n  hideRoundHeaders = input(false, { transform: booleanAttribute });\n\n  roundHeaderComponent = input<BracketRoundHeaderComponent<TRoundData, TMatchData> | undefined>();\n  matchComponent = input<BracketMatchComponent<TRoundData, TMatchData> | undefined>();\n\n  bracketData = computed(() => generateBracketData(this.source(), { layout: this.layout() }));\n\n  roundTypeMap = computed(() => generateBracketRoundTypeMap(this.bracketData()));\n  matchParticipantMap = computed(() => generateMatchParticipantMap(this.bracketData()));\n  matchPositionsMap = computed(() => generateMatchPositionMaps(this.bracketData()));\n\n  roundRelations = computed(() => generateRoundRelations(this.bracketData()));\n  matchRelations = computed(() =>\n    generateMatchRelations(this.bracketData(), this.roundRelations(), this.matchPositionsMap()),\n  );\n\n  swissGroups = computed(() => generateBracketRoundSwissGroupMaps(this.bracketData(), this.matchParticipantMap()));\n\n  items = computed(() =>\n    generateBracketGridItems(\n      this.bracketData(),\n      this.roundTypeMap(),\n      this.swissGroups(),\n      this.roundRelations(),\n      this.matchRelations(),\n      {\n        includeRoundHeaders: !this.hideRoundHeaders(),\n        headerComponent: this.roundHeaderComponent(),\n        matchComponent: this.matchComponent(),\n      },\n    ),\n  );\n\n  definitions = computed(() =>\n    generateBracketGridDefinitions(this.bracketData(), this.roundTypeMap(), {\n      includeRoundHeaders: !this.hideRoundHeaders(),\n    }),\n  );\n\n  firstRounds = computed(() => getFirstRounds(this.bracketData(), this.roundTypeMap()));\n\n  drawManData = computed(() =>\n    this.#domSanitizer.bypassSecurityTrustHtml(\n      drawMan(this.items(), this.firstRounds(), {\n        columnGap: this.columnGap(),\n        columnWidth: this.columnWidth(),\n        matchHeight: this.matchHeight(),\n        roundHeaderHeight: this.hideRoundHeaders() ? 0 : this.roundHeaderHeight(),\n        rowGap: this.rowGap(),\n        gridDefinitions: this.definitions(),\n        curve: {\n          curveAmount: this.curveAmount(),\n        },\n        path: {\n          dashArray: this.lineDashArray(),\n          dashOffset: this.lineDashOffset(),\n          width: this.lineWidth(),\n        },\n      }),\n    ),\n  );\n}\n","<section\n  [style.--_cw.px]=\"columnWidth()\"\n  [style.--_mh.px]=\"matchHeight()\"\n  [style.--_rhh.px]=\"roundHeaderHeight()\"\n  [style.--_cg.px]=\"columnGap()\"\n  [style.--_rg.px]=\"rowGap()\"\n  [style.--_bcc]=\"definitions().columnCount\"\n  [style.--_brc]=\"definitions().rowCount\"\n  class=\"et-bracket-new\"\n>\n  <svg [innerHTML]=\"drawManData()\" class=\"et-bracket-new-svg\" xmlns=\"http://www.w3.org/2000/svg\" />\n\n  @for (round of items().values(); track round.layoutId) {\n    <ul [style.--_c]=\"round.columnStart + ' / ' + round.columnEnd\" class=\"et-bracket-new-round\">\n      @for (item of round.items.values(); track item.layoutId) {\n        <li [style.--_r]=\"item.rowStart + ' / ' + item.rowEnd\" class=\"et-bracket-new-item\">\n          <ng-container *ngComponentOutlet=\"item.component; inputs: item.data\" />\n        </li>\n      }\n    </ul>\n  }\n</section>\n"]}
|
|
@@ -7,10 +7,10 @@ export class BracketMatchDirective {
|
|
|
7
7
|
this.bracket = inject(BRACKET_TOKEN);
|
|
8
8
|
this.match$ = this.bracket.getBracketMatchById(this.matchId);
|
|
9
9
|
}
|
|
10
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.
|
|
11
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.
|
|
10
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: BracketMatchDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
11
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.12", type: BracketMatchDirective, isStandalone: true, ngImport: i0 }); }
|
|
12
12
|
}
|
|
13
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: BracketMatchDirective, decorators: [{
|
|
14
14
|
type: Directive,
|
|
15
15
|
args: [{
|
|
16
16
|
standalone: true,
|
|
@@ -7,10 +7,10 @@ export class BracketRoundDirective {
|
|
|
7
7
|
this.bracket = inject(BRACKET_TOKEN);
|
|
8
8
|
this.round$ = this.bracket.getBracketRoundById(this.roundId);
|
|
9
9
|
}
|
|
10
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.
|
|
11
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.
|
|
10
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: BracketRoundDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
11
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.12", type: BracketRoundDirective, isStandalone: true, ngImport: i0 }); }
|
|
12
12
|
}
|
|
13
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: BracketRoundDirective, decorators: [{
|
|
14
14
|
type: Directive,
|
|
15
15
|
args: [{
|
|
16
16
|
standalone: true,
|