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
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>