UNPKG

jqwidgets-framework

Version:

jQWidgets is an advanced Angular, Vue, Blazor, React, Web Components, jquery, ASP .NET MVC, Custom Elements and HTML5 UI framework.

181 lines (175 loc) 8.38 kB
<!DOCTYPE html> <html> <head> <title></title> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <link rel="stylesheet" href="../../../jqwidgets/styles/jqx.base.css" type="text/css" /> <link rel="stylesheet" href="../../../jqwidgets/styles/jqx.metro.css" type="text/css" /> <link rel="stylesheet" href="../../../styles/bootstrap.min.css" /> <link rel="stylesheet" href="../../../styles/bootstrap-theme.min.css" /> <script type="text/javascript" src="../../../scripts/jquery-1.11.1.min.js"></script> <script type="text/javascript" src="../../../scripts/bootstrap.min.js"></script> <script type="text/javascript" src="../../../jqwidgets/jqxcore.js"></script> <script type="text/javascript" src="../../../jqwidgets/jqxdata.js"></script> <script type="text/javascript" src="../../../jqwidgets/jqxbuttons.js"></script> <script type="text/javascript" src="../../../scripts/demos.js"></script> <script type="text/javascript" src="../../../jqwidgets/jqxdraw.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/jqxsplitter.js"></script> <script type="text/javascript"> $(document).ready(function () { 'use strict'; var fields = [ { name: 'id', type: 'string' }, { name: 'status', map: 'state', type: 'string' }, { name: 'text', map: 'label', type: 'string' }, { name: 'color', map: 'hex', type: 'string' }, { name: 'resourceId', type: 'number' } ]; var source = { url: 'data.php?usedwidget=taskskanban', datatype: 'json', 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'; }; $('#tasks').jqxKanban({ template: '<div class="jqx-kanban-item" id="">' + '<div class="jqx-kanban-item-color-status"></div>' + '<div class="jqx-kanban-item-text"></div>' + '<div style="display: none;" class="jqx-kanban-item-footer"></div>' + '</div>', resources: resourcesAdapterFunc(), width: '100%', height: 680, theme: 'metro', source: dataAdapter, itemRenderer: function (element, item, resource) { $(element).find('.jqx-kanban-item-color-status').html('<span style="line-height: 23px; margin-left: 5px; color:white;">' + resource.name + '</span>'); }, columns: [ { text: 'Backlog', iconClassName: getIconClassName(), dataField: 'new' }, { text: 'In Progress', iconClassName: getIconClassName(), dataField: 'work' }, { text: 'Done', iconClassName: getIconClassName(), dataField: 'done' } ] }); $('#tasks').on('itemAttrClicked', function (event) { var args = event.args; if (args.attribute === 'template') { $('#tasks').jqxKanban('removeItem', args.item.id); } }); var itemIndex = 0; $('#tasks').on('columnAttrClicked', function (event) { var args = event.args; if (args.attribute === 'button') { args.cancelToggle = true; if (!args.column.collapsed) { var colors = ['#f19b60', '#5dc3f0', '#6bbd49', '#732794']; $('#tasks').jqxKanban('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 = $('#newItem' + itemIndex); input.mousedown(function (event) { event.stopPropagation(); }); input.mouseup(function (event) { event.stopPropagation(); }); input.keydown(function (event) { if (event.keyCode === 13) { $('<span>' + $(event.target).val() + '</span>').insertBefore($(event.target)); $(event.target).remove(); } }); input.focus(); itemIndex++; } } }); }); </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; } .jqx-kanban-item-text { padding-top: 6px; } .jqx-kanban-item-avatar { top: 9px; } .jqx-kanban-template-icon { position: absolute; right: 3px; top: 12px; } </style> </head> <body> <div class="container" style="overflow:hidden;"> <div id="tasks"></div> </div> </body> </html>