UNPKG

chessground-haichess

Version:
79 lines 11.2 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.bindDocument = exports.bindBoard = void 0; const drag = require("./drag"); const draw = require("./draw"); const drop_1 = require("./drop"); const util_1 = require("./util"); function bindBoard(s, boundsUpdated) { const boardEl = s.dom.elements.board; if (!s.dom.relative && s.resizable && 'ResizeObserver' in window) { const observer = new window['ResizeObserver'](boundsUpdated); observer.observe(boardEl); } if (s.viewOnly) return; const onStart = startDragOrDraw(s); boardEl.addEventListener('touchstart', onStart, { passive: false, }); boardEl.addEventListener('mousedown', onStart, { passive: false, }); if (s.disableContextMenu || s.drawable.enabled) { boardEl.addEventListener('contextmenu', e => e.preventDefault()); } } exports.bindBoard = bindBoard; function bindDocument(s, boundsUpdated) { const unbinds = []; if (!s.dom.relative && s.resizable && !('ResizeObserver' in window)) { unbinds.push(unbindable(document.body, 'chessground.resize', boundsUpdated)); } if (!s.viewOnly) { const onmove = dragOrDraw(s, drag.move, draw.move); const onend = dragOrDraw(s, drag.end, draw.end); for (const ev of ['touchmove', 'mousemove']) unbinds.push(unbindable(document, ev, onmove)); for (const ev of ['touchend', 'mouseup']) unbinds.push(unbindable(document, ev, onend)); const onScroll = () => s.dom.bounds.clear(); unbinds.push(unbindable(document, 'scroll', onScroll, { capture: true, passive: true })); unbinds.push(unbindable(window, 'resize', onScroll, { passive: true })); } return () => unbinds.forEach(f => f()); } exports.bindDocument = bindDocument; function unbindable(el, eventName, callback, options) { el.addEventListener(eventName, callback, options); return () => el.removeEventListener(eventName, callback, options); } function startDragOrDraw(s) { return e => { if (s.draggable.current) drag.cancel(s); else if (s.drawable.current) draw.cancel(s); else if (e.shiftKey || util_1.isRightButton(e)) { if (s.drawable.enabled) draw.start(s, e); } else if (!s.viewOnly) { if (s.dropmode.active) drop_1.drop(s, e); else drag.start(s, e); } }; } function dragOrDraw(s, withDrag, withDraw) { return e => { if (s.drawable.current) { if (s.drawable.enabled) withDraw(s, e); } else if (!s.viewOnly) withDrag(s, e); }; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"events.js","sourceRoot":"","sources":["src/events.ts"],"names":[],"mappings":";;;AACA,+BAA+B;AAC/B,+BAA+B;AAC/B,iCAA8B;AAC9B,iCAAuC;AAMvC,SAAgB,SAAS,CAAC,CAAQ,EAAE,aAAyB;IAC3D,MAAM,OAAO,GAAG,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC;IAErC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,IAAI,CAAC,CAAC,SAAS,IAAI,gBAAgB,IAAI,MAAM,EAAE;QAChE,MAAM,QAAQ,GAAG,IAAK,MAAc,CAAC,gBAAgB,CAAC,CAAC,aAAa,CAAC,CAAC;QACtE,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;KAC3B;IAED,IAAI,CAAC,CAAC,QAAQ;QAAE,OAAO;IAIvB,MAAM,OAAO,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC;IACnC,OAAO,CAAC,gBAAgB,CAAC,YAAY,EAAE,OAAwB,EAAE;QAC/D,OAAO,EAAE,KAAK;KACf,CAAC,CAAC;IACH,OAAO,CAAC,gBAAgB,CAAC,WAAW,EAAE,OAAwB,EAAE;QAC9D,OAAO,EAAE,KAAK;KACf,CAAC,CAAC;IAEH,IAAI,CAAC,CAAC,kBAAkB,IAAI,CAAC,CAAC,QAAQ,CAAC,OAAO,EAAE;QAC9C,OAAO,CAAC,gBAAgB,CAAC,aAAa,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,EAAE,CAAC,CAAC;KAClE;AACH,CAAC;AAvBD,8BAuBC;AAGD,SAAgB,YAAY,CAAC,CAAQ,EAAE,aAAyB;IAC9D,MAAM,OAAO,GAAgB,EAAE,CAAC;IAIhC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,IAAI,CAAC,CAAC,SAAS,IAAI,CAAC,CAAC,gBAAgB,IAAI,MAAM,CAAC,EAAE;QACnE,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,EAAE,oBAAoB,EAAE,aAAa,CAAC,CAAC,CAAC;KAC9E;IAED,IAAI,CAAC,CAAC,CAAC,QAAQ,EAAE;QACf,MAAM,MAAM,GAAG,UAAU,CAAC,CAAC,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;QACnD,MAAM,KAAK,GAAG,UAAU,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;QAEhD,KAAK,MAAM,EAAE,IAAI,CAAC,WAAW,EAAE,WAAW,CAAC;YAAE,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,EAAE,EAAE,MAAuB,CAAC,CAAC,CAAC;QAC7G,KAAK,MAAM,EAAE,IAAI,CAAC,UAAU,EAAE,SAAS,CAAC;YAAE,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,EAAE,EAAE,KAAsB,CAAC,CAAC,CAAC;QAEzG,MAAM,QAAQ,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;QAC5C,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;QACzF,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;KACzE;IAED,OAAO,GAAG,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;AACzC,CAAC;AAtBD,oCAsBC;AAED,SAAS,UAAU,CACjB,EAAe,EACf,SAAiB,EACjB,QAAuB,EACvB,OAAiC;IAEjC,EAAE,CAAC,gBAAgB,CAAC,SAAS,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;IAClD,OAAO,GAAG,EAAE,CAAC,EAAE,CAAC,mBAAmB,CAAC,SAAS,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;AACpE,CAAC;AAED,SAAS,eAAe,CAAC,CAAQ;IAC/B,OAAO,CAAC,CAAC,EAAE;QACT,IAAI,CAAC,CAAC,SAAS,CAAC,OAAO;YAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;aACnC,IAAI,CAAC,CAAC,QAAQ,CAAC,OAAO;YAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;aACvC,IAAI,CAAC,CAAC,QAAQ,IAAI,oBAAa,CAAC,CAAC,CAAC,EAAE;YACvC,IAAI,CAAC,CAAC,QAAQ,CAAC,OAAO;gBAAE,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;SAC1C;aAAM,IAAI,CAAC,CAAC,CAAC,QAAQ,EAAE;YACtB,IAAI,CAAC,CAAC,QAAQ,CAAC,MAAM;gBAAE,WAAI,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;;gBAC7B,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;SACvB;IACH,CAAC,CAAC;AACJ,CAAC;AAED,SAAS,UAAU,CAAC,CAAQ,EAAE,QAAwB,EAAE,QAAwB;IAC9E,OAAO,CAAC,CAAC,EAAE;QACT,IAAI,CAAC,CAAC,QAAQ,CAAC,OAAO,EAAE;YACtB,IAAI,CAAC,CAAC,QAAQ,CAAC,OAAO;gBAAE,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;SACxC;aAAM,IAAI,CAAC,CAAC,CAAC,QAAQ;YAAE,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACzC,CAAC,CAAC;AACJ,CAAC","sourcesContent":["import { State } from './state';\nimport * as drag from './drag';\nimport * as draw from './draw';\nimport { drop } from './drop';\nimport { isRightButton } from './util';\nimport * as cg from './types';\n\ntype MouchBind = (e: cg.MouchEvent) => void;\ntype StateMouchBind = (d: State, e: cg.MouchEvent) => void;\n\nexport function bindBoard(s: State, boundsUpdated: () => void): void {\n  const boardEl = s.dom.elements.board;\n\n  if (!s.dom.relative && s.resizable && 'ResizeObserver' in window) {\n    const observer = new (window as any)['ResizeObserver'](boundsUpdated);\n    observer.observe(boardEl);\n  }\n\n  if (s.viewOnly) return;\n\n  // Cannot be passive, because we prevent touch scrolling and dragging of\n  // selected elements.\n  const onStart = startDragOrDraw(s);\n  boardEl.addEventListener('touchstart', onStart as EventListener, {\n    passive: false,\n  });\n  boardEl.addEventListener('mousedown', onStart as EventListener, {\n    passive: false,\n  });\n\n  if (s.disableContextMenu || s.drawable.enabled) {\n    boardEl.addEventListener('contextmenu', e => e.preventDefault());\n  }\n}\n\n// returns the unbind function\nexport function bindDocument(s: State, boundsUpdated: () => void): cg.Unbind {\n  const unbinds: cg.Unbind[] = [];\n\n  // Old versions of Edge and Safari do not support ResizeObserver. Send\n  // chessground.resize if a user action has changed the bounds of the board.\n  if (!s.dom.relative && s.resizable && !('ResizeObserver' in window)) {\n    unbinds.push(unbindable(document.body, 'chessground.resize', boundsUpdated));\n  }\n\n  if (!s.viewOnly) {\n    const onmove = dragOrDraw(s, drag.move, draw.move);\n    const onend = dragOrDraw(s, drag.end, draw.end);\n\n    for (const ev of ['touchmove', 'mousemove']) unbinds.push(unbindable(document, ev, onmove as EventListener));\n    for (const ev of ['touchend', 'mouseup']) unbinds.push(unbindable(document, ev, onend as EventListener));\n\n    const onScroll = () => s.dom.bounds.clear();\n    unbinds.push(unbindable(document, 'scroll', onScroll, { capture: true, passive: true }));\n    unbinds.push(unbindable(window, 'resize', onScroll, { passive: true }));\n  }\n\n  return () => unbinds.forEach(f => f());\n}\n\nfunction unbindable(\n  el: EventTarget,\n  eventName: string,\n  callback: EventListener,\n  options?: AddEventListenerOptions\n): cg.Unbind {\n  el.addEventListener(eventName, callback, options);\n  return () => el.removeEventListener(eventName, callback, options);\n}\n\nfunction startDragOrDraw(s: State): MouchBind {\n  return e => {\n    if (s.draggable.current) drag.cancel(s);\n    else if (s.drawable.current) draw.cancel(s);\n    else if (e.shiftKey || isRightButton(e)) {\n      if (s.drawable.enabled) draw.start(s, e);\n    } else if (!s.viewOnly) {\n      if (s.dropmode.active) drop(s, e);\n      else drag.start(s, e);\n    }\n  };\n}\n\nfunction dragOrDraw(s: State, withDrag: StateMouchBind, withDraw: StateMouchBind): MouchBind {\n  return e => {\n    if (s.drawable.current) {\n      if (s.drawable.enabled) withDraw(s, e);\n    } else if (!s.viewOnly) withDrag(s, e);\n  };\n}\n"]}