From 2a223fe58bddf32cebeb2ce75d7e1f23b2bddd28 Mon Sep 17 00:00:00 2001 From: Stefan Hanauska Date: Sun, 7 Jan 2024 21:27:47 +0100 Subject: [PATCH] MBS-8586: Simplify horizontal scrolling --- amd/build/board.min.js | 2 +- amd/build/board.min.js.map | 2 +- amd/build/selectors.min.js | 2 +- amd/build/selectors.min.js.map | 2 +- amd/src/board.js | 47 ++++++++++++++++++++++++++++++++++ amd/src/selectors.js | 3 +++ styles.css | 27 +++++++++++++++++++ templates/board.mustache | 6 +++++ 8 files changed, 87 insertions(+), 4 deletions(-) diff --git a/amd/build/board.min.js b/amd/build/board.min.js index 417a206d..e5099873 100644 --- a/amd/build/board.min.js +++ b/amd/build/board.min.js @@ -1,3 +1,3 @@ -define("mod_kanban/board",["exports","core/reactive","mod_kanban/selectors","mod_kanban/capabilities","mod_kanban/exporter","mod_kanban/kanbancomponent","core/log","core/notification","core/str"],(function(_exports,_reactive,_selectors,_capabilities,_exporter,_kanbancomponent,_log,_notification,Str){function _getRequireWildcardCache(nodeInterop){if("function"!=typeof WeakMap)return null;var cacheBabelInterop=new WeakMap,cacheNodeInterop=new WeakMap;return(_getRequireWildcardCache=function(nodeInterop){return nodeInterop?cacheNodeInterop:cacheBabelInterop})(nodeInterop)}function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}function _defineProperty(obj,key,value){return key in obj?Object.defineProperty(obj,key,{value:value,enumerable:!0,configurable:!0,writable:!0}):obj[key]=value,obj}Object.defineProperty(_exports,"__esModule",{value:!0}),_exports.default=void 0,_selectors=_interopRequireDefault(_selectors),_capabilities=_interopRequireDefault(_capabilities),_exporter=_interopRequireDefault(_exporter),_kanbancomponent=_interopRequireDefault(_kanbancomponent),_log=_interopRequireDefault(_log),Str=function(obj,nodeInterop){if(!nodeInterop&&obj&&obj.__esModule)return obj;if(null===obj||"object"!=typeof obj&&"function"!=typeof obj)return{default:obj};var cache=_getRequireWildcardCache(nodeInterop);if(cache&&cache.has(obj))return cache.get(obj);var newObj={},hasPropertyDescriptor=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var key in obj)if("default"!==key&&Object.prototype.hasOwnProperty.call(obj,key)){var desc=hasPropertyDescriptor?Object.getOwnPropertyDescriptor(obj,key):null;desc&&(desc.get||desc.set)?Object.defineProperty(newObj,key,desc):newObj[key]=obj[key]}newObj.default=obj,cache&&cache.set(obj,newObj);return newObj}(Str);class _default extends _kanbancomponent.default{constructor(){super(...arguments),_defineProperty(this,"LOCKED_COLUMNS",1),_defineProperty(this,"LOCKED_COMPLETE",2)}static init(target){return new this({element:document.getElementById(target)})}create(){this.cmid=this.element.dataset.cmid,this.id=this.element.dataset.id}getWatchers(){return[{watch:"board:updated",handler:this._boardUpdated},{watch:"columns:created",handler:this._columnCreated},{watch:"board:deleted",handler:this._reload},{watch:"common:updated",handler:this._commonUpdated}]}async stateReady(state){this.addEventListener(this.getElement(_selectors.default.ADDCOLUMNFIRST),"click",this._addColumn),1==state.capabilities.get(_capabilities.default.MANAGEBOARD).value&&(this.addEventListener(this.getElement(_selectors.default.LOCKBOARDCOLUMNS),"click",this._lockColumns),this.addEventListener(this.getElement(_selectors.default.UNLOCKBOARDCOLUMNS),"click",this._unlockColumns),this.addEventListener(this.getElement(_selectors.default.SAVEASTEMPLATE),"click",this._templateConfirm),this.addEventListener(this.getElement(_selectors.default.SHOWTEMPLATE),"click",this._showTemplate),this.addEventListener(this.getElement(_selectors.default.DELETETEMPLATE),"click",this._deleteTemplateConfirm)),this.addEventListener(this.getElement(_selectors.default.DELETEBOARD),"click",this._deleteConfirm),this.dragdrop=new _reactive.DragDrop(this),state.common.liveupdate>0&&this._continuousUpdate(state.common.liveupdate),this.toggleClass("ontouchstart"in document.documentElement,"mod_kanban_touch")}_showTemplate(){window.location.href=M.cfg.wwwroot+"/mod/kanban/view.php?id="+this.reactive.state.common.id+"&boardid="+this.reactive.state.common.template}_reload(){window.location.replace(M.cfg.wwwroot+"/mod/kanban/view.php?id="+this.reactive.state.common.id+"&userid="+this.reactive.state.common.userid)}_continuousUpdate(){setInterval((()=>{this.reactive.dispatch("getUpdates")}),1e3*(arguments.length>0&&void 0!==arguments[0]?arguments[0]:10))}_commonUpdated(_ref){let{element:element}=_ref;this.toggleClass(0!=element.template,"mod_kanban_hastemplate")}destroy(){void 0!==this.dragdrop&&this.dragdrop.unregister(),this._reload()}_templateConfirm(){Str.get_strings([{key:"saveastemplate",component:"mod_kanban"},{key:"saveastemplateconfirm",component:"mod_kanban"},{key:"save",component:"core"}]).then((strings=>(0,_notification.saveCancel)(strings[0],strings[1],strings[2],(()=>{this._saveAsTemplate()})))).catch((error=>_log.default.debug(error)))}_saveAsTemplate(){this.reactive.dispatch("saveAsTemplate")}_deleteConfirm(){Str.get_strings([{key:"deleteboard",component:"mod_kanban"},{key:"deleteboardconfirm",component:"mod_kanban"},{key:"delete",component:"core"}]).then((strings=>(0,_notification.saveCancel)(strings[0],strings[1],strings[2],(()=>{this._deleteBoard()})))).catch((error=>_log.default.debug(error)))}_deleteTemplateConfirm(){Str.get_strings([{key:"deletetemplate",component:"mod_kanban"},{key:"deletetemplateconfirm",component:"mod_kanban"},{key:"delete",component:"core"}]).then((strings=>(0,_notification.saveCancel)(strings[0],strings[1],strings[2],(()=>{this._deleteBoard()})))).catch((error=>_log.default.debug(error)))}_deleteBoard(){this.reactive.dispatch("deleteBoard")}_boardUpdated(_ref2){let{element:element}=_ref2;const colcontainer=this.getElement(_selectors.default.COLUMNCONTAINER);if(void 0!==element.sequence){let sequence=element.sequence.split(",");[...colcontainer.children].forEach((node=>{node.classList.contains("mod_kanban_column")&&!sequence.includes(node.dataset.id)&&colcontainer.removeChild(node)})),[...colcontainer.children].sort(((a,b)=>sequence.indexOf(a.dataset.id)>sequence.indexOf(b.dataset.id)?1:-1)).forEach((node=>colcontainer.appendChild(node)))}this.toggleClass(element.locked,"mod_kanban_board_locked_columns"),this.toggleClass(element.hastemplate,"mod_kanban_hastemplate")}async _columnCreated(_ref3){let{element:element}=_ref3,data=Object.assign({id:element.id,title:element.title,options:element.options,sequence:element.sequence},_exporter.default.exportCapabilities(this.reactive.state)),placeholder=document.createElement("li");placeholder.setAttribute("data-id",data.id),this.getElement(_selectors.default.COLUMNCONTAINER).appendChild(placeholder);const newelement=(await this.renderComponent(placeholder,"mod_kanban/column",data)).getElement();this.getElement(_selectors.default.COLUMNCONTAINER).replaceChild(newelement,placeholder)}_addColumn(){document.activeElement.blur(),this.reactive.dispatch("addColumn",0)}_lockColumns(){this.reactive.dispatch("lockColumns")}_unlockColumns(){this.reactive.dispatch("unlockColumns")}validateDropData(dropdata){return"column"==(null==dropdata?void 0:dropdata.type)}drop(dropdata){this.reactive.dispatch("moveColumn",dropdata.id,0)}showDropZone(){this.getElement(_selectors.default.ADDCOLUMNCONTAINER).classList.add("mod_kanban_insert")}hideDropZone(){this.getElement(_selectors.default.ADDCOLUMNCONTAINER).classList.remove("mod_kanban_insert")}}return _exports.default=_default,_exports.default})); +define("mod_kanban/board",["exports","core/reactive","mod_kanban/selectors","mod_kanban/capabilities","mod_kanban/exporter","mod_kanban/kanbancomponent","core/log","core/notification","core/str"],(function(_exports,_reactive,_selectors,_capabilities,_exporter,_kanbancomponent,_log,_notification,Str){function _getRequireWildcardCache(nodeInterop){if("function"!=typeof WeakMap)return null;var cacheBabelInterop=new WeakMap,cacheNodeInterop=new WeakMap;return(_getRequireWildcardCache=function(nodeInterop){return nodeInterop?cacheNodeInterop:cacheBabelInterop})(nodeInterop)}function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}function _defineProperty(obj,key,value){return key in obj?Object.defineProperty(obj,key,{value:value,enumerable:!0,configurable:!0,writable:!0}):obj[key]=value,obj}Object.defineProperty(_exports,"__esModule",{value:!0}),_exports.default=void 0,_selectors=_interopRequireDefault(_selectors),_capabilities=_interopRequireDefault(_capabilities),_exporter=_interopRequireDefault(_exporter),_kanbancomponent=_interopRequireDefault(_kanbancomponent),_log=_interopRequireDefault(_log),Str=function(obj,nodeInterop){if(!nodeInterop&&obj&&obj.__esModule)return obj;if(null===obj||"object"!=typeof obj&&"function"!=typeof obj)return{default:obj};var cache=_getRequireWildcardCache(nodeInterop);if(cache&&cache.has(obj))return cache.get(obj);var newObj={},hasPropertyDescriptor=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var key in obj)if("default"!==key&&Object.prototype.hasOwnProperty.call(obj,key)){var desc=hasPropertyDescriptor?Object.getOwnPropertyDescriptor(obj,key):null;desc&&(desc.get||desc.set)?Object.defineProperty(newObj,key,desc):newObj[key]=obj[key]}newObj.default=obj,cache&&cache.set(obj,newObj);return newObj}(Str);class _default extends _kanbancomponent.default{constructor(){super(...arguments),_defineProperty(this,"LOCKED_COLUMNS",1),_defineProperty(this,"LOCKED_COMPLETE",2)}static init(target){return new this({element:document.getElementById(target)})}create(){this.cmid=this.element.dataset.cmid,this.id=this.element.dataset.id}getWatchers(){return[{watch:"board:updated",handler:this._boardUpdated},{watch:"columns:created",handler:this._columnCreated},{watch:"board:deleted",handler:this._reload},{watch:"common:updated",handler:this._commonUpdated}]}async stateReady(state){this.addEventListener(this.getElement(_selectors.default.ADDCOLUMNFIRST),"click",this._addColumn),1==state.capabilities.get(_capabilities.default.MANAGEBOARD).value&&(this.addEventListener(this.getElement(_selectors.default.LOCKBOARDCOLUMNS),"click",this._lockColumns),this.addEventListener(this.getElement(_selectors.default.UNLOCKBOARDCOLUMNS),"click",this._unlockColumns),this.addEventListener(this.getElement(_selectors.default.SAVEASTEMPLATE),"click",this._templateConfirm),this.addEventListener(this.getElement(_selectors.default.SHOWTEMPLATE),"click",this._showTemplate),this.addEventListener(this.getElement(_selectors.default.DELETETEMPLATE),"click",this._deleteTemplateConfirm)),this.addEventListener(this.getElement(_selectors.default.DELETEBOARD),"click",this._deleteConfirm),this.addEventListener(this.getElement(_selectors.default.SCROLLLEFT),"click",this._scrollLeft),this.addEventListener(this.getElement(_selectors.default.SCROLLRIGHT),"click",this._scrollRight),this.addEventListener(this.getElement(_selectors.default.MAIN),"scroll",this._updateScrollButtons),this.dragdrop=new _reactive.DragDrop(this),state.common.liveupdate>0&&this._continuousUpdate(state.common.liveupdate),this.toggleClass("ontouchstart"in document.documentElement,"mod_kanban_touch"),this._updateScrollButtons()}_showTemplate(){window.location.href=M.cfg.wwwroot+"/mod/kanban/view.php?id="+this.reactive.state.common.id+"&boardid="+this.reactive.state.common.template}_reload(){window.location.replace(M.cfg.wwwroot+"/mod/kanban/view.php?id="+this.reactive.state.common.id+"&userid="+this.reactive.state.common.userid)}_continuousUpdate(){setInterval((()=>{this.reactive.dispatch("getUpdates")}),1e3*(arguments.length>0&&void 0!==arguments[0]?arguments[0]:10))}_commonUpdated(_ref){let{element:element}=_ref;this.toggleClass(0!=element.template,"mod_kanban_hastemplate")}destroy(){void 0!==this.dragdrop&&this.dragdrop.unregister(),this._reload()}_templateConfirm(){Str.get_strings([{key:"saveastemplate",component:"mod_kanban"},{key:"saveastemplateconfirm",component:"mod_kanban"},{key:"save",component:"core"}]).then((strings=>(0,_notification.saveCancel)(strings[0],strings[1],strings[2],(()=>{this._saveAsTemplate()})))).catch((error=>_log.default.debug(error)))}_saveAsTemplate(){this.reactive.dispatch("saveAsTemplate")}_deleteConfirm(){Str.get_strings([{key:"deleteboard",component:"mod_kanban"},{key:"deleteboardconfirm",component:"mod_kanban"},{key:"delete",component:"core"}]).then((strings=>(0,_notification.saveCancel)(strings[0],strings[1],strings[2],(()=>{this._deleteBoard()})))).catch((error=>_log.default.debug(error)))}_deleteTemplateConfirm(){Str.get_strings([{key:"deletetemplate",component:"mod_kanban"},{key:"deletetemplateconfirm",component:"mod_kanban"},{key:"delete",component:"core"}]).then((strings=>(0,_notification.saveCancel)(strings[0],strings[1],strings[2],(()=>{this._deleteBoard()})))).catch((error=>_log.default.debug(error)))}_deleteBoard(){this.reactive.dispatch("deleteBoard")}_boardUpdated(_ref2){let{element:element}=_ref2;const colcontainer=this.getElement(_selectors.default.COLUMNCONTAINER);if(void 0!==element.sequence){let sequence=element.sequence.split(",");[...colcontainer.children].forEach((node=>{node.classList.contains("mod_kanban_column")&&!sequence.includes(node.dataset.id)&&colcontainer.removeChild(node)})),[...colcontainer.children].sort(((a,b)=>sequence.indexOf(a.dataset.id)>sequence.indexOf(b.dataset.id)?1:-1)).forEach((node=>colcontainer.appendChild(node)))}this.toggleClass(element.locked,"mod_kanban_board_locked_columns"),this.toggleClass(element.hastemplate,"mod_kanban_hastemplate")}async _columnCreated(_ref3){let{element:element}=_ref3,data=Object.assign({id:element.id,title:element.title,options:element.options,sequence:element.sequence},_exporter.default.exportCapabilities(this.reactive.state)),placeholder=document.createElement("li");placeholder.setAttribute("data-id",data.id),this.getElement(_selectors.default.COLUMNCONTAINER).appendChild(placeholder);const newelement=(await this.renderComponent(placeholder,"mod_kanban/column",data)).getElement();this.getElement(_selectors.default.COLUMNCONTAINER).replaceChild(newelement,placeholder)}_addColumn(){document.activeElement.blur(),this.reactive.dispatch("addColumn",0)}_lockColumns(){this.reactive.dispatch("lockColumns")}_unlockColumns(){this.reactive.dispatch("unlockColumns")}validateDropData(dropdata){return"column"==(null==dropdata?void 0:dropdata.type)}drop(dropdata){this.reactive.dispatch("moveColumn",dropdata.id,0)}showDropZone(){this.getElement(_selectors.default.ADDCOLUMNCONTAINER).classList.add("mod_kanban_insert")}hideDropZone(){this.getElement(_selectors.default.ADDCOLUMNCONTAINER).classList.remove("mod_kanban_insert")}_scrollLeft(){this.getElement(_selectors.default.MAIN).scrollLeft-=80}_scrollRight(){this.getElement(_selectors.default.MAIN).scrollLeft+=80}_updateScrollButtons(){let main=this.getElement(_selectors.default.MAIN);main.scrollLeft<=1?this.getElement(_selectors.default.SCROLLLEFT).style.setProperty("visibility","hidden"):this.getElement(_selectors.default.SCROLLLEFT).style.setProperty("visibility","visible"),main.scrollLeft 0) {\n this._continuousUpdate(state.common.liveupdate);\n }\n this.toggleClass('ontouchstart' in document.documentElement, 'mod_kanban_touch');\n }\n\n /**\n * Called to show template.\n */\n _showTemplate() {\n window.location.href =\n M.cfg.wwwroot +\n '/mod/kanban/view.php?id=' +\n this.reactive.state.common.id +\n '&boardid=' +\n this.reactive.state.common.template;\n }\n\n /**\n * Reload current page.\n */\n _reload() {\n window.location.replace(\n M.cfg.wwwroot + '/mod/kanban/view.php?id=' + this.reactive.state.common.id +\n '&userid=' + this.reactive.state.common.userid);\n }\n\n /**\n * Start continuous update.\n * @param {number} seconds Seconds between two refresh calls, defaults to 10\n */\n _continuousUpdate(seconds = 10) {\n setInterval(() => {\n this.reactive.dispatch('getUpdates');\n }, seconds * 1000);\n }\n\n /**\n * Called when common data was updated\n * @param {*} param0\n */\n _commonUpdated({element}) {\n this.toggleClass(element.template != 0, 'mod_kanban_hastemplate');\n }\n\n /**\n * Remove all subcomponents dependencies.\n */\n destroy() {\n if (this.dragdrop !== undefined) {\n this.dragdrop.unregister();\n }\n this._reload();\n }\n\n /**\n * Display confirmation modal for saving a board as template.\n */\n _templateConfirm() {\n Str.get_strings([\n {key: 'saveastemplate', component: 'mod_kanban'},\n {key: 'saveastemplateconfirm', component: 'mod_kanban'},\n {key: 'save', component: 'core'},\n ]).then((strings) => {\n return saveCancel(\n strings[0],\n strings[1],\n strings[2],\n () => {\n this._saveAsTemplate();\n }\n );\n }).catch((error) => Log.debug(error));\n }\n\n /**\n * Called when current board should be saved as template.\n */\n _saveAsTemplate() {\n this.reactive.dispatch('saveAsTemplate');\n }\n\n /**\n * Display confirmation modal for deleting a board.\n */\n _deleteConfirm() {\n Str.get_strings([\n {key: 'deleteboard', component: 'mod_kanban'},\n {key: 'deleteboardconfirm', component: 'mod_kanban'},\n {key: 'delete', component: 'core'},\n ]).then((strings) => {\n return saveCancel(\n strings[0],\n strings[1],\n strings[2],\n () => {\n this._deleteBoard();\n }\n );\n }).catch((error) => Log.debug(error));\n }\n\n /**\n * Display confirmation modal for deleting a template.\n */\n _deleteTemplateConfirm() {\n Str.get_strings([\n {key: 'deletetemplate', component: 'mod_kanban'},\n {key: 'deletetemplateconfirm', component: 'mod_kanban'},\n {key: 'delete', component: 'core'},\n ]).then((strings) => {\n return saveCancel(\n strings[0],\n strings[1],\n strings[2],\n () => {\n this._deleteBoard();\n }\n );\n }).catch((error) => Log.debug(error));\n }\n\n /**\n * Called to delete current board.\n */\n _deleteBoard() {\n this.reactive.dispatch('deleteBoard');\n }\n\n /**\n * Called when board was updated.\n * @param {*} param0\n */\n _boardUpdated({element}) {\n const colcontainer = this.getElement(selectors.COLUMNCONTAINER);\n if (element.sequence !== undefined) {\n let sequence = element.sequence.split(',');\n // Remove all columns from frontend that are no longer present in the database.\n [...colcontainer.children]\n .forEach((node) => {\n if (node.classList.contains('mod_kanban_column') && !sequence.includes(node.dataset.id)) {\n colcontainer.removeChild(node);\n }\n });\n // Reorder columns according to sequence from the database.\n [...colcontainer.children]\n .sort((a, b) => sequence.indexOf(a.dataset.id) > sequence.indexOf(b.dataset.id) ? 1 : -1)\n .forEach(node => colcontainer.appendChild(node));\n }\n // Set CSS classes to show/hide action menu items.\n this.toggleClass(element.locked, 'mod_kanban_board_locked_columns');\n this.toggleClass(element.hastemplate, 'mod_kanban_hastemplate');\n }\n\n /**\n * Called when a new column was added. Creates a new subcomponent.\n * @param {*} param0\n */\n async _columnCreated({element}) {\n let data = Object.assign({\n id: element.id,\n title: element.title,\n options: element.options,\n sequence: element.sequence,\n }, exporter.exportCapabilities(this.reactive.state));\n let placeholder = document.createElement('li');\n placeholder.setAttribute('data-id', data.id);\n this.getElement(selectors.COLUMNCONTAINER).appendChild(placeholder);\n const newcomponent = await this.renderComponent(placeholder, 'mod_kanban/column', data);\n const newelement = newcomponent.getElement();\n this.getElement(selectors.COLUMNCONTAINER).replaceChild(newelement, placeholder);\n }\n\n /**\n * Called to add a column.\n */\n _addColumn() {\n document.activeElement.blur();\n // Board component only handles adding a column at the leftmost position, hence second parameter is always 0.\n this.reactive.dispatch('addColumn', 0);\n }\n\n /**\n * Called to lock all columns.\n */\n _lockColumns() {\n this.reactive.dispatch('lockColumns');\n }\n\n /**\n * Called to unlock all columns.\n */\n _unlockColumns() {\n this.reactive.dispatch('unlockColumns');\n }\n\n /**\n * Validate draggable data. This component only accepts columns.\n * @param {object} dropdata\n * @returns {boolean} if the data is valid for this drop-zone.\n */\n validateDropData(dropdata) {\n let type = dropdata?.type;\n return type == 'column';\n }\n\n /**\n * Executed when a valid dropdata is dropped over the drop-zone.\n * Moves the dropped column to the leftmost position (other positions are handled by column component).\n * @param {object} dropdata\n */\n drop(dropdata) {\n this.reactive.dispatch('moveColumn', dropdata.id, 0);\n }\n\n /**\n * Show some visual hints to the user.\n */\n showDropZone() {\n this.getElement(selectors.ADDCOLUMNCONTAINER).classList.add('mod_kanban_insert');\n }\n\n /**\n * Remove visual hints to the user.\n */\n hideDropZone() {\n this.getElement(selectors.ADDCOLUMNCONTAINER).classList.remove('mod_kanban_insert');\n }\n}\n"],"names":["KanbanComponent","target","this","element","document","getElementById","create","cmid","dataset","id","getWatchers","watch","handler","_boardUpdated","_columnCreated","_reload","_commonUpdated","state","addEventListener","getElement","selectors","ADDCOLUMNFIRST","_addColumn","capabilities","get","MANAGEBOARD","value","LOCKBOARDCOLUMNS","_lockColumns","UNLOCKBOARDCOLUMNS","_unlockColumns","SAVEASTEMPLATE","_templateConfirm","SHOWTEMPLATE","_showTemplate","DELETETEMPLATE","_deleteTemplateConfirm","DELETEBOARD","_deleteConfirm","dragdrop","DragDrop","common","liveupdate","_continuousUpdate","toggleClass","documentElement","window","location","href","M","cfg","wwwroot","reactive","template","replace","userid","setInterval","dispatch","destroy","undefined","unregister","Str","get_strings","key","component","then","strings","_saveAsTemplate","catch","error","Log","debug","_deleteBoard","colcontainer","COLUMNCONTAINER","sequence","split","children","forEach","node","classList","contains","includes","removeChild","sort","a","b","indexOf","appendChild","locked","hastemplate","data","Object","assign","title","options","exporter","exportCapabilities","placeholder","createElement","setAttribute","newelement","renderComponent","replaceChild","activeElement","blur","validateDropData","dropdata","type","drop","showDropZone","ADDCOLUMNCONTAINER","add","hideDropZone","remove"],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"board.min.js","sources":["../src/board.js"],"sourcesContent":["import {DragDrop} from 'core/reactive';\nimport selectors from 'mod_kanban/selectors';\nimport capabilities from 'mod_kanban/capabilities';\nimport exporter from 'mod_kanban/exporter';\nimport KanbanComponent from 'mod_kanban/kanbancomponent';\nimport Log from 'core/log';\nimport {saveCancel} from 'core/notification';\nimport * as Str from 'core/str';\n\n/**\n * Component representing a kanban board.\n */\nexport default class extends KanbanComponent {\n LOCKED_COLUMNS = 1;\n LOCKED_COMPLETE = 2;\n\n /**\n * Init component\n * @param {HTMLElement} target Element to attach the component to\n * @returns {KanbanComponent}\n */\n static init(target) {\n let element = document.getElementById(target);\n return new this({\n element: element,\n });\n }\n\n /**\n * Called before registering to reactive instance.\n */\n create() {\n this.cmid = this.element.dataset.cmid;\n this.id = this.element.dataset.id;\n }\n\n /**\n * Watchers defined by this component.\n * @returns {array}\n */\n getWatchers() {\n return [\n {watch: `board:updated`, handler: this._boardUpdated},\n {watch: `columns:created`, handler: this._columnCreated},\n {watch: `board:deleted`, handler: this._reload},\n {watch: `common:updated`, handler: this._commonUpdated},\n ];\n }\n\n /**\n * Called once when state is ready (also if component is registered after initial state was set), attaching event\n * isteners and initializing drag and drop.\n * @param {*} state The initial state\n */\n async stateReady(state) {\n this.addEventListener(\n this.getElement(selectors.ADDCOLUMNFIRST),\n 'click',\n this._addColumn\n );\n if (state.capabilities.get(capabilities.MANAGEBOARD).value == true) {\n this.addEventListener(\n this.getElement(selectors.LOCKBOARDCOLUMNS),\n 'click',\n this._lockColumns\n );\n this.addEventListener(\n this.getElement(selectors.UNLOCKBOARDCOLUMNS),\n 'click',\n this._unlockColumns\n );\n this.addEventListener(\n this.getElement(selectors.SAVEASTEMPLATE),\n 'click',\n this._templateConfirm\n );\n this.addEventListener(\n this.getElement(selectors.SHOWTEMPLATE),\n 'click',\n this._showTemplate\n );\n this.addEventListener(\n this.getElement(selectors.DELETETEMPLATE),\n 'click',\n this._deleteTemplateConfirm\n );\n }\n this.addEventListener(\n this.getElement(selectors.DELETEBOARD),\n 'click',\n this._deleteConfirm\n );\n this.addEventListener(\n this.getElement(selectors.SCROLLLEFT),\n 'click',\n this._scrollLeft\n );\n this.addEventListener(\n this.getElement(selectors.SCROLLRIGHT),\n 'click',\n this._scrollRight\n );\n this.addEventListener(\n this.getElement(selectors.MAIN),\n 'scroll',\n this._updateScrollButtons\n );\n this.dragdrop = new DragDrop(this);\n if (state.common.liveupdate > 0) {\n this._continuousUpdate(state.common.liveupdate);\n }\n this.toggleClass('ontouchstart' in document.documentElement, 'mod_kanban_touch');\n this._updateScrollButtons();\n }\n\n /**\n * Called to show template.\n */\n _showTemplate() {\n window.location.href =\n M.cfg.wwwroot +\n '/mod/kanban/view.php?id=' +\n this.reactive.state.common.id +\n '&boardid=' +\n this.reactive.state.common.template;\n }\n\n /**\n * Reload current page.\n */\n _reload() {\n window.location.replace(\n M.cfg.wwwroot + '/mod/kanban/view.php?id=' + this.reactive.state.common.id +\n '&userid=' + this.reactive.state.common.userid);\n }\n\n /**\n * Start continuous update.\n * @param {number} seconds Seconds between two refresh calls, defaults to 10\n */\n _continuousUpdate(seconds = 10) {\n setInterval(() => {\n this.reactive.dispatch('getUpdates');\n }, seconds * 1000);\n }\n\n /**\n * Called when common data was updated\n * @param {*} param0\n */\n _commonUpdated({element}) {\n this.toggleClass(element.template != 0, 'mod_kanban_hastemplate');\n }\n\n /**\n * Remove all subcomponents dependencies.\n */\n destroy() {\n if (this.dragdrop !== undefined) {\n this.dragdrop.unregister();\n }\n this._reload();\n }\n\n /**\n * Display confirmation modal for saving a board as template.\n */\n _templateConfirm() {\n Str.get_strings([\n {key: 'saveastemplate', component: 'mod_kanban'},\n {key: 'saveastemplateconfirm', component: 'mod_kanban'},\n {key: 'save', component: 'core'},\n ]).then((strings) => {\n return saveCancel(\n strings[0],\n strings[1],\n strings[2],\n () => {\n this._saveAsTemplate();\n }\n );\n }).catch((error) => Log.debug(error));\n }\n\n /**\n * Called when current board should be saved as template.\n */\n _saveAsTemplate() {\n this.reactive.dispatch('saveAsTemplate');\n }\n\n /**\n * Display confirmation modal for deleting a board.\n */\n _deleteConfirm() {\n Str.get_strings([\n {key: 'deleteboard', component: 'mod_kanban'},\n {key: 'deleteboardconfirm', component: 'mod_kanban'},\n {key: 'delete', component: 'core'},\n ]).then((strings) => {\n return saveCancel(\n strings[0],\n strings[1],\n strings[2],\n () => {\n this._deleteBoard();\n }\n );\n }).catch((error) => Log.debug(error));\n }\n\n /**\n * Display confirmation modal for deleting a template.\n */\n _deleteTemplateConfirm() {\n Str.get_strings([\n {key: 'deletetemplate', component: 'mod_kanban'},\n {key: 'deletetemplateconfirm', component: 'mod_kanban'},\n {key: 'delete', component: 'core'},\n ]).then((strings) => {\n return saveCancel(\n strings[0],\n strings[1],\n strings[2],\n () => {\n this._deleteBoard();\n }\n );\n }).catch((error) => Log.debug(error));\n }\n\n /**\n * Called to delete current board.\n */\n _deleteBoard() {\n this.reactive.dispatch('deleteBoard');\n }\n\n /**\n * Called when board was updated.\n * @param {*} param0\n */\n _boardUpdated({element}) {\n const colcontainer = this.getElement(selectors.COLUMNCONTAINER);\n if (element.sequence !== undefined) {\n let sequence = element.sequence.split(',');\n // Remove all columns from frontend that are no longer present in the database.\n [...colcontainer.children]\n .forEach((node) => {\n if (node.classList.contains('mod_kanban_column') && !sequence.includes(node.dataset.id)) {\n colcontainer.removeChild(node);\n }\n });\n // Reorder columns according to sequence from the database.\n [...colcontainer.children]\n .sort((a, b) => sequence.indexOf(a.dataset.id) > sequence.indexOf(b.dataset.id) ? 1 : -1)\n .forEach(node => colcontainer.appendChild(node));\n }\n // Set CSS classes to show/hide action menu items.\n this.toggleClass(element.locked, 'mod_kanban_board_locked_columns');\n this.toggleClass(element.hastemplate, 'mod_kanban_hastemplate');\n }\n\n /**\n * Called when a new column was added. Creates a new subcomponent.\n * @param {*} param0\n */\n async _columnCreated({element}) {\n let data = Object.assign({\n id: element.id,\n title: element.title,\n options: element.options,\n sequence: element.sequence,\n }, exporter.exportCapabilities(this.reactive.state));\n let placeholder = document.createElement('li');\n placeholder.setAttribute('data-id', data.id);\n this.getElement(selectors.COLUMNCONTAINER).appendChild(placeholder);\n const newcomponent = await this.renderComponent(placeholder, 'mod_kanban/column', data);\n const newelement = newcomponent.getElement();\n this.getElement(selectors.COLUMNCONTAINER).replaceChild(newelement, placeholder);\n }\n\n /**\n * Called to add a column.\n */\n _addColumn() {\n document.activeElement.blur();\n // Board component only handles adding a column at the leftmost position, hence second parameter is always 0.\n this.reactive.dispatch('addColumn', 0);\n }\n\n /**\n * Called to lock all columns.\n */\n _lockColumns() {\n this.reactive.dispatch('lockColumns');\n }\n\n /**\n * Called to unlock all columns.\n */\n _unlockColumns() {\n this.reactive.dispatch('unlockColumns');\n }\n\n /**\n * Validate draggable data. This component only accepts columns.\n * @param {object} dropdata\n * @returns {boolean} if the data is valid for this drop-zone.\n */\n validateDropData(dropdata) {\n let type = dropdata?.type;\n return type == 'column';\n }\n\n /**\n * Executed when a valid dropdata is dropped over the drop-zone.\n * Moves the dropped column to the leftmost position (other positions are handled by column component).\n * @param {object} dropdata\n */\n drop(dropdata) {\n this.reactive.dispatch('moveColumn', dropdata.id, 0);\n }\n\n /**\n * Show some visual hints to the user.\n */\n showDropZone() {\n this.getElement(selectors.ADDCOLUMNCONTAINER).classList.add('mod_kanban_insert');\n }\n\n /**\n * Remove visual hints to the user.\n */\n hideDropZone() {\n this.getElement(selectors.ADDCOLUMNCONTAINER).classList.remove('mod_kanban_insert');\n }\n\n /**\n * Scroll to the left.\n */\n _scrollLeft() {\n this.getElement(selectors.MAIN).scrollLeft -= 80;\n }\n\n /**\n * Scroll to the right.\n */\n _scrollRight() {\n this.getElement(selectors.MAIN).scrollLeft += 80;\n }\n\n /**\n * Only show scroll buttons if it's possible to scroll in this direction.\n */\n _updateScrollButtons() {\n let main = this.getElement(selectors.MAIN);\n if (main.scrollLeft <= 1) {\n this.getElement(selectors.SCROLLLEFT).style.setProperty('visibility', 'hidden');\n } else {\n this.getElement(selectors.SCROLLLEFT).style.setProperty('visibility', 'visible');\n }\n if (main.scrollLeft < main.scrollLeftMax) {\n this.getElement(selectors.SCROLLRIGHT).style.setProperty('visibility', 'visible');\n } else {\n this.getElement(selectors.SCROLLRIGHT).style.setProperty('visibility', 'hidden');\n }\n }\n}\n"],"names":["KanbanComponent","target","this","element","document","getElementById","create","cmid","dataset","id","getWatchers","watch","handler","_boardUpdated","_columnCreated","_reload","_commonUpdated","state","addEventListener","getElement","selectors","ADDCOLUMNFIRST","_addColumn","capabilities","get","MANAGEBOARD","value","LOCKBOARDCOLUMNS","_lockColumns","UNLOCKBOARDCOLUMNS","_unlockColumns","SAVEASTEMPLATE","_templateConfirm","SHOWTEMPLATE","_showTemplate","DELETETEMPLATE","_deleteTemplateConfirm","DELETEBOARD","_deleteConfirm","SCROLLLEFT","_scrollLeft","SCROLLRIGHT","_scrollRight","MAIN","_updateScrollButtons","dragdrop","DragDrop","common","liveupdate","_continuousUpdate","toggleClass","documentElement","window","location","href","M","cfg","wwwroot","reactive","template","replace","userid","setInterval","dispatch","destroy","undefined","unregister","Str","get_strings","key","component","then","strings","_saveAsTemplate","catch","error","Log","debug","_deleteBoard","colcontainer","COLUMNCONTAINER","sequence","split","children","forEach","node","classList","contains","includes","removeChild","sort","a","b","indexOf","appendChild","locked","hastemplate","data","Object","assign","title","options","exporter","exportCapabilities","placeholder","createElement","setAttribute","newelement","renderComponent","replaceChild","activeElement","blur","validateDropData","dropdata","type","drop","showDropZone","ADDCOLUMNCONTAINER","add","hideDropZone","remove","scrollLeft","main","style","setProperty","scrollLeftMax"],"mappings":"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"} \ No newline at end of file diff --git a/amd/build/selectors.min.js b/amd/build/selectors.min.js index c8270934..4f8b2233 100644 --- a/amd/build/selectors.min.js +++ b/amd/build/selectors.min.js @@ -1,3 +1,3 @@ -define("mod_kanban/selectors",["exports"],(function(_exports){Object.defineProperty(_exports,"__esModule",{value:!0}),_exports.default=void 0;return _exports.default={ADDCARD:'[data-action="add_card"]',ADDCARDCONTAINER:".mod_kanban_addcard_container",ADDCARDFIRST:".mod_kanban_addcard_first",ADDCOLUMN:'[data-action="add_column"]',ADDCOLUMNCONTAINER:".mod_kanban_addcolumn_container",ADDCOLUMNFIRST:".mod_kanban_addcolumn_first",ASSIGNEES:".mod_kanban_assignees",ASSIGNSELF:'[data-action="assign_self"]',ASSIGNUSER:'[data-action="assign_user"]',ASSIGNEDUSER:".mod_kanban_assigned_user",BOARD:".mod_kanban_board",CARD:".mod_kanban_card",COLUMN:".mod_kanban_column",COLUMNCONTAINER:".mod_kanban_column_container",COLUMNINNER:".mod_kanban_column_inner",COMPLETE:'[data-action="complete_card"]',COMPLETIONSTATE:".mod_kanban_card_completion",CONTAINER:".mod_kanban_render_container",DELETEBOARD:'[data-action="delete_board"]',DELETECARD:'[data-action="delete_card"]',DELETECOLUMN:'[data-action="delete_column"]',DELETEMESSAGE:'[data-action="delete_message"]',DELETETEMPLATE:'[data-action="delete_template"]',DESCRIPTIONMODAL:".mod_kanban_description",DESCRIPTIONMODALBODY:".mod_kanban_description_modal .modal-body",DESCRIPTIONMODALFOOTER:".mod_kanban_description_modal .modal-footer",DESCRIPTIONMODALTITLE:".mod_kanban_description_modal .modal-title",DESCRIPTIONTOGGLE:".mod_kanban_description",DISCUSSION:".mod_kanban_discussion",DISCUSSIONINPUT:".mod_kanban_discussion_input",DISCUSSIONMESSAGES:".mod_kanban_discussion_messages",DISCUSSIONMODAL:".mod_kanban_discussion_modal",DISCUSSIONMODALTITLE:".mod_kanban_discussion_modal .modal-title",DISCUSSIONMODALTRIGGER:".mod_kanban_discussion_trigger",DISCUSSIONSEND:'[data-action="send_discussion_message"]',DISCUSSIONSHOW:'[data-action="show_discussion"]',DUEDATE:".mod_kanban_duedate",EDITDETAILS:'[data-action="edit_details"]',HIDEHIDDEN:'[data-action="hide_hidden"]',HISTORY:".mod_kanban_history",HISTORYITEMS:".mod_kanban_history_items",HISTORYMODAL:".mod_kanban_history_modal",HISTORYMODALTRIGGER:'[data-action="show_history"]',INPLACEEDITABLE:".inplaceeditable",LOCKCOLUMN:'[data-action="lock_column"]',LOCKBOARDCOLUMNS:'[data-action="lock_board_columns"]',MOVECARDAFTERCARD:".mod_kanban_move_card_aftercard",MOVECARDCOLUMN:".mod_kanban_move_card_column",MOVEMODALTRIGGER:'[data-action="move_card"]',PUSHCARD:'[data-action="push_card"]',SAVEASTEMPLATE:'[data-action="create_template"]',SHOWBOARD:'[data-action="show_board"]',SHOWHIDDEN:'[data-action="show_hidden"]',SHOWTEMPLATE:'[data-action="show_template"]',UNASSIGNSELF:'[data-action="unassign_self"]',UNASSIGNUSER:'[data-action="unassign_user"]',UNCOMPLETE:'[data-action="uncomplete_card"]',UNLOCKCOLUMN:'[data-action="unlock_column"]',UNLOCKBOARDCOLUMNS:'[data-action="unlock_board_columns"]'},_exports.default})); +define("mod_kanban/selectors",["exports"],(function(_exports){Object.defineProperty(_exports,"__esModule",{value:!0}),_exports.default=void 0;return _exports.default={ADDCARD:'[data-action="add_card"]',ADDCARDCONTAINER:".mod_kanban_addcard_container",ADDCARDFIRST:".mod_kanban_addcard_first",ADDCOLUMN:'[data-action="add_column"]',ADDCOLUMNCONTAINER:".mod_kanban_addcolumn_container",ADDCOLUMNFIRST:".mod_kanban_addcolumn_first",ASSIGNEES:".mod_kanban_assignees",ASSIGNSELF:'[data-action="assign_self"]',ASSIGNUSER:'[data-action="assign_user"]',ASSIGNEDUSER:".mod_kanban_assigned_user",BOARD:".mod_kanban_board",CARD:".mod_kanban_card",COLUMN:".mod_kanban_column",COLUMNCONTAINER:".mod_kanban_column_container",COLUMNINNER:".mod_kanban_column_inner",COMPLETE:'[data-action="complete_card"]',COMPLETIONSTATE:".mod_kanban_card_completion",CONTAINER:".mod_kanban_render_container",DELETEBOARD:'[data-action="delete_board"]',DELETECARD:'[data-action="delete_card"]',DELETECOLUMN:'[data-action="delete_column"]',DELETEMESSAGE:'[data-action="delete_message"]',DELETETEMPLATE:'[data-action="delete_template"]',DESCRIPTIONMODAL:".mod_kanban_description",DESCRIPTIONMODALBODY:".mod_kanban_description_modal .modal-body",DESCRIPTIONMODALFOOTER:".mod_kanban_description_modal .modal-footer",DESCRIPTIONMODALTITLE:".mod_kanban_description_modal .modal-title",DESCRIPTIONTOGGLE:".mod_kanban_description",DISCUSSION:".mod_kanban_discussion",DISCUSSIONINPUT:".mod_kanban_discussion_input",DISCUSSIONMESSAGES:".mod_kanban_discussion_messages",DISCUSSIONMODAL:".mod_kanban_discussion_modal",DISCUSSIONMODALTITLE:".mod_kanban_discussion_modal .modal-title",DISCUSSIONMODALTRIGGER:".mod_kanban_discussion_trigger",DISCUSSIONSEND:'[data-action="send_discussion_message"]',DISCUSSIONSHOW:'[data-action="show_discussion"]',DUEDATE:".mod_kanban_duedate",EDITDETAILS:'[data-action="edit_details"]',HIDEHIDDEN:'[data-action="hide_hidden"]',HISTORY:".mod_kanban_history",HISTORYITEMS:".mod_kanban_history_items",HISTORYMODAL:".mod_kanban_history_modal",HISTORYMODALTRIGGER:'[data-action="show_history"]',INPLACEEDITABLE:".inplaceeditable",LOCKCOLUMN:'[data-action="lock_column"]',LOCKBOARDCOLUMNS:'[data-action="lock_board_columns"]',MAIN:".mod_kanban_main",MOVECARDAFTERCARD:".mod_kanban_move_card_aftercard",MOVECARDCOLUMN:".mod_kanban_move_card_column",MOVEMODALTRIGGER:'[data-action="move_card"]',PUSHCARD:'[data-action="push_card"]',SAVEASTEMPLATE:'[data-action="create_template"]',SCROLLLEFT:".mod_kanban_scroll_left button",SCROLLRIGHT:".mod_kanban_scroll_right button",SHOWBOARD:'[data-action="show_board"]',SHOWHIDDEN:'[data-action="show_hidden"]',SHOWTEMPLATE:'[data-action="show_template"]',UNASSIGNSELF:'[data-action="unassign_self"]',UNASSIGNUSER:'[data-action="unassign_user"]',UNCOMPLETE:'[data-action="uncomplete_card"]',UNLOCKCOLUMN:'[data-action="unlock_column"]',UNLOCKBOARDCOLUMNS:'[data-action="unlock_board_columns"]'},_exports.default})); //# sourceMappingURL=selectors.min.js.map \ No newline at end of file diff --git a/amd/build/selectors.min.js.map b/amd/build/selectors.min.js.map index c9aa4f95..155b5350 100644 --- a/amd/build/selectors.min.js.map +++ b/amd/build/selectors.min.js.map @@ -1 +1 @@ -{"version":3,"file":"selectors.min.js","sources":["../src/selectors.js"],"sourcesContent":["/**\n * Selectors for mod_kanban.\n */\nexport default {\n ADDCARD: `[data-action=\"add_card\"]`,\n ADDCARDCONTAINER: `.mod_kanban_addcard_container`,\n ADDCARDFIRST: `.mod_kanban_addcard_first`,\n ADDCOLUMN: `[data-action=\"add_column\"]`,\n ADDCOLUMNCONTAINER: `.mod_kanban_addcolumn_container`,\n ADDCOLUMNFIRST: `.mod_kanban_addcolumn_first`,\n ASSIGNEES: `.mod_kanban_assignees`,\n ASSIGNSELF: `[data-action=\"assign_self\"]`,\n ASSIGNUSER: `[data-action=\"assign_user\"]`,\n ASSIGNEDUSER: `.mod_kanban_assigned_user`,\n BOARD: `.mod_kanban_board`,\n CARD: `.mod_kanban_card`,\n COLUMN: `.mod_kanban_column`,\n COLUMNCONTAINER: `.mod_kanban_column_container`,\n COLUMNINNER: `.mod_kanban_column_inner`,\n COMPLETE: `[data-action=\"complete_card\"]`,\n COMPLETIONSTATE: `.mod_kanban_card_completion`,\n CONTAINER: `.mod_kanban_render_container`,\n DELETEBOARD: `[data-action=\"delete_board\"]`,\n DELETECARD: `[data-action=\"delete_card\"]`,\n DELETECOLUMN: `[data-action=\"delete_column\"]`,\n DELETEMESSAGE: `[data-action=\"delete_message\"]`,\n DELETETEMPLATE: `[data-action=\"delete_template\"]`,\n DESCRIPTIONMODAL: `.mod_kanban_description`,\n DESCRIPTIONMODALBODY: `.mod_kanban_description_modal .modal-body`,\n DESCRIPTIONMODALFOOTER: `.mod_kanban_description_modal .modal-footer`,\n DESCRIPTIONMODALTITLE: `.mod_kanban_description_modal .modal-title`,\n DESCRIPTIONTOGGLE: `.mod_kanban_description`,\n DISCUSSION: `.mod_kanban_discussion`,\n DISCUSSIONINPUT: `.mod_kanban_discussion_input`,\n DISCUSSIONMESSAGES: `.mod_kanban_discussion_messages`,\n DISCUSSIONMODAL: `.mod_kanban_discussion_modal`,\n DISCUSSIONMODALTITLE: `.mod_kanban_discussion_modal .modal-title`,\n DISCUSSIONMODALTRIGGER: `.mod_kanban_discussion_trigger`,\n DISCUSSIONSEND: `[data-action=\"send_discussion_message\"]`,\n DISCUSSIONSHOW: `[data-action=\"show_discussion\"]`,\n DUEDATE: `.mod_kanban_duedate`,\n EDITDETAILS: `[data-action=\"edit_details\"]`,\n HIDEHIDDEN: `[data-action=\"hide_hidden\"]`,\n HISTORY: `.mod_kanban_history`,\n HISTORYITEMS: `.mod_kanban_history_items`,\n HISTORYMODAL: `.mod_kanban_history_modal`,\n HISTORYMODALTRIGGER: `[data-action=\"show_history\"]`,\n INPLACEEDITABLE: `.inplaceeditable`,\n LOCKCOLUMN: `[data-action=\"lock_column\"]`,\n LOCKBOARDCOLUMNS: `[data-action=\"lock_board_columns\"]`,\n MOVECARDAFTERCARD: `.mod_kanban_move_card_aftercard`,\n MOVECARDCOLUMN: `.mod_kanban_move_card_column`,\n MOVEMODALTRIGGER: `[data-action=\"move_card\"]`,\n PUSHCARD: `[data-action=\"push_card\"]`,\n SAVEASTEMPLATE: `[data-action=\"create_template\"]`,\n SHOWBOARD: `[data-action=\"show_board\"]`,\n SHOWHIDDEN: `[data-action=\"show_hidden\"]`,\n SHOWTEMPLATE: `[data-action=\"show_template\"]`,\n UNASSIGNSELF: `[data-action=\"unassign_self\"]`,\n UNASSIGNUSER: `[data-action=\"unassign_user\"]`,\n UNCOMPLETE: `[data-action=\"uncomplete_card\"]`,\n UNLOCKCOLUMN: `[data-action=\"unlock_column\"]`,\n UNLOCKBOARDCOLUMNS: `[data-action=\"unlock_board_columns\"]`,\n};"],"names":["ADDCARD","ADDCARDCONTAINER","ADDCARDFIRST","ADDCOLUMN","ADDCOLUMNCONTAINER","ADDCOLUMNFIRST","ASSIGNEES","ASSIGNSELF","ASSIGNUSER","ASSIGNEDUSER","BOARD","CARD","COLUMN","COLUMNCONTAINER","COLUMNINNER","COMPLETE","COMPLETIONSTATE","CONTAINER","DELETEBOARD","DELETECARD","DELETECOLUMN","DELETEMESSAGE","DELETETEMPLATE","DESCRIPTIONMODAL","DESCRIPTIONMODALBODY","DESCRIPTIONMODALFOOTER","DESCRIPTIONMODALTITLE","DESCRIPTIONTOGGLE","DISCUSSION","DISCUSSIONINPUT","DISCUSSIONMESSAGES","DISCUSSIONMODAL","DISCUSSIONMODALTITLE","DISCUSSIONMODALTRIGGER","DISCUSSIONSEND","DISCUSSIONSHOW","DUEDATE","EDITDETAILS","HIDEHIDDEN","HISTORY","HISTORYITEMS","HISTORYMODAL","HISTORYMODALTRIGGER","INPLACEEDITABLE","LOCKCOLUMN","LOCKBOARDCOLUMNS","MOVECARDAFTERCARD","MOVECARDCOLUMN","MOVEMODALTRIGGER","PUSHCARD","SAVEASTEMPLATE","SHOWBOARD","SHOWHIDDEN","SHOWTEMPLATE","UNASSIGNSELF","UNASSIGNUSER","UNCOMPLETE","UNLOCKCOLUMN","UNLOCKBOARDCOLUMNS"],"mappings":"sKAGe,CACXA,mCACAC,iDACAC,yCACAC,uCACAC,qDACAC,6CACAC,kCACAC,yCACAC,yCACAC,yCACAC,0BACAC,wBACAC,4BACAC,+CACAC,uCACAC,yCACAC,8CACAC,yCACAC,2CACAC,yCACAC,6CACAC,+CACAC,iDACAC,2CACAC,iEACAC,qEACAC,mEACAC,4CACAC,oCACAC,+CACAC,qDACAC,+CACAC,iEACAC,wDACAC,yDACAC,iDACAC,8BACAC,2CACAC,yCACAC,8BACAC,yCACAC,yCACAC,mDACAC,mCACAC,yCACAC,sDACAC,oDACAC,8CACAC,6CACAC,qCACAC,iDACAC,uCACAC,yCACAC,6CACAC,6CACAC,6CACAC,6CACAC,6CACAC"} \ No newline at end of file +{"version":3,"file":"selectors.min.js","sources":["../src/selectors.js"],"sourcesContent":["/**\n * Selectors for mod_kanban.\n */\nexport default {\n ADDCARD: `[data-action=\"add_card\"]`,\n ADDCARDCONTAINER: `.mod_kanban_addcard_container`,\n ADDCARDFIRST: `.mod_kanban_addcard_first`,\n ADDCOLUMN: `[data-action=\"add_column\"]`,\n ADDCOLUMNCONTAINER: `.mod_kanban_addcolumn_container`,\n ADDCOLUMNFIRST: `.mod_kanban_addcolumn_first`,\n ASSIGNEES: `.mod_kanban_assignees`,\n ASSIGNSELF: `[data-action=\"assign_self\"]`,\n ASSIGNUSER: `[data-action=\"assign_user\"]`,\n ASSIGNEDUSER: `.mod_kanban_assigned_user`,\n BOARD: `.mod_kanban_board`,\n CARD: `.mod_kanban_card`,\n COLUMN: `.mod_kanban_column`,\n COLUMNCONTAINER: `.mod_kanban_column_container`,\n COLUMNINNER: `.mod_kanban_column_inner`,\n COMPLETE: `[data-action=\"complete_card\"]`,\n COMPLETIONSTATE: `.mod_kanban_card_completion`,\n CONTAINER: `.mod_kanban_render_container`,\n DELETEBOARD: `[data-action=\"delete_board\"]`,\n DELETECARD: `[data-action=\"delete_card\"]`,\n DELETECOLUMN: `[data-action=\"delete_column\"]`,\n DELETEMESSAGE: `[data-action=\"delete_message\"]`,\n DELETETEMPLATE: `[data-action=\"delete_template\"]`,\n DESCRIPTIONMODAL: `.mod_kanban_description`,\n DESCRIPTIONMODALBODY: `.mod_kanban_description_modal .modal-body`,\n DESCRIPTIONMODALFOOTER: `.mod_kanban_description_modal .modal-footer`,\n DESCRIPTIONMODALTITLE: `.mod_kanban_description_modal .modal-title`,\n DESCRIPTIONTOGGLE: `.mod_kanban_description`,\n DISCUSSION: `.mod_kanban_discussion`,\n DISCUSSIONINPUT: `.mod_kanban_discussion_input`,\n DISCUSSIONMESSAGES: `.mod_kanban_discussion_messages`,\n DISCUSSIONMODAL: `.mod_kanban_discussion_modal`,\n DISCUSSIONMODALTITLE: `.mod_kanban_discussion_modal .modal-title`,\n DISCUSSIONMODALTRIGGER: `.mod_kanban_discussion_trigger`,\n DISCUSSIONSEND: `[data-action=\"send_discussion_message\"]`,\n DISCUSSIONSHOW: `[data-action=\"show_discussion\"]`,\n DUEDATE: `.mod_kanban_duedate`,\n EDITDETAILS: `[data-action=\"edit_details\"]`,\n HIDEHIDDEN: `[data-action=\"hide_hidden\"]`,\n HISTORY: `.mod_kanban_history`,\n HISTORYITEMS: `.mod_kanban_history_items`,\n HISTORYMODAL: `.mod_kanban_history_modal`,\n HISTORYMODALTRIGGER: `[data-action=\"show_history\"]`,\n INPLACEEDITABLE: `.inplaceeditable`,\n LOCKCOLUMN: `[data-action=\"lock_column\"]`,\n LOCKBOARDCOLUMNS: `[data-action=\"lock_board_columns\"]`,\n MAIN: `.mod_kanban_main`,\n MOVECARDAFTERCARD: `.mod_kanban_move_card_aftercard`,\n MOVECARDCOLUMN: `.mod_kanban_move_card_column`,\n MOVEMODALTRIGGER: `[data-action=\"move_card\"]`,\n PUSHCARD: `[data-action=\"push_card\"]`,\n SAVEASTEMPLATE: `[data-action=\"create_template\"]`,\n SCROLLLEFT: `.mod_kanban_scroll_left button`,\n SCROLLRIGHT: `.mod_kanban_scroll_right button`,\n SHOWBOARD: `[data-action=\"show_board\"]`,\n SHOWHIDDEN: `[data-action=\"show_hidden\"]`,\n SHOWTEMPLATE: `[data-action=\"show_template\"]`,\n UNASSIGNSELF: `[data-action=\"unassign_self\"]`,\n UNASSIGNUSER: `[data-action=\"unassign_user\"]`,\n UNCOMPLETE: `[data-action=\"uncomplete_card\"]`,\n UNLOCKCOLUMN: `[data-action=\"unlock_column\"]`,\n UNLOCKBOARDCOLUMNS: `[data-action=\"unlock_board_columns\"]`,\n};"],"names":["ADDCARD","ADDCARDCONTAINER","ADDCARDFIRST","ADDCOLUMN","ADDCOLUMNCONTAINER","ADDCOLUMNFIRST","ASSIGNEES","ASSIGNSELF","ASSIGNUSER","ASSIGNEDUSER","BOARD","CARD","COLUMN","COLUMNCONTAINER","COLUMNINNER","COMPLETE","COMPLETIONSTATE","CONTAINER","DELETEBOARD","DELETECARD","DELETECOLUMN","DELETEMESSAGE","DELETETEMPLATE","DESCRIPTIONMODAL","DESCRIPTIONMODALBODY","DESCRIPTIONMODALFOOTER","DESCRIPTIONMODALTITLE","DESCRIPTIONTOGGLE","DISCUSSION","DISCUSSIONINPUT","DISCUSSIONMESSAGES","DISCUSSIONMODAL","DISCUSSIONMODALTITLE","DISCUSSIONMODALTRIGGER","DISCUSSIONSEND","DISCUSSIONSHOW","DUEDATE","EDITDETAILS","HIDEHIDDEN","HISTORY","HISTORYITEMS","HISTORYMODAL","HISTORYMODALTRIGGER","INPLACEEDITABLE","LOCKCOLUMN","LOCKBOARDCOLUMNS","MAIN","MOVECARDAFTERCARD","MOVECARDCOLUMN","MOVEMODALTRIGGER","PUSHCARD","SAVEASTEMPLATE","SCROLLLEFT","SCROLLRIGHT","SHOWBOARD","SHOWHIDDEN","SHOWTEMPLATE","UNASSIGNSELF","UNASSIGNUSER","UNCOMPLETE","UNLOCKCOLUMN","UNLOCKBOARDCOLUMNS"],"mappings":"sKAGe,CACXA,mCACAC,iDACAC,yCACAC,uCACAC,qDACAC,6CACAC,kCACAC,yCACAC,yCACAC,yCACAC,0BACAC,wBACAC,4BACAC,+CACAC,uCACAC,yCACAC,8CACAC,yCACAC,2CACAC,yCACAC,6CACAC,+CACAC,iDACAC,2CACAC,iEACAC,qEACAC,mEACAC,4CACAC,oCACAC,+CACAC,qDACAC,+CACAC,iEACAC,wDACAC,yDACAC,iDACAC,8BACAC,2CACAC,yCACAC,8BACAC,yCACAC,yCACAC,mDACAC,mCACAC,yCACAC,sDACAC,wBACAC,oDACAC,8CACAC,6CACAC,qCACAC,iDACAC,4CACAC,8CACAC,uCACAC,yCACAC,6CACAC,6CACAC,6CACAC,6CACAC,6CACAC"} \ No newline at end of file diff --git a/amd/src/board.js b/amd/src/board.js index 767ef577..9de4d97e 100644 --- a/amd/src/board.js +++ b/amd/src/board.js @@ -90,11 +90,27 @@ export default class extends KanbanComponent { 'click', this._deleteConfirm ); + this.addEventListener( + this.getElement(selectors.SCROLLLEFT), + 'click', + this._scrollLeft + ); + this.addEventListener( + this.getElement(selectors.SCROLLRIGHT), + 'click', + this._scrollRight + ); + this.addEventListener( + this.getElement(selectors.MAIN), + 'scroll', + this._updateScrollButtons + ); this.dragdrop = new DragDrop(this); if (state.common.liveupdate > 0) { this._continuousUpdate(state.common.liveupdate); } this.toggleClass('ontouchstart' in document.documentElement, 'mod_kanban_touch'); + this._updateScrollButtons(); } /** @@ -319,4 +335,35 @@ export default class extends KanbanComponent { hideDropZone() { this.getElement(selectors.ADDCOLUMNCONTAINER).classList.remove('mod_kanban_insert'); } + + /** + * Scroll to the left. + */ + _scrollLeft() { + this.getElement(selectors.MAIN).scrollLeft -= 80; + } + + /** + * Scroll to the right. + */ + _scrollRight() { + this.getElement(selectors.MAIN).scrollLeft += 80; + } + + /** + * Only show scroll buttons if it's possible to scroll in this direction. + */ + _updateScrollButtons() { + let main = this.getElement(selectors.MAIN); + if (main.scrollLeft <= 1) { + this.getElement(selectors.SCROLLLEFT).style.setProperty('visibility', 'hidden'); + } else { + this.getElement(selectors.SCROLLLEFT).style.setProperty('visibility', 'visible'); + } + if (main.scrollLeft < main.scrollLeftMax) { + this.getElement(selectors.SCROLLRIGHT).style.setProperty('visibility', 'visible'); + } else { + this.getElement(selectors.SCROLLRIGHT).style.setProperty('visibility', 'hidden'); + } + } } diff --git a/amd/src/selectors.js b/amd/src/selectors.js index 4172e4ba..04000b37 100644 --- a/amd/src/selectors.js +++ b/amd/src/selectors.js @@ -48,11 +48,14 @@ export default { INPLACEEDITABLE: `.inplaceeditable`, LOCKCOLUMN: `[data-action="lock_column"]`, LOCKBOARDCOLUMNS: `[data-action="lock_board_columns"]`, + MAIN: `.mod_kanban_main`, MOVECARDAFTERCARD: `.mod_kanban_move_card_aftercard`, MOVECARDCOLUMN: `.mod_kanban_move_card_column`, MOVEMODALTRIGGER: `[data-action="move_card"]`, PUSHCARD: `[data-action="push_card"]`, SAVEASTEMPLATE: `[data-action="create_template"]`, + SCROLLLEFT: `.mod_kanban_scroll_left button`, + SCROLLRIGHT: `.mod_kanban_scroll_right button`, SHOWBOARD: `[data-action="show_board"]`, SHOWHIDDEN: `[data-action="show_hidden"]`, SHOWTEMPLATE: `[data-action="show_template"]`, diff --git a/styles.css b/styles.css index 6d243cc7..18427613 100644 --- a/styles.css +++ b/styles.css @@ -391,3 +391,30 @@ a.mod_kanban_attachment_item { .mod_kanban_board .btn { background-color: white; } + +.mod_kanban_column_container.row { + margin-left: -30px; +} + +.mod_kanban_scroll.row { + display: block; + position: sticky; + top: 50%; + z-index: 3; + width: 30px; + float: left; +} + +.mod_kanban_scroll_button { + height: 50px; + width: 30px; + border: none; +} + +.mod_kanban_scroll_left { + left: 0; +} + +.mod_kanban_scroll_right { + left: calc(100vw - 30px); +} \ No newline at end of file diff --git a/templates/board.mustache b/templates/board.mustache index 3175e8bd..4d8f88f5 100644 --- a/templates/board.mustache +++ b/templates/board.mustache @@ -44,6 +44,12 @@ {{>mod_kanban/actionmenuboard}} +
+ +
+
+ +