UNPKG

jqwidgets-scripts-custom

Version:

jQWidgets is an advanced jQuery, Angular 7, Vue, React, ASP .NET MVC, Custom Elements and HTML5 UI framework.

199 lines (184 loc) 10.2 kB
<!DOCTYPE html> <html lang='en'> <head> <title id='Description'>Custom Element Kanban HeaderTemplate</title> <meta http-equiv='X-UA-Compatible' content='IE=edge,chrome=1' /> <meta name='viewport' content='width=device-width, initial-scale=1 maximum-scale=1 minimum-scale=1' /> <meta name='description' content='This is an example of the header templates in Custom Element Kanban.' /> <link rel='stylesheet' href='../../../jqwidgets/styles/jqx.base.css' type='text/css' /> <link rel='stylesheet' href='../styles/demos.css' type='text/css' /> <script type='text/javascript' src='../../../scripts/webcomponents-lite.min.js'></script> <script type='text/javascript' src='../../../jqwidgets/jqxcore.js'></script> <script type='text/javascript' src='../../../jqwidgets/jqxcore.elements.js'></script> <script type="text/javascript" src="../../../jqwidgets/jqxsortable.js"></script> <script type="text/javascript" src="../../../jqwidgets/jqxkanban.js"></script> <script type="text/javascript" src="../../../jqwidgets/jqxdata.js"></script> <script type="text/javascript" src="../../../scripts/demos.js"></script> <style> .jqx-kanban-item-color-status { width: 100%; height: 25px; border-top-left-radius: 3px; border-top-right-radius: 3px; position: relative; margin-top: 0px; top: 0px; } .jqx-kanban-item { padding-top: 0px; padding-bottom: 0px; } .jqx-kanban-item-text { padding-top: 6px; padding-bottom: 6px; } .jqx-kanban-item-avatar { top: 9px; } .jqx-kanban-template-icon { position: absolute; right: 3px; top: 12px; } </style> <script type='text/javascript'> var fields = [ { name: 'id', type: 'string' }, { name: 'status', map: 'state', type: 'string' }, { name: 'text', map: 'label', type: 'string' }, { name: 'tags', type: 'string' }, { name: 'color', map: 'hex', type: 'string' }, { name: 'resourceId', type: 'number' } ]; var source = { localData: [ { id: '1161', state: 'new', label: 'Make a new Dashboard', tags: 'dashboard', hex: '#36c7d0', resourceId: 3 }, { id: '1645', state: 'work', label: 'Prepare new release', tags: 'release', hex: '#ff7878', resourceId: 1 }, { id: '9213', state: 'new', label: 'One item added to the cart', tags: 'cart', hex: '#96c443', resourceId: 3 }, { id: '6546', state: 'done', label: 'Edit Item Price', tags: 'price, edit', hex: '#ff7878', resourceId: 4 }, { id: '9034', state: 'new', label: 'Login 404 issue', tags: 'issue, login', hex: '#96c443' } ], dataType: 'array', dataFields: fields }; var dataAdapter = new jqx.dataAdapter(source); var resourcesAdapterFunc = function () { var resourcesSource = { localData: [ { id: 0, name: 'No name', image: '../jqwidgets/styles/../../images/common.png', common: true }, { id: 1, name: 'Andrew Fuller', image: '../../../images/andrew.png' }, { id: 2, name: 'Janet Leverling', image: '../../../images/janet.png' }, { id: 3, name: 'Steven Buchanan', image: '../../../images/steven.png' }, { id: 4, name: 'Nancy Davolio', image: '../../../images/nancy.png' }, { id: 5, name: 'Michael Buchanan', image: '../../../images/Michael.png' }, { id: 6, name: 'Margaret Buchanan', image: '../../../images/margaret.png' }, { id: 7, name: 'Robert Buchanan', image: '../../../images/robert.png' }, { id: 8, name: 'Laura Buchanan', image: '../../../images/Laura.png' }, { id: 9, name: 'Laura Buchanan', image: '../../../images/Anne.png' } ], dataType: 'array', dataFields: [ { name: 'id', type: 'number' }, { name: 'name', type: 'string' }, { name: 'image', type: 'string' }, { name: 'common', type: 'boolean' } ] }; var resourcesDataAdapter = new jqx.dataAdapter(resourcesSource); return resourcesDataAdapter; } var getIconClassName = function () { switch (theme) { case 'darkblue': case 'black': case 'shinyblack': case 'ui-le-frog': case 'metrodark': case 'orange': case 'darkblue': case 'highcontrast': case 'ui-sunny': case 'ui-darkness': return 'jqx-icon-plus-alt-white '; } return 'jqx-icon-plus-alt'; } JQXElements.settings['Kanban'] = { template: "<div class='jqx-kanban-item' id=''>" + "<div class='jqx-kanban-item-color-status'></div>" + "<div style='display: none;' class='jqx-kanban-item-avatar'></div>" + "<div class='jqx-icon jqx-icon-close jqx-kanban-item-template-content jqx-kanban-template-icon'></div>" + "<div class='jqx-kanban-item-text'></div>" + "<div style='display: none;' class='jqx-kanban-item-footer'></div>" + "</div>", resources: resourcesAdapterFunc(), source: dataAdapter, // render items. itemRenderer: function (element, item, resource) { element[0].getElementsByClassName('jqx-kanban-item-color-status')[0].innerHTML = '<span style="line-height: 23px; margin-left: 5px;">' + resource.name + '</span>'; element[0].getElementsByClassName('jqx-kanban-item-text')[0].style.background = item.color; }, columns: [ { text: 'Backlog', iconClassName: getIconClassName(), dataField: 'new', maxItems: 4 }, { text: 'In Progress', iconClassName: getIconClassName(), dataField: 'work', maxItems: 2 }, { text: 'Done', iconClassName: getIconClassName(), dataField: 'done', maxItems: 5 } ], // render column headers. columnRenderer: function (element, collapsedElement, column) { if (element[0]) { var elementHeaderStatus = element[0].getElementsByClassName('jqx-kanban-column-header-status')[0]; var collapsedElementHeaderStatus = collapsedElement[0].getElementsByClassName('jqx-kanban-column-header-status')[0]; //Get the number of elements in the column var columnItems = document.querySelector('jqx-kanban').getColumnItems(column.dataField.length); elementHeaderStatus.innerHTML = ' (' + columnItems + '/' + column.maxItems + ')'; collapsedElementHeaderStatus.innerHTML = ' (' + columnItems + '/' + column.maxItems + ')'; } } } window.onload = function () { var myKanban = document.querySelector('jqx-kanban'); myKanban.addEventListener('itemAttrClicked', function (event) { var args = event.args; if (args.attribute == 'template') { myKanban.removeItem(args.item.id); } }); var itemIndex = 0; myKanban.addEventListener('columnAttrClicked', function (event) { var args = event.args; if (args.attribute == 'button') { args.cancelToggle = true; if (!args.column.collapsed) { var colors = ['#f19b60', '#5dc3f0', '#6bbd49', '#dddddd'] myKanban.addItem({ status: args.column.dataField, text: "<input placeholder='(No Title)' style='width: 96%; margin-top:2px; border-radius: 3px; border-color: #ddd; line-height:20px; height: 20px;' class='jqx-input' id='newItem" + itemIndex + "' value=''/>", tags: "new task", color: colors[Math.floor(Math.random() * 4)], resourceId: Math.floor(Math.random() * 4) }); var input = document.querySelector('#newItem' + itemIndex); input.addEventListener('mousedown', function (event) { event.stopPropagation(); }); input.addEventListener('mouseup', function (event) { event.stopPropagation(); }); input.addEventListener('keydown', function (event) { if (event.keyCode == 13) { document.querySelector('<span>' + document.querySelector(event.target).val() + '</span>').insertBefore($(event.target)); document.querySelector(event.target).remove(); } }); input.focus(); itemIndex++; } } }); } </script> </head> <body> <div class='example-description'> Custom element Kanban Header Template. </div> <jqx-kanban settings='Kanban'></jqx-kanban> </body> </html>