// form test('table test', function() { App.i18n.set('de-de') $('#table').append('

table simple I

') var el = $('#table1') App.TicketPriority.refresh( [ { id: 1, name: '1 low', note: 'some note 1', active: true, created_at: '2014-06-10T11:17:34.000Z', }, { id: 2, name: '2 normal', note: 'some note 2', active: false, created_at: '2014-06-10T10:17:34.000Z', }, ] ) var rowClick = function (id, e) { e.preventDefault() console.log('rowClick', id, e.target) }; var rowDblClick = function (id, e) { e.preventDefault() console.log('rowDblClick', id, e.target) }; var rowMouseover = function (id, e) { e.preventDefault() console.log('rowMouseover', id, e.target) }; var rowMouseout = function (id, e) { e.preventDefault() console.log('rowMouseout', id, e.target) }; var colClick = function (id, e) { e.preventDefault() console.log('colClick', id, e.target) }; var colDblClick = function (id, e) { e.preventDefault() console.log('colDblClick', id, e.target) }; var colMouseover = function (id, e) { e.preventDefault() console.log('colMouseover', id, e.target) }; var colMouseout = function (id, e) { e.preventDefault() console.log('colMouseout', id, e.target) }; new App.ControllerTable({ el: el, overview: ['name', 'created_at', 'active'], model: App.TicketPriority, objects: App.TicketPriority.search({sortBy:'name', order: 'ASC'}), checkbox: false, radio: false, bindRow: { events: { 'click': rowClick, 'mouseover': rowMouseover, 'mouseout': rowMouseout, 'dblclick': rowDblClick, } }, bindCol: { name: { events: { 'click': colClick, 'mouseover': colMouseover, 'mouseout': colMouseout, 'dblclick': colDblClick, } }, created_at: { events: { 'mouseover': colMouseover, 'mouseout': colMouseout, } } }, }) equal(el.find('table > thead > tr').length, 1, 'row count') equal(el.find('table > thead > tr > th:nth-child(1)').text().trim(), 'Name', 'check header') equal(el.find('table > thead > tr > th:nth-child(2)').text().trim(), 'Erstellt', 'check header') equal(el.find('table > thead > tr > th:nth-child(3)').text().trim(), 'Aktiv', 'check header') equal(el.find('tbody > tr:nth-child(1) > td').length, 3, 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:first').text().trim(), '1 niedrig', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(2)').text().trim(), '10.06.2014', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(3)').text().trim(), 'true', 'check row 1') equal(el.find('tbody > tr:nth-child(2) > td').length, 3, 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:first').text().trim(), '2 normal', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(2)').text().trim(), '10.06.2014', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(3)').text().trim(), 'false', 'check row 2') $('#table').append('

table simple II

') el = $('#table2') new App.ControllerTable({ el: el, overview: ['name', 'created_at', 'active'], model: App.TicketPriority, objects: App.TicketPriority.search({sortBy:'name', order: 'DESC'}), checkbox: false, radio: false, }) equal(el.find('table > thead > tr').length, 1, 'row count') equal(el.find('table > thead > tr > th:nth-child(1)').text().trim(), 'Name', 'check header') equal(el.find('table > thead > tr > th:nth-child(2)').text().trim(), 'Erstellt', 'check header') equal(el.find('table > thead > tr > th:nth-child(3)').text().trim(), 'Aktiv', 'check header') equal(el.find('tbody > tr:nth-child(1) > td').length, 3, 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:first').text().trim(), '2 normal', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(2)').text().trim(), '10.06.2014', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(3)').text().trim(), 'false', 'check row 1') equal(el.find('tbody > tr:nth-child(2) > td').length, 3, 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:first').text().trim(), '1 niedrig', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(2)').text().trim(), '10.06.2014', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(3)').text().trim(), 'true', 'check row 2') $('#table').append('

table simple III

') el = $('#table3') new App.ControllerTable({ el: el, model: App.TicketPriority, objects: App.TicketPriority.search({sortBy:'created_at', order: 'DESC'}), checkbox: false, radio: false, }) equal(el.find('table > thead > tr').length, 1, 'row count') equal(el.find('table > thead > tr > th:nth-child(1)').text().trim(), 'Name', 'check header') notEqual( el.find('table > thead > tr > th:nth-child(2)').text().trim(), 'Erstellt', 'check header') notEqual( el.find('table > thead > tr > th:nth-child(3)').text().trim(), 'Aktiv', 'check header') equal(el.find('tbody > tr:nth-child(2) > td').length, 1, 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:first').text().trim(), '2 normal', 'check row 2') notEqual( el.find('tbody > tr:nth-child(2) > td:nth-child(2)').text().trim(), '?', 'check row 2') notEqual( el.find('tbody > tr:nth-child(2) > td:nth-child(3)').text().trim(), 'true', 'check row 2') equal(el.find('tbody > tr:nth-child(1) > td').length, 1, 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:first').text().trim(), '1 niedrig', 'check row 1') notEqual( el.find('tbody > tr:nth-child(1) > td:nth-child(2)').text().trim(), '?', 'check row 1') notEqual( el.find('tbody > tr:nth-child(1) > td:nth-child(3)').text().trim(), 'false', 'check row 1') App.Group.refresh( [ { id: 1, name: 'group 1', active: true, created_at: '2014-06-10T11:17:34.000Z', }, { id: 2, name: 'group 2', active: true, created_at: '2014-06-10T11:17:34.000Z', }, ]) App.User.refresh( [ { id: 55, login: 'login55', firstname: 'firstname55', lastname: 'lastname55', email: 'email55', active: true, created_at: '2014-06-10T11:17:34.000Z', }, { id: 56, login: 'login56', firstname: 'firstname56', lastname: 'lastname56', email: 'email56', active: true, created_at: '2014-06-10T11:17:34.000Z', }, ]) App.TicketState.refresh( [ { id: 1, name: 'new', active: true, created_at: '2014-06-10T11:17:34.000Z', }, { id: 2, name: 'open', note: 'some note 2', active: false, created_at: '2014-06-10T10:17:34.000Z', }, ]) App.Ticket.refresh( [ { id: 1, title: 'some title 1', number: '4711', priority_id: 1, owner_id: 55, customer_id: 56, state_id: 1, group_id: 2, created_at: '2014-06-10T11:17:34.000Z', }, { id: 3, title: 'some title 3', number: '4713', priority_id: 2, owner_id: 56, state_id: 1, group_id: 2, created_at: '2014-07-11T11:19:34.000Z', }, { id: 2, title: 'some title 2', number: '4712', priority_id: 1, state_id: 2, group_id: 1, created_at: '2014-06-10T11:19:34.000Z', }, ]) $('#table').append('

table complex I

') el = $('#table4') new App.ControllerTable({ el: el, overview: ['number', 'title', 'owner', 'customer', 'priority', 'group', 'state', 'created_at'], model: App.Ticket, objects: App.Ticket.search({sortBy:'created_at', order: 'DESC'}), checkbox: true, }) equal(el.find('table > thead > tr').length, 1, 'row count') equal(el.find('table > thead > tr > th:nth-child(1)').text().trim(), '', 'check header') equal(el.find('table > thead > tr > th:nth-child(2)').text().trim(), '#', 'check header') equal(el.find('table > thead > tr > th:nth-child(3)').text().trim(), 'Titel', 'check header') equal(el.find('table > thead > tr > th:nth-child(4)').text().trim(), 'Besitzer', 'check header') equal(el.find('table > thead > tr > th:nth-child(5)').text().trim(), 'Kunde', 'check header') equal(el.find('table > thead > tr > th:nth-child(6)').text().trim(), 'Priorität', 'check header') equal(el.find('table > thead > tr > th:nth-child(7)').text().trim(), 'Gruppe', 'check header') equal(el.find('table > thead > tr > th:nth-child(8)').text().trim(), 'Status', 'check header') equal(el.find('table > thead > tr > th:nth-child(9)').text().trim(), 'Erstellt am', 'check header') equal(el.find('tbody > tr:nth-child(1) > td').length, 9, 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(1) input').val(), '3', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(1) input').prop('checked'), '', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(1)').text().trim(), '', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(2)').text().trim(), '4713', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(3)').text().trim(), 'some title 3', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(4)').text().trim(), 'firstname56 lastname56', 'check row 2') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(5)').text().trim(), '-', 'check row 2') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(6)').text().trim(), '2 normal', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(7)').text().trim(), 'group 2', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(8)').text().trim(), 'neu', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(9)').text().trim(), '11.07.2014', 'check row 1') equal(el.find('tbody > tr:nth-child(2) > td').length, 9, 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(1) input').val(), '2', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(1) input').prop('checked'), '', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(1)').text().trim(), '', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(2)').text().trim(), '4712', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(3)').text().trim(), 'some title 2', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(4)').text().trim(), '-', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(5)').text().trim(), '-', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(6)').text().trim(), '1 niedrig', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(7)').text().trim(), 'group 1', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(8)').text().trim(), 'offen', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(9)').text().trim(), '10.06.2014', 'check row 2') equal(el.find('tbody > tr:nth-child(3) > td').length, 9, 'check row 3') equal(el.find('tbody > tr:nth-child(3) > td:nth-child(1) input').val(), '1', 'check row 3') equal(el.find('tbody > tr:nth-child(3) > td:nth-child(1) input').prop('checked'), '', 'check row 3') equal(el.find('tbody > tr:nth-child(3) > td:nth-child(1)').text().trim(), '', 'check row 3') equal(el.find('tbody > tr:nth-child(3) > td:nth-child(2)').text().trim(), '4711', 'check row 3') equal(el.find('tbody > tr:nth-child(3) > td:nth-child(3)').text().trim(), 'some title 1', 'check row 3') equal(el.find('tbody > tr:nth-child(3) > td:nth-child(4)').text().trim(), 'firstname55 lastname55', 'check row 2') equal(el.find('tbody > tr:nth-child(3) > td:nth-child(5)').text().trim(), 'firstname56 lastname56', 'check row 2') equal(el.find('tbody > tr:nth-child(3) > td:nth-child(6)').text().trim(), '1 niedrig', 'check row 3') equal(el.find('tbody > tr:nth-child(3) > td:nth-child(7)').text().trim(), 'group 2', 'check row 3') equal(el.find('tbody > tr:nth-child(3) > td:nth-child(8)').text().trim(), 'neu', 'check row 3') equal(el.find('tbody > tr:nth-child(3) > td:nth-child(9)').text().trim(), '10.06.2014', 'check row 3') el.find('input[name="bulk_all"]').click() equal(el.find('tbody > tr:nth-child(1) > td:nth-child(1) input').prop('checked'), true, 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(1) input').val(), '3', 'check row 1') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(1) input').prop('checked'), true, 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(1) input').val(), '2', 'check row 2') equal(el.find('tbody > tr:nth-child(3) > td:nth-child(1) input').prop('checked'), true, 'check row 3') equal(el.find('tbody > tr:nth-child(3) > td:nth-child(1) input').val(), '1', 'check row 3') $('#table').append('

table complex II

') el = $('#table5') var clickCheckbox = function (id, checked, e) { console.log('clickCheckbox', id, checked, e.target) }; new App.ControllerTable({ el: el, overview: ['number', 'title', 'owner', 'customer', 'priority', 'group', 'state', 'created_at'], model: App.Ticket, objects: App.Ticket.search({sortBy:'created_at', order: 'DESC'}), checkbox: true, groupBy: 'group', bindCheckbox: { events: { 'click': clickCheckbox, } }, }) equal(el.find('table > thead > tr').length, 1, 'row count') equal(el.find('table > thead > tr > th:nth-child(1)').text().trim(), '', 'check header') equal(el.find('table > thead > tr > th:nth-child(2)').text().trim(), '#', 'check header') equal(el.find('table > thead > tr > th:nth-child(3)').text().trim(), 'Titel', 'check header') equal(el.find('table > thead > tr > th:nth-child(4)').text().trim(), 'Besitzer', 'check header') equal(el.find('table > thead > tr > th:nth-child(5)').text().trim(), 'Kunde', 'check header') equal(el.find('table > thead > tr > th:nth-child(6)').text().trim(), 'Priorität', 'check header') equal(el.find('table > thead > tr > th:nth-child(7)').text().trim(), 'Status', 'check header') equal(el.find('table > thead > tr > th:nth-child(8)').text().trim(), 'Erstellt am', 'check header') equal(el.find('tbody > tr:nth-child(1) > td').length, 1, 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(1)').text().trim(), 'group 1', 'check row 1') equal(el.find('tbody > tr:nth-child(2) > td').length, 8, 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(1) input').val(), '2', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(1) input').prop('checked'), '', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(1)').text().trim(), '', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(2)').text().trim(), '4712', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(3)').text().trim(), 'some title 2', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(4)').text().trim(), '-', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(5)').text().trim(), '-', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(6)').text().trim(), '1 niedrig', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(7)').text().trim(), 'offen', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(8)').text().trim(), '10.06.2014', 'check row 2') equal(el.find('tbody > tr:nth-child(3) > td').length, 1, 'check row 3') equal(el.find('tbody > tr:nth-child(3) > td:nth-child(1)').text().trim(), 'group 2', 'check row 4') equal(el.find('tbody > tr:nth-child(4) > td').length, 8, 'check row 4') equal(el.find('tbody > tr:nth-child(4) > td:nth-child(1) input').val(), '3', 'check row 4') equal(el.find('tbody > tr:nth-child(4) > td:nth-child(1) input').prop('checked'), '', 'check row 4') equal(el.find('tbody > tr:nth-child(4) > td:nth-child(1)').text().trim(), '', 'check row 4') equal(el.find('tbody > tr:nth-child(4) > td:nth-child(2)').text().trim(), '4713', 'check row 4') equal(el.find('tbody > tr:nth-child(4) > td:nth-child(3)').text().trim(), 'some title 3', 'check row 4') equal(el.find('tbody > tr:nth-child(4) > td:nth-child(4)').text().trim(), 'firstname56 lastname56', 'check row 2') equal(el.find('tbody > tr:nth-child(4) > td:nth-child(5)').text().trim(), '-', 'check row 2') equal(el.find('tbody > tr:nth-child(4) > td:nth-child(6)').text().trim(), '2 normal', 'check row 4') equal(el.find('tbody > tr:nth-child(4) > td:nth-child(7)').text().trim(), 'neu', 'check row 4') equal(el.find('tbody > tr:nth-child(4) > td:nth-child(8)').text().trim(), '11.07.2014', 'check row 4') el.find('input[name="bulk"]:eq(1)').click() equal(el.find('tbody > tr:nth-child(2) > td:nth-child(1) input').prop('checked'), '', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(1) input').val(), '2', 'check row 1') equal(el.find('tbody > tr:nth-child(4) > td:nth-child(1) input').prop('checked'), true, 'check row 4') equal(el.find('tbody > tr:nth-child(4) > td:nth-child(1) input').val(), '3', 'check row 4') equal(el.find('tbody > tr:nth-child(5) > td:nth-child(1) input').prop('checked'), '', 'check row 5') equal(el.find('tbody > tr:nth-child(5) > td:nth-child(1) input').val(), '1', 'check row 5') el.find('tbody > tr:nth-child(5) > td:nth-child(1) label').click() equal(el.find('tbody > tr:nth-child(5) > td:nth-child(1) input').prop('checked'), true, 'check row 5') equal(el.find('tbody > tr:nth-child(5) > td:nth-child(1) input').val(), '1', 'check row 5') $('#table').append('

table Group By Direction DESC

') el = $('#table6') var clickCheckbox = function (id, checked, e) { console.log('clickCheckbox', id, checked, e.target) }; new App.ControllerTable({ el: el, overview: ['number', 'title', 'owner', 'customer', 'priority', 'group', 'state', 'created_at'], model: App.Ticket, objects: App.Ticket.search({sortBy:'created_at', order: 'DESC'}), groupBy: 'priority', groupDirection: 'DESC', }) equal(el.find('tbody > tr:nth-child(1) > td:nth-child(1)').text().trim(), '1 niedrig', 'check row 1') equal(el.find('tbody > tr:nth-child(4) > td:nth-child(1)').text().trim(), '2 normal', 'check row 3') $('#table').append('

table Group By Direction ASC

') el = $('#table7') var clickCheckbox = function (id, checked, e) { console.log('clickCheckbox', id, checked, e.target) }; new App.ControllerTable({ el: el, overview: ['number', 'title', 'owner', 'customer', 'priority', 'group', 'state', 'created_at'], model: App.Ticket, objects: App.Ticket.search({sortBy:'created_at', order: 'DESC'}), groupBy: 'priority', groupDirection: 'ASC', }) equal(el.find('tbody > tr:nth-child(1) > td:nth-child(1)').text().trim(), '1 niedrig', 'check row 1') equal(el.find('tbody > tr:nth-child(4) > td:nth-child(1)').text().trim(), '2 normal', 'check row 4') }); test('table test 2.1', function() { App.i18n.set('de-de') $('#table').append('

table with hash

') var el = $('#table-hash2_1') App.Group.refresh( [ { id: 5, name: 'group 5', active: true, created_at: '2014-06-10T11:17:34.000Z', }, ]) App.Channel.configure_delete = true App.Channel.configure_clone = false App.Channel.configure_attributes = [ { name: 'adapter', display: 'Type', tag: 'select', multiple: false, null: false, options: { IMAP: 'IMAP', POP3: 'POP3' } }, { name: 'options::host', display: 'Host', tag: 'input', type: 'text', limit: 120, null: true, autocapitalize: false }, { name: 'options::user', display: 'User', tag: 'input', type: 'text', limit: 120, null: true, autocapitalize: false }, { name: 'options::password', display: 'Password', tag: 'input', type: 'password', limit: 120, null: true, autocapitalize: false }, { name: 'options::ssl', display: 'SSL', tag: 'select', multiple: false, null: true, options: { true: 'yes', false: 'no' }, translate: true, default: true}, { name: 'options::folder', display: 'Folder', tag: 'input', type: 'text', limit: 120, null: true, autocapitalize: false }, { name: 'group_id', display: 'Group', tag: 'select', multiple: false, null: false, nulloption: true, relation: 'Group' }, { name: 'active', display: 'Active', tag: 'select', multiple: false, null: false, options: { true: 'yes', false: 'no' }, translate: true, default: true }, ] App.Channel.refresh( [ { id: 1, adapter: 'adapter1', options: { host: 'host1', user: 'user1', }, group_id: 5, active: true, created_at: '2014-06-10T11:17:34.000Z', }, { id: 2, adapter: 'adapter2', options: { host: 'host2', user: 'user2', }, group_id: 5, active: true, created_at: '2014-06-10T11:17:34.000Z', }, ] ) new App.ControllerTable({ el: el, overview: ['adapter', 'options::host', 'options::user', 'active'], model: App.Channel, objects: App.Channel.search({sortBy:'adapter', order: 'ASC'}), }) equal(el.find('table > thead > tr').length, 1, 'row count') equal(el.find('table > thead > tr > th:nth-child(1)').text().trim(), 'Typ', 'check header') equal(el.find('table > thead > tr > th:nth-child(2)').text().trim(), 'Host', 'check header') equal(el.find('table > thead > tr > th:nth-child(3)').text().trim(), 'Benutzer', 'check header') equal(el.find('table > thead > tr > th:nth-child(4)').text().trim(), 'Aktiv', 'check header') equal(el.find('table > thead > tr > th:nth-child(5)').text().trim(), 'Aktion', 'check header') equal(el.find('tbody > tr:nth-child(1) > td').length, 5, 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(1)').text().trim(), 'adapter1', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(2)').text().trim(), 'host1', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(3)').text().trim(), 'user1', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(4)').text().trim(), 'ja', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(5)').text().trim(), '', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(5) .dropdown.dropdown--actions').length, 0, 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(5) .js-delete').length, 1, 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(5) .js-clone').length, 0, 'check row 1') equal(el.find('tbody > tr:nth-child(2) > td').length, 5, 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(1)').text().trim(), 'adapter2', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(2)').text().trim(), 'host2', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(3)').text().trim(), 'user2', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(4)').text().trim(), 'ja', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(5)').text().trim(), '', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(5) .dropdown.dropdown--actions').length, 0, 'check row 1') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(5) .js-delete').length, 1, 'check row 1') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(5) .js-clone').length, 0, 'check row 1') }); test('table test 2.2', function() { App.i18n.set('de-de') $('#table').append('

table with hash

') var el = $('#table-hash2_2') App.Group.refresh( [ { id: 5, name: 'group 5', active: true, created_at: '2014-06-10T11:17:34.000Z', }, ]) App.Channel.configure_delete = false App.Channel.configure_clone = true App.Channel.configure_attributes = [ { name: 'adapter', display: 'Type', tag: 'select', multiple: false, null: false, options: { IMAP: 'IMAP', POP3: 'POP3' } }, { name: 'options::host', display: 'Host', tag: 'input', type: 'text', limit: 120, null: true, autocapitalize: false }, { name: 'options::user', display: 'User', tag: 'input', type: 'text', limit: 120, null: true, autocapitalize: false }, { name: 'options::password', display: 'Password', tag: 'input', type: 'password', limit: 120, null: true, autocapitalize: false }, { name: 'options::ssl', display: 'SSL', tag: 'select', multiple: false, null: true, options: { true: 'yes', false: 'no' }, translate: true, default: true}, { name: 'options::folder', display: 'Folder', tag: 'input', type: 'text', limit: 120, null: true, autocapitalize: false }, { name: 'group_id', display: 'Group', tag: 'select', multiple: false, null: false, nulloption: true, relation: 'Group' }, { name: 'active', display: 'Active', tag: 'select', multiple: false, null: false, options: { true: 'yes', false: 'no' }, translate: true, default: true }, ] App.Channel.refresh( [ { id: 1, adapter: 'adapter1', options: { host: 'host1', user: 'user1', }, group_id: 5, active: true, created_at: '2014-06-10T11:17:34.000Z', }, { id: 2, adapter: 'adapter2', options: { host: 'host2', user: 'user2', }, group_id: 5, active: true, created_at: '2014-06-10T11:17:34.000Z', }, ] ) new App.ControllerTable({ el: el, overview: ['adapter', 'options::host', 'options::user', 'active'], model: App.Channel, objects: App.Channel.search({sortBy:'adapter', order: 'ASC'}), }) equal(el.find('table > thead > tr').length, 1, 'row count') equal(el.find('table > thead > tr > th:nth-child(1)').text().trim(), 'Typ', 'check header') equal(el.find('table > thead > tr > th:nth-child(2)').text().trim(), 'Host', 'check header') equal(el.find('table > thead > tr > th:nth-child(3)').text().trim(), 'Benutzer', 'check header') equal(el.find('table > thead > tr > th:nth-child(4)').text().trim(), 'Aktiv', 'check header') equal(el.find('table > thead > tr > th:nth-child(5)').text().trim(), 'Aktion', 'check header') equal(el.find('tbody > tr:nth-child(1) > td').length, 5, 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(1)').text().trim(), 'adapter1', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(2)').text().trim(), 'host1', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(3)').text().trim(), 'user1', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(4)').text().trim(), 'ja', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(5)').text().trim(), '', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(5) .dropdown.dropdown--actions').length, 0, 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(5) .js-delete').length, 0, 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(5) .js-clone').length, 1, 'check row 1') equal(el.find('tbody > tr:nth-child(2) > td').length, 5, 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(1)').text().trim(), 'adapter2', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(2)').text().trim(), 'host2', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(3)').text().trim(), 'user2', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(4)').text().trim(), 'ja', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(5)').text().trim(), '', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(5) .dropdown.dropdown--actions').length, 0, 'check row 1') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(5) .js-delete').length, 0, 'check row 1') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(5) .js-clone').length, 1, 'check row 1') }); test('table test 3', function() { App.i18n.set('de-de') $('#table').append('

table with hash

') var el = $('#table-hash2') App.Group.refresh( [ { id: 5, name: 'group 5', active: true, created_at: '2014-06-10T11:17:34.000Z', }, ]) App.Channel.configure_delete = true App.Channel.configure_clone = true App.Channel.configure_attributes = [ { name: 'adapter', display: 'Type', tag: 'select', multiple: false, null: false, options: { IMAP: 'IMAP', POP3: 'POP3' } }, { name: 'options::host', display: 'Host', tag: 'input', type: 'text', limit: 120, null: true, autocapitalize: false }, { name: 'options::user', display: 'User', tag: 'input', type: 'text', limit: 120, null: true, autocapitalize: false }, { name: 'options::password', display: 'Password', tag: 'input', type: 'password', limit: 120, null: true, autocapitalize: false }, { name: 'options::ssl', display: 'SSL', tag: 'select', multiple: false, null: true, options: { true: 'yes', false: 'no' }, translate: true, default: true}, { name: 'options::folder', display: 'Folder', tag: 'input', type: 'text', limit: 120, null: true, autocapitalize: false }, { name: 'group_id', display: 'Group', tag: 'select', multiple: false, null: false, nulloption: true, relation: 'Group' }, { name: 'active', display: 'Active', tag: 'select', multiple: false, null: false, options: { true: 'yes', false: 'no' }, translate: true, default: true }, ] App.Channel.refresh( [ { id: 1, adapter: 'adapter1', options: { host: 'host1', user: 'user1', }, group_id: 5, active: true, created_at: '2014-06-10T11:17:34.000Z', }, { id: 2, adapter: 'adapter2', options: { host: 'host2', user: 'user2', }, group_id: 5, active: true, created_at: '2014-06-10T11:17:34.000Z', }, ] ) new App.ControllerTable({ el: el, overview: ['adapter', 'options::host', 'options::user', 'active'], model: App.Channel, objects: App.Channel.search({sortBy:'adapter', order: 'ASC'}), }) equal(el.find('table > thead > tr').length, 1, 'row count') equal(el.find('table > thead > tr > th:nth-child(1)').text().trim(), 'Typ', 'check header') equal(el.find('table > thead > tr > th:nth-child(2)').text().trim(), 'Host', 'check header') equal(el.find('table > thead > tr > th:nth-child(3)').text().trim(), 'Benutzer', 'check header') equal(el.find('table > thead > tr > th:nth-child(4)').text().trim(), 'Aktiv', 'check header') equal(el.find('table > thead > tr > th:nth-child(5)').text().trim(), 'Aktion', 'check header') equal(el.find('tbody > tr:nth-child(1) > td').length, 5, 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(1)').text().trim(), 'adapter1', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(2)').text().trim(), 'host1', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(3)').text().trim(), 'user1', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(4)').text().trim(), 'ja', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(5) .dropdown.dropdown--actions .js-delete').length, 1, 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(5) .dropdown.dropdown--actions .js-clone').length, 1, 'check row 1') equal(el.find('tbody > tr:nth-child(2) > td').length, 5, 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(1)').text().trim(), 'adapter2', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(2)').text().trim(), 'host2', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(3)').text().trim(), 'user2', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(4)').text().trim(), 'ja', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(5) .dropdown.dropdown--actions .js-delete').length, 1, 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(5) .dropdown.dropdown--actions .js-clone').length, 1, 'check row 2') }); test('table test 4', function() { App.i18n.set('de-de') $('#table').append('

table with link

') var el = $('#table-link1') App.EmailAddress.refresh( [ { id: 55, realname: 'realname 55', email: 'email 55', active: true, created_at: '2014-06-10T11:17:34.000Z', }, { id: 56, realname: 'realname 56', email: 'email 56', active: true, created_at: '2014-06-10T11:17:34.000Z', }, ]) var callbackHeader = function (header) { console.log('current header is', header); // add new header item var attribute = { name: 'some name', display: 'Some Name', }; header.push(attribute); console.log('new header is', header); return header } var callbackAttributes = function(value, object, attribute, header, refObject) { console.log('data of item col', value, object, attribute, header, refObject) value = ' ' attribute.class = 'glyphicon glyphicon-user' attribute.link = '#' attribute.title = App.i18n.translateInline('Switch to') if (object.id == 55) { attribute.data = { some: 'value55', xxx: 55, } } else { attribute.data = { some: 'value56', xxx: 56, } } return value } var switchTo = function(id, e) { e.preventDefault() console.log('switchTo with id', id, e.target) //@disconnectClient() //App.Auth._logout() //window.location = App.Config.get('api_path') + '/sessions/switch/' + id } new App.ControllerTable({ el: el, model: App.EmailAddress, objects: App.EmailAddress.search({sortBy:'realname', order: 'ASC'}), callbackHeader: [callbackHeader], callbackAttributes: { 'some name': [ callbackAttributes ] }, bindCol: { 'some name': { events: { 'click': switchTo, } }, }, }) equal(el.find('table > thead > tr').length, 1, 'row count') equal(el.find('table > thead > tr > th:nth-child(1)').text().trim(), 'Anzeigename', 'check header') equal(el.find('table > thead > tr > th:nth-child(3)').text().trim(), 'Some Name', 'check header') equal(el.find('tbody > tr:nth-child(1) > td').length, 3, 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(1)').text().trim(), 'realname 55', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(2)').text().trim(), 'email 55', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(3)').text().trim(), '', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(3) > a > span').hasClass('glyphicon-user'), true, 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(3) > a > span').hasClass('glyphicon'), true, 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(3)').attr('title'), 'Umschalten zu', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(3) > a > span').data('some'), 'value55', 'check row 2') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(3) > a > span').data('xxx'), '55', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td').length, 3, 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(1)').text().trim(), 'realname 56', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(2)').text().trim(), 'email 56', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(3)').text().trim(), '', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(3) > a > span').hasClass('glyphicon-user'), true, 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(3) > a > span').hasClass('glyphicon'), true, 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(3)').attr('title'), 'Umschalten zu', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(3) > a > span').data('some'), 'value56', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(3) > a > span').data('xxx'), '56', 'check row 2') }); test('table test 5', function() { App.i18n.set('de-de') $('#table').append('

table with data

') var el = $('#table-data1') data = [ { name: 'some name 1', data: 'some data 1', active: true }, { name: 'some name 2', data: 'some data 2', active: false }, { name: 'some name 3', data: 'some data 3', active: true }, ] new App.ControllerTable({ el: el, overview: ['name', 'data', 'active'], attribute_list: [ { name: 'name', display: 'Name', type: 'text', style: 'width: 10%' }, { name: 'data', display: 'Data', type: 'text' }, { name: 'active', display: 'Active', type: 'text' }, ], objects: data }); equal(el.find('table > thead > tr').length, 1, 'row count') equal(el.find('table > thead > tr > th:nth-child(1)').text().trim(), 'Name', 'check header') equal(el.find('table > thead > tr > th:nth-child(2)').text().trim(), 'Data', 'check header') equal(el.find('table > thead > tr > th:nth-child(3)').text().trim(), 'Aktiv', 'check header') equal(el.find('tbody > tr:nth-child(1) > td').length, 3, 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:first').text().trim(), 'some name 1', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(2)').text().trim(), 'some data 1', 'check row 1') equal(el.find('tbody > tr:nth-child(1) > td:nth-child(3)').text().trim(), 'true', 'check row 1') equal(el.find('tbody > tr:nth-child(2) > td').length, 3, 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:first').text().trim(), 'some name 2', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(2)').text().trim(), 'some data 2', 'check row 2') equal(el.find('tbody > tr:nth-child(2) > td:nth-child(3)').text().trim(), 'false', 'check row 2') }); test('table test 6/7', function() { $('#table').append('

sotable table with data

') var el_head_sortable = $('#table-data6') $('#table').append('

not sortable table with data

') var el_not_head_sortable = $('#table-data7') data = [ { name: 'a item', data: 'g data', active: true }, { name: 'b item', data: 'b data', active: false }, { name: 'c item', data: 'z data', active: false }, { name: 'd item', data: '', active: false }, ] new App.ControllerTable({ tableId: 'a', el: el_head_sortable, overview: ['name', 'data', 'active'], attribute_list: [ { name: 'name', display: 'Name', type: 'text', style: 'width: 10%', unsortable: true }, { name: 'data', display: 'Data', type: 'text' }, { name: 'active', display: 'Active', type: 'text' }, ], objects: data }); new App.ControllerTable({ tableId: 'b', el: el_not_head_sortable, overview: ['name', 'data', 'active'], attribute_list: [ { name: 'name', display: 'Name', type: 'text', style: 'width: 10%', unsortable: true }, { name: 'data', display: 'Data', type: 'text' }, { name: 'active', display: 'Active', type: 'text' }, ], objects: data, dndCallback: function() { return true } }); equal(el_head_sortable.find('tbody > tr:nth-child(1) > td:first').text().trim(), 'a item', 'check row 1') equal(el_not_head_sortable.find('tbody > tr:nth-child(1) > td:nth-child(2)').text().trim(), 'a item', 'check row 1') ok(_.isEqual(list_items(el_head_sortable, 1), ['a item', 'b item', 'c item', 'd item']), 'sortable table is rendered correctly') ok(_.isEqual(list_items(el_not_head_sortable, 2), ['a item', 'b item', 'c item', 'd item']), 'unsortable table is rendered correctly') click_sort(el_head_sortable, 2) click_sort(el_not_head_sortable, 3) ok(_.isEqual(list_items(el_head_sortable, 1), ['b item', 'a item', 'c item', 'd item']), 'sortable table is sorted') ok(_.isEqual(list_items(el_not_head_sortable, 2), ['a item', 'b item', 'c item', 'd item']), 'unsortable table is not sorted') click_sort(el_head_sortable, 3) ok(_.isEqual(list_items(el_head_sortable, 1), ['b item', 'c item', 'd item', 'a item']), 'sorting by boolean column works') click_sort(el_head_sortable, 1) ok(_.isEqual(list_items(el_head_sortable, 1), ['b item', 'c item', 'd item', 'a item']), 'sorting on name column is disabled') }); function click_sort(table, column_number) { table .find(`table > thead > tr > th:nth-child(${column_number}) > .js-sort`) .click() } function list_items(table, column_number) { return table .find(`tbody > tr > td:nth-child(${column_number})`) .text() .split("\n") .filter(elem => elem.match(/[\w]+/)) .map(elem => elem.trim()) }