I am tired to represent data row, column-wise like attach an image .
condition:
- Representation data similar next to in a column when overflow column then represent by row,
- When next data is more than column Y-axis max and then X-axis representation.
- If the blue over the previous Y-axis value then X and then Y
Here the example code: Codesandbox.io or
var data = { game_results: [ { game_number: "1", winner: "red" }, { game_number: "2", winner: "red" }, { game_number: "3", winner: "red" }, { game_number: "4", winner: "red" }, { game_number: "5", winner: "red" }, { game_number: "6", winner: "red" }, { game_number: "7", winner: "red" }, { game_number: "8", winner: "red" }, { game_number: "9", winner: "red" }, { game_number: "10", winner: "red" }, { game_number: "11", winner: "blue" }, { game_number: "12", winner: "blue" }, { game_number: "13", winner: "red" }, { game_number: "14", winner: "red" }, { game_number: "15", winner: "red" }, { game_number: "16", winner: "blue" }, { game_number: "17", winner: "blue" }, { game_number: "18", winner: "blue" }, { game_number: "19", winner: "blue" }, { game_number: "20", winner: "blue" }, { game_number: "21", winner: "blue" }, { game_number: "22", winner: "red" }, { game_number: "23", winner: "blue" }, { game_number: "24", winner: "blue" }, { game_number: "25", winner: "blue" }, { game_number: "26", winner: "blue" }, { game_number: "27", winner: "blue" }, { game_number: "28", winner: "blue" }, { game_number: "30", winner: "blue" }, { game_number: "31", winner: "red" }, { game_number: "32", winner: "red" }, { game_number: "33", winner: "red" }, { game_number: "34", winner: "red" }, { game_number: "35", winner: "blue" } ] }; var width = 50, height = 50; var overflow1 = false; var prevState = data.game_results[0].winner; var regularx = 0, regularY = 0, x2 = 0, y2 = 6, xMax = 0; console.log("result ", data.game_results.length); for (i = 1; i <= data.game_results.length || 0; i++) { if (!(data.game_results[i - 1].winner == prevState)) { prevState = data.game_results[i - 1].winner; regularY = 0; x2 += 1; regularx = x2; xMax += 1; if (overflow1) { y2 -= 1; } } var _top = regularY * height; var _left = regularx * width; if (regularx == 0) { _left = 0; } if (regularY == 0) { _top = 0; } if (overflow1) { overflow1 = false; } if (regularY == y2) { overflow1 = true; regularY = y2 - 1; regularx += 1; _top = (y2 - 1) * height; _left = regularx * width; } $(".box__inner").append( '<div class="box '+ data.game_results[i - 1].winner+'" style="top:' + _top + "px; left:" + _left + "px; background: " + 'transparent'+ ' "></div>' ); regularY += 1; }
*:before, *:after, * { box-sizing: border-box; margin: 0; padding: 0; } .box-outer { border: 1px solid #ddd; overflow: auto; } .box__inner { height: 300px; position: relative; min-width: 100%; background: url(); } .box { position: absolute; left: 0; top: 0; width: 50px; height: 50px; border-radius: 50%; background: #fff; border: 5px solid transparent; } .box:before, .box:after { content: ''; display: block; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 20px; height: 20px; border-radius: 50%; z-index: 1; background: #fff; } .box:before { width: 45px; height: 45px; background: red } .box.red:before { background: red; } .box.blue:before { background: blue; }
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <div class="box-outer"> <div class="box__inner"> <!-- <div class="box"></div> --> </div> </div>
Answer
var data = { game_results: [ { game_number: "1", winner: "red" }, { game_number: "2", winner: "red" }, { game_number: "3", winner: "red" }, { game_number: "4", winner: "red" }, { game_number: "5", winner: "red" }, { game_number: "6", winner: "red" }, { game_number: "7", winner: "red" }, { game_number: "8", winner: "red" }, { game_number: "9", winner: "red" }, { game_number: "10", winner: "red" }, { game_number: "11", winner: "blue" }, { game_number: "12", winner: "blue" }, { game_number: "13", winner: "red" }, { game_number: "14", winner: "red" }, { game_number: "15", winner: "red" }, { game_number: "16", winner: "blue" }, { game_number: "17", winner: "blue" }, { game_number: "18", winner: "blue" }, { game_number: "19", winner: "blue" }, { game_number: "20", winner: "blue" }, { game_number: "21", winner: "blue" }, { game_number: "22", winner: "red" }, { game_number: "23", winner: "blue" }, { game_number: "24", winner: "blue" }, { game_number: "25", winner: "blue" }, { game_number: "26", winner: "blue" }, { game_number: "27", winner: "blue" }, { game_number: "28", winner: "blue" }, { game_number: "30", winner: "blue" }, { game_number: "31", winner: "red" }, { game_number: "32", winner: "red" }, { game_number: "33", winner: "red" }, { game_number: "34", winner: "red" }, { game_number: "35", winner: "blue" } ] }; $(document).ready(async function () { await renderGameObject(); }); var visitedDataSet = []; async function renderGameObject() { var width = 50, height = 50; var regularx = 0, ymax = 6; let _top = -1; let _left = 0; let xCordCompleted = -1; let previousColor = ""; //for loop to render the element for (const r of data.game_results) { //Reset the color/state: if (previousColor != r.winner) { previousColor = r.winner; xCordCompleted = xCordCompleted + 1; _top = -1; _left = xCordCompleted; } //calculate that last position if (_top === ymax - 1) { regularx += 1; _left = regularx; var cordinate = await checkAvailablePosition(_left, _top); _left = cordinate.xCod; _top = cordinate.yCod; } else { _top = _top + 1; var cordinate1 = await checkAvailablePosition(_left, _top); _left = cordinate1.xCod; _top = cordinate1.yCod; } // stored the visited coordinate visitedDataSet.push({ x: _left, y: _top }); $(".box__inner").append( '<div class="box ' + r.winner + '" style="top:' + _top * width + "px; left:" + _left * height + "px; background: " + "transparent" + ' "></div>' ); } } async function checkAvailablePosition(xCod, yCod) { let existingData = (await visitedDataSet.filter((r) => r.x === xCod && r.y === yCod)) || []; if (existingData.length > 0) { //console.log("existing:", existingData); // if ( ( (await visitedDataSet.filter( (r) => r.x === xCod + 1 && r.y === yCod - 1 )) || [] ).length > 0 ) { return { xCod: xCod + 1, yCod: yCod + 1 }; } else { return { xCod: xCod + 1, yCod: yCod - 1 }; } } else { return { xCod: xCod, yCod: yCod }; } }
*:before, *:after, * { box-sizing: border-box; margin: 0; padding: 0; } .box-outer { border: 1px solid #ddd; overflow: auto; } .box__inner { height: 300px; position: relative; min-width: 100%; background: url(); } .box { position: absolute; left: 0; top: 0; width: 50px; height: 50px; border-radius: 50%; background: #fff; border: 5px solid transparent; } .box:before, .box:after { content: ''; display: block; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 20px; height: 20px; border-radius: 50%; z-index: 1; background: #fff; } .box:before { width: 45px; height: 45px; background: red } .box.red:before { background: red; } .box.blue:before { background: blue; }
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <div class="box-outer"> <div class="box__inner"> <!-- <div class="box"></div> --> </div> </div>
Could you check the code from the link, I have stored the visited co-ordinate and checked the visited path so that we can change the logic.