ui.js 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. var UI_CELLS = [];
  2. function dCreate(domName) {
  3. return document.createElement(domName);
  4. }
  5. function uiCreateCell(cellData) {
  6. var cell = dCreate("div");
  7. cell.className = R.klass.cell.item;
  8. if (cellData.isBlack) {
  9. cell.classList.add(R.klass.cell.black);
  10. } else if (cellData.definitions !== null) {
  11. cell.classList.add(R.klass.cell.definition);
  12. var cellContent =dCreate("span");
  13. cellData.definitions.forEach(function(definition) {
  14. var domDefinition = dCreate("span");
  15. domDefinition.className = R.klass.cell.definitions.item;
  16. domDefinition.innerHTML = definition.text.join("<br/>");
  17. cellContent.appendChild(domDefinition);
  18. });
  19. cell.appendChild(cellContent);
  20. } else {
  21. cell.classList.add(R.klass.cell.letter);
  22. }
  23. return cell;
  24. }
  25. function uiCreateGrid() {
  26. var frag = document.createDocumentFragment();
  27. for (var i =0; i < GRID.height; i++) {
  28. var line = dCreate("div");
  29. line.className = R.klass.line;
  30. frag.appendChild(line);
  31. for (var j =0; j < GRID.width; j++) {
  32. var cell = uiCreateCell(GRID.grid[j][i]);
  33. cell.dataset.x = j;
  34. cell.dataset.y = i;
  35. line.appendChild(cell);
  36. UI_CELLS.push({
  37. x: j
  38. ,y: i
  39. ,dom: cell
  40. ,data: GRID.grid[j][i]
  41. });
  42. }
  43. }
  44. for (var i =0; i < GRID.height; i++) {
  45. for (var j =0; j < GRID.width; j++) {
  46. var cell = UI_CELLS[i *GRID.width +j];
  47. if (cell.data.definitions) {
  48. cell.data.definitions.forEach(function(d) {
  49. switch (d.direction) {
  50. case Definition.RIGHT_VERTICAL:
  51. UI_CELLS[i *GRID.width +j +1].dom.classList.add(R.klass.cell.definitions.rightVertical);
  52. break;
  53. case Definition.RIGHT_HORIZONTAL:
  54. UI_CELLS[i *GRID.width +j +1].dom.classList.add(R.klass.cell.definitions.rightHorizontal);
  55. break;
  56. case Definition.BOTTOM_VERTICAL:
  57. UI_CELLS[(i +1) *GRID.width +j].dom.classList.add(R.klass.cell.definitions.bottomVertical);
  58. break;
  59. case Definition.BOTTOM_HORIZONTAL:
  60. UI_CELLS[(i +1) *GRID.width +j].dom.classList.add(R.klass.cell.definitions.bottomHorizontal);
  61. break;
  62. }
  63. });
  64. }
  65. }
  66. }
  67. document.body.textContent = "";
  68. document.body.appendChild(frag);
  69. }
  70. function onGridUpdated() {
  71. UI_CELLS.forEach(function(i) {
  72. if (!i.data.definitions && !i.data.isBlack) {
  73. //TODO
  74. }
  75. });
  76. }
  77. function gridClickDelegate(e) {
  78. var target = e.target;
  79. while (target && !target.classList.contains(R.klass.cell.item))
  80. target = target.parentElement;
  81. if (target && target.dataset && target.dataset.x && target.dataset.y) {
  82. var clickedCell = UI_CELLS[parseInt(target.dataset.x, 10) +parseInt(target.dataset.y, 10) *GRID.width];
  83. if (clickedCell.data.isBlack) {
  84. unselect();
  85. } else if (clickedCell.data.definitions) {
  86. var first = true;
  87. unselect();
  88. if (clickedCell.data.definitions.length) {
  89. clickedCell.data.definitions[0].word.forEach(function(coordinates) {
  90. select(coordinates[0], coordinates[1]);
  91. if (first) {
  92. CURRENTINPUT = UI_CELLS[coordinates[0] +coordinates[1] *GRID.width];
  93. CURRENTINPUT.dom.classList.add(R.klass.cell.currentInput);
  94. first = false;
  95. }
  96. });
  97. }
  98. } else {
  99. var words = GRID.getWord(clickedCell.x, clickedCell.y);
  100. unselect();
  101. words.forEach(function (word) {
  102. word.forEach(function (coordinates) {
  103. select(coordinates[0], coordinates[1]);
  104. });
  105. });
  106. target.classList.add(R.klass.cell.currentInput);
  107. CURRENTINPUT = clickedCell;
  108. }
  109. }
  110. }