@ethlete/cdk 4.45.0 → 4.46.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.
Files changed (22) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/esm2022/lib/components/bracket/components/new-bracket/bracket-new.mjs +782 -0
  3. package/esm2022/lib/components/bracket/components/new-bracket/draw-man.mjs +66 -0
  4. package/esm2022/lib/components/bracket/components/new-bracket/grid-definitions.mjs +47 -0
  5. package/esm2022/lib/components/bracket/components/new-bracket/grid-placements.mjs +97 -0
  6. package/esm2022/lib/components/bracket/components/new-bracket/index.mjs +8 -0
  7. package/esm2022/lib/components/bracket/components/new-bracket/new-bracket-default-match.component.mjs +17 -0
  8. package/esm2022/lib/components/bracket/components/new-bracket/new-bracket-default-round-header.component.mjs +16 -0
  9. package/esm2022/lib/components/bracket/components/new-bracket/new-bracket.component.mjs +54 -0
  10. package/esm2022/lib/components/bracket/public-api/index.mjs +2 -1
  11. package/fesm2022/ethlete-cdk.mjs +1096 -3
  12. package/fesm2022/ethlete-cdk.mjs.map +1 -1
  13. package/lib/components/bracket/components/new-bracket/bracket-new.d.ts +238 -0
  14. package/lib/components/bracket/components/new-bracket/draw-man.d.ts +12 -0
  15. package/lib/components/bracket/components/new-bracket/grid-definitions.d.ts +9 -0
  16. package/lib/components/bracket/components/new-bracket/grid-placements.d.ts +56 -0
  17. package/lib/components/bracket/components/new-bracket/index.d.ts +7 -0
  18. package/lib/components/bracket/components/new-bracket/new-bracket-default-match.component.d.ts +8 -0
  19. package/lib/components/bracket/components/new-bracket/new-bracket-default-round-header.component.d.ts +7 -0
  20. package/lib/components/bracket/components/new-bracket/new-bracket.component.d.ts +26 -0
  21. package/lib/components/bracket/public-api/index.d.ts +1 -0
  22. package/package.json +1 -1
@@ -0,0 +1,66 @@
1
+ const LINE_WIDTH = 1;
2
+ const path = (d) => `<path d="${d}" stroke="red" fill="none" stroke-width="${LINE_WIDTH}" />`;
3
+ export const drawMan = (items, roundRelations, dimensions) => {
4
+ const { columnWidth, matchHeight, rowGap, columnGap, roundHeaderHeight, gridDefinitions } = dimensions;
5
+ const roundHeaderRowGap = roundHeaderHeight ? rowGap : 0;
6
+ 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
+ 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
+ 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
+ for (const item of round.items.values()) {
23
+ if (item.type === 'round')
24
+ continue; // we don't draw lines for round headers
25
+ switch (item.matchRelation.type) {
26
+ case 'nothing-to-one': {
27
+ continue;
28
+ }
29
+ case 'one-to-nothing':
30
+ case 'one-to-one': {
31
+ // draw a straight line
32
+ const previousRound = items.get(item.matchRelation.previousRound.id);
33
+ if (!previousRound)
34
+ throw new Error('Previous round or match is missing');
35
+ const previousMatch = previousRound.items.get(item.matchRelation.previousMatch.id);
36
+ if (!previousMatch || previousMatch.type !== 'match')
37
+ throw new Error('Previous round or match is missing');
38
+ const previousRoundRows = previousRound.roundRelation.currentRound.matchCount;
39
+ const previousRoundRowGaps = previousRoundRows - 1;
40
+ const previousRoundRowHeight = (totalHeight - baseOffsetY) / previousRoundRows - previousRoundRowGaps * rowGap;
41
+ const previousRoundRowWhitespace = (previousRoundRowHeight - matchHeight) / 2;
42
+ const previousRoundMatchHeightOffset = previousRoundRowWhitespace + matchHeight / 2;
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}`));
54
+ break;
55
+ }
56
+ case 'two-to-nothing':
57
+ case 'two-to-one': {
58
+ // draw two lines that merge into one in the middle
59
+ break;
60
+ }
61
+ }
62
+ }
63
+ }
64
+ return svgParts.join(' /n');
65
+ };
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"]}
@@ -0,0 +1,47 @@
1
+ import { COMMON_BRACKET_ROUND_TYPE, DOUBLE_ELIMINATION_BRACKET_ROUND_TYPE, TOURNAMENT_MODE, } from './bracket-new';
2
+ const generateColumnCount = (bracketData, roundTypeMap) => {
3
+ const thirdPlaceRoundSize = roundTypeMap.get(COMMON_BRACKET_ROUND_TYPE.THIRD_PLACE)?.size || 0;
4
+ switch (bracketData.mode) {
5
+ case TOURNAMENT_MODE.DOUBLE_ELIMINATION: {
6
+ const upperBracketSize = roundTypeMap.get(DOUBLE_ELIMINATION_BRACKET_ROUND_TYPE.UPPER_BRACKET)?.size || 0;
7
+ const lowerBracketSize = roundTypeMap.get(DOUBLE_ELIMINATION_BRACKET_ROUND_TYPE.LOWER_BRACKET)?.size || 0;
8
+ // the total columns are the bigger number of winner bracket rounds vs looser bracket rounds + all other rounds excluding third place
9
+ return bracketData.rounds.size - thirdPlaceRoundSize + Math.max(upperBracketSize, lowerBracketSize);
10
+ }
11
+ default: {
12
+ // the total columns are the amount of rounds excluding third place
13
+ return bracketData.rounds.size - thirdPlaceRoundSize;
14
+ }
15
+ }
16
+ };
17
+ const generateRowCount = (bracketData, roundTypeMap, options) => {
18
+ switch (bracketData.mode) {
19
+ case TOURNAMENT_MODE.DOUBLE_ELIMINATION: {
20
+ const upperBracketSize = roundTypeMap.get(DOUBLE_ELIMINATION_BRACKET_ROUND_TYPE.UPPER_BRACKET)?.values().next()
21
+ .value?.matchCount;
22
+ const lowerBracketSize = roundTypeMap.get(DOUBLE_ELIMINATION_BRACKET_ROUND_TYPE.LOWER_BRACKET)?.values().next()
23
+ .value?.matchCount;
24
+ const roundHeadersCount = options.includeRoundHeaders ? 2 : 0;
25
+ if (upperBracketSize === undefined || lowerBracketSize === undefined) {
26
+ throw new Error('Upper or lower bracket size is undefined');
27
+ }
28
+ // the total rows the amount of matches in the first upper bracket round + first lower bracket round + if true, the round header row for both
29
+ return upperBracketSize + lowerBracketSize + roundHeadersCount;
30
+ }
31
+ default: {
32
+ const firstRoundSize = bracketData.rounds.values().next().value?.matchCount;
33
+ const roundHeadersCount = options.includeRoundHeaders ? 1 : 0;
34
+ if (firstRoundSize === undefined) {
35
+ throw new Error('First round size is undefined');
36
+ }
37
+ // the total rows are the amount of matches in the first round + if true, the round header row
38
+ return firstRoundSize + roundHeadersCount;
39
+ }
40
+ }
41
+ };
42
+ export const generateBracketGridDefinitions = (bracketData, roundTypeMap, options) => {
43
+ const columnCount = generateColumnCount(bracketData, roundTypeMap);
44
+ const rowCount = generateRowCount(bracketData, roundTypeMap, options);
45
+ return { columnCount, rowCount };
46
+ };
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC1kZWZpbml0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY2RrL3NyYy9saWIvY29tcG9uZW50cy9icmFja2V0L2NvbXBvbmVudHMvbmV3LWJyYWNrZXQvZ3JpZC1kZWZpbml0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBR0wseUJBQXlCLEVBQ3pCLHFDQUFxQyxFQUNyQyxlQUFlLEdBQ2hCLE1BQU0sZUFBZSxDQUFDO0FBTXZCLE1BQU0sbUJBQW1CLEdBQUcsQ0FDMUIsV0FBZ0QsRUFDaEQsWUFBeUQsRUFDekQsRUFBRTtJQUNGLE1BQU0sbUJBQW1CLEdBQUcsWUFBWSxDQUFDLEdBQUcsQ0FBQyx5QkFBeUIsQ0FBQyxXQUFXLENBQUMsRUFBRSxJQUFJLElBQUksQ0FBQyxDQUFDO0lBRS9GLFFBQVEsV0FBVyxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3pCLEtBQUssZUFBZSxDQUFDLGtCQUFrQixDQUFDLENBQUMsQ0FBQztZQUN4QyxNQUFNLGdCQUFnQixHQUFHLFlBQVksQ0FBQyxHQUFHLENBQUMscUNBQXFDLENBQUMsYUFBYSxDQUFDLEVBQUUsSUFBSSxJQUFJLENBQUMsQ0FBQztZQUMxRyxNQUFNLGdCQUFnQixHQUFHLFlBQVksQ0FBQyxHQUFHLENBQUMscUNBQXFDLENBQUMsYUFBYSxDQUFDLEVBQUUsSUFBSSxJQUFJLENBQUMsQ0FBQztZQUUxRyxxSUFBcUk7WUFDckksT0FBTyxXQUFXLENBQUMsTUFBTSxDQUFDLElBQUksR0FBRyxtQkFBbUIsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLGdCQUFnQixFQUFFLGdCQUFnQixDQUFDLENBQUM7UUFDdEcsQ0FBQztRQUNELE9BQU8sQ0FBQyxDQUFDLENBQUM7WUFDUixtRUFBbUU7WUFDbkUsT0FBTyxXQUFXLENBQUMsTUFBTSxDQUFDLElBQUksR0FBRyxtQkFBbUIsQ0FBQztRQUN2RCxDQUFDO0lBQ0gsQ0FBQztBQUNILENBQUMsQ0FBQztBQUVGLE1BQU0sZ0JBQWdCLEdBQUcsQ0FDdkIsV0FBZ0QsRUFDaEQsWUFBeUQsRUFDekQsT0FBOEMsRUFDOUMsRUFBRTtJQUNGLFFBQVEsV0FBVyxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3pCLEtBQUssZUFBZSxDQUFDLGtCQUFrQixDQUFDLENBQUMsQ0FBQztZQUN4QyxNQUFNLGdCQUFnQixHQUFHLFlBQVksQ0FBQyxHQUFHLENBQUMscUNBQXFDLENBQUMsYUFBYSxDQUFDLEVBQUUsTUFBTSxFQUFFLENBQUMsSUFBSSxFQUFFO2lCQUM1RyxLQUFLLEVBQUUsVUFBVSxDQUFDO1lBQ3JCLE1BQU0sZ0JBQWdCLEdBQUcsWUFBWSxDQUFDLEdBQUcsQ0FBQyxxQ0FBcUMsQ0FBQyxhQUFhLENBQUMsRUFBRSxNQUFNLEVBQUUsQ0FBQyxJQUFJLEVBQUU7aUJBQzVHLEtBQUssRUFBRSxVQUFVLENBQUM7WUFDckIsTUFBTSxpQkFBaUIsR0FBRyxPQUFPLENBQUMsbUJBQW1CLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBRTlELElBQUksZ0JBQWdCLEtBQUssU0FBUyxJQUFJLGdCQUFnQixLQUFLLFNBQVMsRUFBRSxDQUFDO2dCQUNyRSxNQUFNLElBQUksS0FBSyxDQUFDLDBDQUEwQyxDQUFDLENBQUM7WUFDOUQsQ0FBQztZQUVELDZJQUE2STtZQUM3SSxPQUFPLGdCQUFnQixHQUFHLGdCQUFnQixHQUFHLGlCQUFpQixDQUFDO1FBQ2pFLENBQUM7UUFDRCxPQUFPLENBQUMsQ0FBQyxDQUFDO1lBQ1IsTUFBTSxjQUFjLEdBQUcsV0FBVyxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxLQUFLLEVBQUUsVUFBVSxDQUFDO1lBQzVFLE1BQU0saUJBQWlCLEdBQUcsT0FBTyxDQUFDLG1CQUFtQixDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUU5RCxJQUFJLGNBQWMsS0FBSyxTQUFTLEVBQUUsQ0FBQztnQkFDakMsTUFBTSxJQUFJLEtBQUssQ0FBQywrQkFBK0IsQ0FBQyxDQUFDO1lBQ25ELENBQUM7WUFFRCw4RkFBOEY7WUFDOUYsT0FBTyxjQUFjLEdBQUcsaUJBQWlCLENBQUM7UUFDNUMsQ0FBQztJQUNILENBQUM7QUFDSCxDQUFDLENBQUM7QUFPRixNQUFNLENBQUMsTUFBTSw4QkFBOEIsR0FBRyxDQUM1QyxXQUFnRCxFQUNoRCxZQUF5RCxFQUN6RCxPQUE4QyxFQUN0QixFQUFFO0lBQzFCLE1BQU0sV0FBVyxHQUFHLG1CQUFtQixDQUFDLFdBQVcsRUFBRSxZQUFZLENBQUMsQ0FBQztJQUNuRSxNQUFNLFFBQVEsR0FBRyxnQkFBZ0IsQ0FBQyxXQUFXLEVBQUUsWUFBWSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBRXRFLE9BQU8sRUFBRSxXQUFXLEVBQUUsUUFBUSxFQUFFLENBQUM7QUFDbkMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQnJhY2tldERhdGEsXG4gIEJyYWNrZXRSb3VuZFR5cGVNYXAsXG4gIENPTU1PTl9CUkFDS0VUX1JPVU5EX1RZUEUsXG4gIERPVUJMRV9FTElNSU5BVElPTl9CUkFDS0VUX1JPVU5EX1RZUEUsXG4gIFRPVVJOQU1FTlRfTU9ERSxcbn0gZnJvbSAnLi9icmFja2V0LW5ldyc7XG5cbmV4cG9ydCB0eXBlIGdlbmVyYXRlQnJhY2tldEdyaWREZWZpbml0aW9uc09wdGlvbnMgPSB7XG4gIGluY2x1ZGVSb3VuZEhlYWRlcnM6IGJvb2xlYW47XG59O1xuXG5jb25zdCBnZW5lcmF0ZUNvbHVtbkNvdW50ID0gPFRSb3VuZERhdGEsIFRNYXRjaERhdGE+KFxuICBicmFja2V0RGF0YTogQnJhY2tldERhdGE8VFJvdW5kRGF0YSwgVE1hdGNoRGF0YT4sXG4gIHJvdW5kVHlwZU1hcDogQnJhY2tldFJvdW5kVHlwZU1hcDxUUm91bmREYXRhLCBUTWF0Y2hEYXRhPixcbikgPT4ge1xuICBjb25zdCB0aGlyZFBsYWNlUm91bmRTaXplID0gcm91bmRUeXBlTWFwLmdldChDT01NT05fQlJBQ0tFVF9ST1VORF9UWVBFLlRISVJEX1BMQUNFKT8uc2l6ZSB8fCAwO1xuXG4gIHN3aXRjaCAoYnJhY2tldERhdGEubW9kZSkge1xuICAgIGNhc2UgVE9VUk5BTUVOVF9NT0RFLkRPVUJMRV9FTElNSU5BVElPTjoge1xuICAgICAgY29uc3QgdXBwZXJCcmFja2V0U2l6ZSA9IHJvdW5kVHlwZU1hcC5nZXQoRE9VQkxFX0VMSU1JTkFUSU9OX0JSQUNLRVRfUk9VTkRfVFlQRS5VUFBFUl9CUkFDS0VUKT8uc2l6ZSB8fCAwO1xuICAgICAgY29uc3QgbG93ZXJCcmFja2V0U2l6ZSA9IHJvdW5kVHlwZU1hcC5nZXQoRE9VQkxFX0VMSU1JTkFUSU9OX0JSQUNLRVRfUk9VTkRfVFlQRS5MT1dFUl9CUkFDS0VUKT8uc2l6ZSB8fCAwO1xuXG4gICAgICAvLyB0aGUgdG90YWwgY29sdW1ucyBhcmUgdGhlIGJpZ2dlciBudW1iZXIgb2Ygd2lubmVyIGJyYWNrZXQgcm91bmRzIHZzIGxvb3NlciBicmFja2V0IHJvdW5kcyArIGFsbCBvdGhlciByb3VuZHMgZXhjbHVkaW5nIHRoaXJkIHBsYWNlXG4gICAgICByZXR1cm4gYnJhY2tldERhdGEucm91bmRzLnNpemUgLSB0aGlyZFBsYWNlUm91bmRTaXplICsgTWF0aC5tYXgodXBwZXJCcmFja2V0U2l6ZSwgbG93ZXJCcmFja2V0U2l6ZSk7XG4gICAgfVxuICAgIGRlZmF1bHQ6IHtcbiAgICAgIC8vIHRoZSB0b3RhbCBjb2x1bW5zIGFyZSB0aGUgYW1vdW50IG9mIHJvdW5kcyBleGNsdWRpbmcgdGhpcmQgcGxhY2VcbiAgICAgIHJldHVybiBicmFja2V0RGF0YS5yb3VuZHMuc2l6ZSAtIHRoaXJkUGxhY2VSb3VuZFNpemU7XG4gICAgfVxuICB9XG59O1xuXG5jb25zdCBnZW5lcmF0ZVJvd0NvdW50ID0gPFRSb3VuZERhdGEsIFRNYXRjaERhdGE+KFxuICBicmFja2V0RGF0YTogQnJhY2tldERhdGE8VFJvdW5kRGF0YSwgVE1hdGNoRGF0YT4sXG4gIHJvdW5kVHlwZU1hcDogQnJhY2tldFJvdW5kVHlwZU1hcDxUUm91bmREYXRhLCBUTWF0Y2hEYXRhPixcbiAgb3B0aW9uczogZ2VuZXJhdGVCcmFja2V0R3JpZERlZmluaXRpb25zT3B0aW9ucyxcbikgPT4ge1xuICBzd2l0Y2ggKGJyYWNrZXREYXRhLm1vZGUpIHtcbiAgICBjYXNlIFRPVVJOQU1FTlRfTU9ERS5ET1VCTEVfRUxJTUlOQVRJT046IHtcbiAgICAgIGNvbnN0IHVwcGVyQnJhY2tldFNpemUgPSByb3VuZFR5cGVNYXAuZ2V0KERPVUJMRV9FTElNSU5BVElPTl9CUkFDS0VUX1JPVU5EX1RZUEUuVVBQRVJfQlJBQ0tFVCk/LnZhbHVlcygpLm5leHQoKVxuICAgICAgICAudmFsdWU/Lm1hdGNoQ291bnQ7XG4gICAgICBjb25zdCBsb3dlckJyYWNrZXRTaXplID0gcm91bmRUeXBlTWFwLmdldChET1VCTEVfRUxJTUlOQVRJT05fQlJBQ0tFVF9ST1VORF9UWVBFLkxPV0VSX0JSQUNLRVQpPy52YWx1ZXMoKS5uZXh0KClcbiAgICAgICAgLnZhbHVlPy5tYXRjaENvdW50O1xuICAgICAgY29uc3Qgcm91bmRIZWFkZXJzQ291bnQgPSBvcHRpb25zLmluY2x1ZGVSb3VuZEhlYWRlcnMgPyAyIDogMDtcblxuICAgICAgaWYgKHVwcGVyQnJhY2tldFNpemUgPT09IHVuZGVmaW5lZCB8fCBsb3dlckJyYWNrZXRTaXplID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdVcHBlciBvciBsb3dlciBicmFja2V0IHNpemUgaXMgdW5kZWZpbmVkJyk7XG4gICAgICB9XG5cbiAgICAgIC8vIHRoZSB0b3RhbCByb3dzIHRoZSBhbW91bnQgb2YgbWF0Y2hlcyBpbiB0aGUgZmlyc3QgdXBwZXIgYnJhY2tldCByb3VuZCArIGZpcnN0IGxvd2VyIGJyYWNrZXQgcm91bmQgKyBpZiB0cnVlLCB0aGUgcm91bmQgaGVhZGVyIHJvdyBmb3IgYm90aFxuICAgICAgcmV0dXJuIHVwcGVyQnJhY2tldFNpemUgKyBsb3dlckJyYWNrZXRTaXplICsgcm91bmRIZWFkZXJzQ291bnQ7XG4gICAgfVxuICAgIGRlZmF1bHQ6IHtcbiAgICAgIGNvbnN0IGZpcnN0Um91bmRTaXplID0gYnJhY2tldERhdGEucm91bmRzLnZhbHVlcygpLm5leHQoKS52YWx1ZT8ubWF0Y2hDb3VudDtcbiAgICAgIGNvbnN0IHJvdW5kSGVhZGVyc0NvdW50ID0gb3B0aW9ucy5pbmNsdWRlUm91bmRIZWFkZXJzID8gMSA6IDA7XG5cbiAgICAgIGlmIChmaXJzdFJvdW5kU2l6ZSA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcignRmlyc3Qgcm91bmQgc2l6ZSBpcyB1bmRlZmluZWQnKTtcbiAgICAgIH1cblxuICAgICAgLy8gdGhlIHRvdGFsIHJvd3MgYXJlIHRoZSBhbW91bnQgb2YgbWF0Y2hlcyBpbiB0aGUgZmlyc3Qgcm91bmQgKyBpZiB0cnVlLCB0aGUgcm91bmQgaGVhZGVyIHJvd1xuICAgICAgcmV0dXJuIGZpcnN0Um91bmRTaXplICsgcm91bmRIZWFkZXJzQ291bnQ7XG4gICAgfVxuICB9XG59O1xuXG5leHBvcnQgdHlwZSBCcmFja2V0R3JpZERlZmluaXRpb25zID0ge1xuICBjb2x1bW5Db3VudDogbnVtYmVyO1xuICByb3dDb3VudDogbnVtYmVyO1xufTtcblxuZXhwb3J0IGNvbnN0IGdlbmVyYXRlQnJhY2tldEdyaWREZWZpbml0aW9ucyA9IDxUUm91bmREYXRhLCBUTWF0Y2hEYXRhPihcbiAgYnJhY2tldERhdGE6IEJyYWNrZXREYXRhPFRSb3VuZERhdGEsIFRNYXRjaERhdGE+LFxuICByb3VuZFR5cGVNYXA6IEJyYWNrZXRSb3VuZFR5cGVNYXA8VFJvdW5kRGF0YSwgVE1hdGNoRGF0YT4sXG4gIG9wdGlvbnM6IGdlbmVyYXRlQnJhY2tldEdyaWREZWZpbml0aW9uc09wdGlvbnMsXG4pOiBCcmFja2V0R3JpZERlZmluaXRpb25zID0+IHtcbiAgY29uc3QgY29sdW1uQ291bnQgPSBnZW5lcmF0ZUNvbHVtbkNvdW50KGJyYWNrZXREYXRhLCByb3VuZFR5cGVNYXApO1xuICBjb25zdCByb3dDb3VudCA9IGdlbmVyYXRlUm93Q291bnQoYnJhY2tldERhdGEsIHJvdW5kVHlwZU1hcCwgb3B0aW9ucyk7XG5cbiAgcmV0dXJuIHsgY29sdW1uQ291bnQsIHJvd0NvdW50IH07XG59O1xuIl19
@@ -0,0 +1,97 @@
1
+ import { TOURNAMENT_MODE, } from './bracket-new';
2
+ import { NewBracketDefaultMatchComponent } from './new-bracket-default-match.component';
3
+ import { NewBracketDefaultRoundHeaderComponent } from './new-bracket-default-round-header.component';
4
+ export const generateBracketGridItems = (bracketData, roundTypeMap, swissGroups, roundRelations, matchRelations, options) => {
5
+ const roundHeaderComponent = options.headerComponent ?? NewBracketDefaultRoundHeaderComponent;
6
+ const matchComponent = options.matchComponent ?? NewBracketDefaultMatchComponent;
7
+ const optionsWithDefaults = {
8
+ ...options,
9
+ headerComponent: roundHeaderComponent,
10
+ matchComponent: matchComponent,
11
+ };
12
+ switch (bracketData.mode) {
13
+ case TOURNAMENT_MODE.DOUBLE_ELIMINATION:
14
+ return generateDoubleEliminationGridPlacements(bracketData, roundTypeMap, roundRelations, matchRelations, optionsWithDefaults);
15
+ case TOURNAMENT_MODE.SWISS_WITH_ELIMINATION: {
16
+ if (!swissGroups)
17
+ throw new Error('Swiss groups are required for swiss with elimination mode');
18
+ return generateSwissWithEliminationGridPlacements(bracketData, roundTypeMap, swissGroups, roundRelations, matchRelations, optionsWithDefaults);
19
+ }
20
+ default:
21
+ return generateGenericGridPlacements(bracketData, roundTypeMap, roundRelations, matchRelations, optionsWithDefaults);
22
+ }
23
+ };
24
+ const generateGenericGridPlacements = (bracketData, roundTypeMap, roundRelations, matchRelations, options) => {
25
+ const gridItems = new Map();
26
+ const firstRound = bracketData.rounds.values().next().value;
27
+ if (!firstRound) {
28
+ throw new Error('First round is missing');
29
+ }
30
+ for (const round of bracketData.rounds.values()) {
31
+ const roundRelation = roundRelations.get(round.id);
32
+ let currentMatchRow = 1;
33
+ const columnStart = round.index + 1;
34
+ const columnEnd = columnStart + 1;
35
+ if (!roundRelation) {
36
+ throw new Error('Round relation is missing');
37
+ }
38
+ if (roundRelation.type === 'two-to-nothing' || roundRelation.type === 'two-to-one') {
39
+ throw new Error(`Invalid relation type ${roundRelation.type}`);
40
+ }
41
+ const roundItem = {
42
+ id: round.id,
43
+ columnStart,
44
+ columnEnd,
45
+ roundRelation,
46
+ items: new Map(),
47
+ };
48
+ if (options.includeRoundHeaders) {
49
+ const roundHeaderItem = {
50
+ type: 'round',
51
+ id: round.id,
52
+ rowStart: currentMatchRow,
53
+ rowEnd: ++currentMatchRow,
54
+ component: options.headerComponent,
55
+ roundRelation,
56
+ data: {
57
+ bracketRound: round,
58
+ },
59
+ };
60
+ roundItem.items.set(round.id, roundHeaderItem);
61
+ }
62
+ const rootRoundMatchFactor = roundRelation.type !== 'nothing-to-one' ? roundRelation.rootRoundMatchFactor : null;
63
+ const matchHeight = rootRoundMatchFactor ? rootRoundMatchFactor : 1;
64
+ for (const match of round.matches.values()) {
65
+ const matchRelation = matchRelations.get(match.id);
66
+ if (!matchRelation) {
67
+ throw new Error('Match relation is missing');
68
+ }
69
+ const baseRow = match.indexInRound * matchHeight;
70
+ const matchItem = {
71
+ type: 'match',
72
+ id: match.id,
73
+ rowStart: baseRow + currentMatchRow,
74
+ rowEnd: baseRow + currentMatchRow + matchHeight,
75
+ component: options.matchComponent,
76
+ matchRelation,
77
+ roundRelation,
78
+ data: {
79
+ bracketRound: round,
80
+ bracketMatch: match,
81
+ },
82
+ };
83
+ roundItem.items.set(match.id, matchItem);
84
+ }
85
+ gridItems.set(round.id, roundItem);
86
+ }
87
+ return gridItems;
88
+ };
89
+ const generateDoubleEliminationGridPlacements = (bracketData, roundTypeMap, roundRelations, matchRelations, options) => {
90
+ const gridItems = new Map();
91
+ return gridItems;
92
+ };
93
+ const generateSwissWithEliminationGridPlacements = (bracketData, roundTypeMap, swissGroups, roundRelations, matchRelations, options) => {
94
+ const gridItems = new Map();
95
+ return gridItems;
96
+ };
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"]}
@@ -0,0 +1,8 @@
1
+ export * from './bracket-new';
2
+ export * from './draw-man';
3
+ export * from './grid-definitions';
4
+ export * from './grid-placements';
5
+ export * from './new-bracket-default-match.component';
6
+ export * from './new-bracket-default-round-header.component';
7
+ export * from './new-bracket.component';
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2Nkay9zcmMvbGliL2NvbXBvbmVudHMvYnJhY2tldC9jb21wb25lbnRzL25ldy1icmFja2V0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYyx5QkFBeUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYnJhY2tldC1uZXcnO1xuZXhwb3J0ICogZnJvbSAnLi9kcmF3LW1hbic7XG5leHBvcnQgKiBmcm9tICcuL2dyaWQtZGVmaW5pdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9ncmlkLXBsYWNlbWVudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9uZXctYnJhY2tldC1kZWZhdWx0LW1hdGNoLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL25ldy1icmFja2V0LWRlZmF1bHQtcm91bmQtaGVhZGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL25ldy1icmFja2V0LmNvbXBvbmVudCc7XG4iXX0=
@@ -0,0 +1,17 @@
1
+ import { ChangeDetectionStrategy, Component, input, ViewEncapsulation } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class NewBracketDefaultMatchComponent {
4
+ constructor() {
5
+ this.bracketRound = input.required();
6
+ this.bracketMatch = input.required();
7
+ }
8
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NewBracketDefaultMatchComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
9
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.11", 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
+ }
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NewBracketDefaultMatchComponent, decorators: [{
12
+ type: Component,
13
+ args: [{ selector: 'et-new-bracket-default-match', template: ` {{ bracketMatch().id }} `, standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
14
+ class: 'et-new-bracket-default-match-host',
15
+ }, 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"] }]
16
+ }] });
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmV3LWJyYWNrZXQtZGVmYXVsdC1tYXRjaC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2Nkay9zcmMvbGliL2NvbXBvbmVudHMvYnJhY2tldC9jb21wb25lbnRzL25ldy1icmFja2V0L25ldy1icmFja2V0LWRlZmF1bHQtbWF0Y2guY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDOztBQTJCN0YsTUFBTSxPQUFPLCtCQUErQjtJQXhCNUM7UUF5QkUsaUJBQVksR0FBRyxLQUFLLENBQUMsUUFBUSxFQUF3QyxDQUFDO1FBQ3RFLGlCQUFZLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBd0MsQ0FBQztLQUN2RTsrR0FIWSwrQkFBK0I7bUdBQS9CLCtCQUErQiwyYkF0QmhDLDJCQUEyQjs7NEZBc0IxQiwrQkFBK0I7a0JBeEIzQyxTQUFTOytCQUNFLDhCQUE4QixZQUM5QiwyQkFBMkIsY0FDekIsSUFBSSxtQkFDQyx1QkFBdUIsQ0FBQyxNQUFNLGlCQUNoQyxpQkFBaUIsQ0FBQyxJQUFJLFFBQy9CO3dCQUNKLEtBQUssRUFBRSxtQ0FBbUM7cUJBQzNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgaW5wdXQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCcmFja2V0TWF0Y2gsIEJyYWNrZXRSb3VuZCB9IGZyb20gJy4vYnJhY2tldC1uZXcnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdldC1uZXctYnJhY2tldC1kZWZhdWx0LW1hdGNoJyxcbiAgdGVtcGxhdGU6IGAge3sgYnJhY2tldE1hdGNoKCkuaWQgfX0gYCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGhvc3Q6IHtcbiAgICBjbGFzczogJ2V0LW5ldy1icmFja2V0LWRlZmF1bHQtbWF0Y2gtaG9zdCcsXG4gIH0sXG4gIHN0eWxlczogYFxuICAgIC5ldC1uZXctYnJhY2tldC1kZWZhdWx0LW1hdGNoLWhvc3Qge1xuICAgICAgZGlzcGxheTogYmxvY2s7XG4gICAgICBwYWRkaW5nOiA4cHg7XG4gICAgICBib3JkZXI6IDFweCBzb2xpZCB5ZWxsb3c7XG4gICAgICBpbmxpbmUtc2l6ZTogMjUwcHg7XG4gICAgICBibG9jay1zaXplOiA3NXB4O1xuICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gICAgICBmb250LXNpemU6IDEycHg7XG4gICAgfVxuICBgLFxufSlcbmV4cG9ydCBjbGFzcyBOZXdCcmFja2V0RGVmYXVsdE1hdGNoQ29tcG9uZW50PFRSb3VuZERhdGEgPSB1bmtub3duLCBUTWF0Y2hEYXRhID0gdW5rbm93bj4ge1xuICBicmFja2V0Um91bmQgPSBpbnB1dC5yZXF1aXJlZDxCcmFja2V0Um91bmQ8VFJvdW5kRGF0YSwgVE1hdGNoRGF0YT4+KCk7XG4gIGJyYWNrZXRNYXRjaCA9IGlucHV0LnJlcXVpcmVkPEJyYWNrZXRNYXRjaDxUUm91bmREYXRhLCBUTWF0Y2hEYXRhPj4oKTtcbn1cbiJdfQ==
@@ -0,0 +1,16 @@
1
+ import { ChangeDetectionStrategy, Component, input, ViewEncapsulation } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class NewBracketDefaultRoundHeaderComponent {
4
+ constructor() {
5
+ this.bracketRound = input.required();
6
+ }
7
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NewBracketDefaultRoundHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
8
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.11", 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
+ }
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NewBracketDefaultRoundHeaderComponent, decorators: [{
11
+ type: Component,
12
+ args: [{ selector: 'et-new-bracket-default-round-header', template: ` {{ bracketRound().name }} `, standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
13
+ class: 'et-new-bracket-default-round-header-host',
14
+ }, 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"] }]
15
+ }] });
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmV3LWJyYWNrZXQtZGVmYXVsdC1yb3VuZC1oZWFkZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jZGsvc3JjL2xpYi9jb21wb25lbnRzL2JyYWNrZXQvY29tcG9uZW50cy9uZXctYnJhY2tldC9uZXctYnJhY2tldC1kZWZhdWx0LXJvdW5kLWhlYWRlci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBMEI3RixNQUFNLE9BQU8scUNBQXFDO0lBdkJsRDtRQXdCRSxpQkFBWSxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQXdDLENBQUM7S0FDdkU7K0dBRlkscUNBQXFDO21HQUFyQyxxQ0FBcUMsNlRBckJ0Qyw2QkFBNkI7OzRGQXFCNUIscUNBQXFDO2tCQXZCakQsU0FBUzsrQkFDRSxxQ0FBcUMsWUFDckMsNkJBQTZCLGNBQzNCLElBQUksbUJBQ0MsdUJBQXVCLENBQUMsTUFBTSxpQkFDaEMsaUJBQWlCLENBQUMsSUFBSSxRQUMvQjt3QkFDSixLQUFLLEVBQUUsMENBQTBDO3FCQUNsRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGlucHV0LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQnJhY2tldFJvdW5kIH0gZnJvbSAnLi9icmFja2V0LW5ldyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2V0LW5ldy1icmFja2V0LWRlZmF1bHQtcm91bmQtaGVhZGVyJyxcbiAgdGVtcGxhdGU6IGAge3sgYnJhY2tldFJvdW5kKCkubmFtZSB9fSBgLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgaG9zdDoge1xuICAgIGNsYXNzOiAnZXQtbmV3LWJyYWNrZXQtZGVmYXVsdC1yb3VuZC1oZWFkZXItaG9zdCcsXG4gIH0sXG4gIHN0eWxlczogYFxuICAgIC5ldC1uZXctYnJhY2tldC1kZWZhdWx0LXJvdW5kLWhlYWRlci1ob3N0IHtcbiAgICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgICAgcGFkZGluZzogOHB4O1xuICAgICAgYm9yZGVyOiAxcHggc29saWQgZ3JlZW47XG4gICAgICBpbmxpbmUtc2l6ZTogMjUwcHg7XG4gICAgICBibG9jay1zaXplOiA1MHB4O1xuICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gICAgfVxuICBgLFxufSlcbmV4cG9ydCBjbGFzcyBOZXdCcmFja2V0RGVmYXVsdFJvdW5kSGVhZGVyQ29tcG9uZW50PFRSb3VuZERhdGEgPSB1bmtub3duLCBUTWF0Y2hEYXRhID0gdW5rbm93bj4ge1xuICBicmFja2V0Um91bmQgPSBpbnB1dC5yZXF1aXJlZDxCcmFja2V0Um91bmQ8VFJvdW5kRGF0YSwgVE1hdGNoRGF0YT4+KCk7XG59XG4iXX0=
@@ -0,0 +1,54 @@
1
+ import { NgComponentOutlet } from '@angular/common';
2
+ import { booleanAttribute, ChangeDetectionStrategy, Component, computed, inject, input, numberAttribute, ViewEncapsulation, } from '@angular/core';
3
+ import { DomSanitizer } from '@angular/platform-browser';
4
+ import { generateBracketRoundSwissGroupMaps, generateBracketRoundTypeMap, generateMatchParticipantMap, generateMatchPositionMaps, generateMatchRelations, generateRoundRelations, } from './bracket-new';
5
+ import { drawMan } from './draw-man';
6
+ import { generateBracketGridDefinitions } from './grid-definitions';
7
+ import { generateBracketGridItems } from './grid-placements';
8
+ import * as i0 from "@angular/core";
9
+ export class NewBracketComponent {
10
+ constructor() {
11
+ this.#domSanitizer = inject(DomSanitizer);
12
+ this.bracketData = input.required();
13
+ this.columnWidth = input(250, { transform: numberAttribute });
14
+ this.matchHeight = input(75, { transform: numberAttribute });
15
+ this.roundHeaderHeight = input(50, { transform: numberAttribute });
16
+ this.columnGap = input(60, { transform: numberAttribute });
17
+ this.rowGap = input(30, { transform: numberAttribute });
18
+ this.hideRoundHeaders = input(false, { transform: booleanAttribute });
19
+ this.roundHeaderComponent = input();
20
+ this.matchComponent = input();
21
+ this.roundTypeMap = computed(() => generateBracketRoundTypeMap(this.bracketData()));
22
+ this.matchParticipantMap = computed(() => generateMatchParticipantMap(this.bracketData()));
23
+ this.matchPositionsMap = computed(() => generateMatchPositionMaps(this.bracketData()));
24
+ this.roundRelations = computed(() => generateRoundRelations(this.bracketData()));
25
+ this.matchRelations = computed(() => generateMatchRelations(this.bracketData(), this.roundRelations(), this.matchPositionsMap()));
26
+ this.swissGroups = computed(() => generateBracketRoundSwissGroupMaps(this.bracketData(), this.matchParticipantMap()));
27
+ this.items = computed(() => generateBracketGridItems(this.bracketData(), this.roundTypeMap(), this.swissGroups(), this.roundRelations(), this.matchRelations(), {
28
+ includeRoundHeaders: !this.hideRoundHeaders(),
29
+ headerComponent: this.roundHeaderComponent(),
30
+ matchComponent: this.matchComponent(),
31
+ }));
32
+ this.definitions = computed(() => generateBracketGridDefinitions(this.bracketData(), this.roundTypeMap(), {
33
+ includeRoundHeaders: !this.hideRoundHeaders(),
34
+ }));
35
+ this.drawManData = computed(() => this.#domSanitizer.bypassSecurityTrustHtml(drawMan(this.items(), this.roundRelations(), {
36
+ columnGap: this.columnGap(),
37
+ columnWidth: this.columnWidth(),
38
+ matchHeight: this.matchHeight(),
39
+ roundHeaderHeight: this.hideRoundHeaders() ? 0 : this.roundHeaderHeight(),
40
+ rowGap: this.rowGap(),
41
+ gridDefinitions: this.definitions(),
42
+ })));
43
+ }
44
+ #domSanitizer;
45
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NewBracketComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
46
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: NewBracketComponent, isStandalone: true, selector: "et-new-bracket", inputs: { bracketData: { classPropertyName: "bracketData", publicName: "bracketData", 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 }, 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.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", styles: [".et-bracket-new{display:grid;gap:var(--_cg);grid-auto-columns:var(--_cw)}.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%}\n"], dependencies: [{ kind: "directive", type: NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
47
+ }
48
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NewBracketComponent, decorators: [{
49
+ type: Component,
50
+ args: [{ selector: 'et-new-bracket', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
51
+ 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.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", styles: [".et-bracket-new{display:grid;gap:var(--_cg);grid-auto-columns:var(--_cw)}.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%}\n"] }]
53
+ }] });
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"]}
@@ -1,5 +1,6 @@
1
1
  export * from '../bracket.imports';
2
2
  export * from '../components/bracket';
3
+ export * as BracketNew from '../components/new-bracket';
3
4
  export * from '../constants';
4
5
  export * from '../directives/bracket-match';
5
6
  export * from '../directives/bracket-round';
@@ -7,4 +8,4 @@ export * from '../partials/bracket-match';
7
8
  export * from '../partials/bracket-round-header';
8
9
  export * from '../types';
9
10
  export * from '../utils';
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2Nkay9zcmMvbGliL2NvbXBvbmVudHMvYnJhY2tldC9wdWJsaWMtYXBpL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsVUFBVSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi4vYnJhY2tldC5pbXBvcnRzJztcbmV4cG9ydCAqIGZyb20gJy4uL2NvbXBvbmVudHMvYnJhY2tldCc7XG5leHBvcnQgKiBmcm9tICcuLi9jb25zdGFudHMnO1xuZXhwb3J0ICogZnJvbSAnLi4vZGlyZWN0aXZlcy9icmFja2V0LW1hdGNoJztcbmV4cG9ydCAqIGZyb20gJy4uL2RpcmVjdGl2ZXMvYnJhY2tldC1yb3VuZCc7XG5leHBvcnQgKiBmcm9tICcuLi9wYXJ0aWFscy9icmFja2V0LW1hdGNoJztcbmV4cG9ydCAqIGZyb20gJy4uL3BhcnRpYWxzL2JyYWNrZXQtcm91bmQtaGVhZGVyJztcbmV4cG9ydCAqIGZyb20gJy4uL3R5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4uL3V0aWxzJztcbiJdfQ==
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2Nkay9zcmMvbGliL2NvbXBvbmVudHMvYnJhY2tldC9wdWJsaWMtYXBpL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxPQUFPLEtBQUssVUFBVSxNQUFNLDJCQUEyQixDQUFDO0FBQ3hELGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxVQUFVLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuLi9icmFja2V0LmltcG9ydHMnO1xuZXhwb3J0ICogZnJvbSAnLi4vY29tcG9uZW50cy9icmFja2V0JztcbmV4cG9ydCAqIGFzIEJyYWNrZXROZXcgZnJvbSAnLi4vY29tcG9uZW50cy9uZXctYnJhY2tldCc7XG5leHBvcnQgKiBmcm9tICcuLi9jb25zdGFudHMnO1xuZXhwb3J0ICogZnJvbSAnLi4vZGlyZWN0aXZlcy9icmFja2V0LW1hdGNoJztcbmV4cG9ydCAqIGZyb20gJy4uL2RpcmVjdGl2ZXMvYnJhY2tldC1yb3VuZCc7XG5leHBvcnQgKiBmcm9tICcuLi9wYXJ0aWFscy9icmFja2V0LW1hdGNoJztcbmV4cG9ydCAqIGZyb20gJy4uL3BhcnRpYWxzL2JyYWNrZXQtcm91bmQtaGVhZGVyJztcbmV4cG9ydCAqIGZyb20gJy4uL3R5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4uL3V0aWxzJztcbiJdfQ==