parent
146e9eeb9f
commit
802d7e010d
@ -0,0 +1,22 @@ |
||||
/** |
||||
* @copyright Copyright (c) 2023 Lucas Azevedo <lhs_azevedo@hotmail.com> |
||||
* |
||||
* @author Lucas Azevedo <lhs_azevedo@hotmail.com> |
||||
* |
||||
* @license AGPL-3.0-or-later |
||||
* |
||||
* This program is free software: you can redistribute it and/or modify |
||||
* it under the terms of the GNU Affero General Public License as |
||||
* published by the Free Software Foundation, either version 3 of the |
||||
* License, or (at your option) any later version. |
||||
* |
||||
* This program is distributed in the hope that it will be useful, |
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
* GNU Affero General Public License for more details. |
||||
* |
||||
* You should have received a copy of the GNU Affero General Public License |
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
* |
||||
*/ |
||||
export default {} |
||||
@ -0,0 +1,143 @@ |
||||
/** |
||||
* @copyright Copyright (c) 2023 Lucas Azevedo <lhs_azevedo@hotmail.com> |
||||
* |
||||
* @author Lucas Azevedo <lhs_azevedo@hotmail.com> |
||||
* |
||||
* @license AGPL-3.0-or-later |
||||
* |
||||
* This program is free software: you can redistribute it and/or modify |
||||
* it under the terms of the GNU Affero General Public License as |
||||
* published by the Free Software Foundation, either version 3 of the |
||||
* License, or (at your option) any later version. |
||||
* |
||||
* This program is distributed in the hope that it will be useful, |
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
* GNU Affero General Public License for more details. |
||||
* |
||||
* You should have received a copy of the GNU Affero General Public License |
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>. |
||||
* |
||||
*/ |
||||
import { action } from './inlineSystemTagsAction' |
||||
import { expect } from '@jest/globals' |
||||
import { File, Permission, View, FileAction } from '@nextcloud/files' |
||||
|
||||
const view = { |
||||
id: 'files', |
||||
name: 'Files', |
||||
} as View |
||||
|
||||
describe('Inline system tags action conditions tests', () => { |
||||
test('Default values', () => { |
||||
const file = new File({ |
||||
id: 1, |
||||
source: 'https://cloud.domain.com/remote.php/dav/files/admin/foobar.txt', |
||||
owner: 'admin', |
||||
mime: 'text/plain', |
||||
permissions: Permission.ALL, |
||||
}) |
||||
|
||||
expect(action).toBeInstanceOf(FileAction) |
||||
expect(action.id).toBe('system-tags') |
||||
expect(action.displayName([file], view)).toBe('') |
||||
expect(action.iconSvgInline([], view)).toBe('') |
||||
expect(action.default).toBeUndefined() |
||||
expect(action.enabled).toBeUndefined() |
||||
expect(action.order).toBe(0) |
||||
}) |
||||
}) |
||||
|
||||
describe('Inline system tags action render tests', () => { |
||||
test('Render nothing when Node does not have system tags', async () => { |
||||
const file = new File({ |
||||
id: 1, |
||||
source: 'http://localhost/remote.php/dav/files/admin/foobar.txt', |
||||
owner: 'admin', |
||||
mime: 'text/plain', |
||||
permissions: Permission.ALL, |
||||
}) |
||||
|
||||
const result = await action.renderInline!(file, view) |
||||
expect(result).toBeNull() |
||||
}) |
||||
|
||||
test('Render a single system tag', async () => { |
||||
const file = new File({ |
||||
id: 1, |
||||
source: 'http://localhost/remote.php/dav/files/admin/foobar.txt', |
||||
owner: 'admin', |
||||
mime: 'text/plain', |
||||
permissions: Permission.ALL, |
||||
attributes: { |
||||
'system-tags': { |
||||
'system-tag': 'Confidential' |
||||
} |
||||
} |
||||
}) |
||||
|
||||
const result = await action.renderInline!(file, view) |
||||
expect(result).toBeInstanceOf(HTMLElement) |
||||
expect(result!.outerHTML).toBe( |
||||
'<ul class="files-list__system-tags" aria-label="This file has the tag Confidential">' +
|
||||
'<li class="files-list__system-tag">Confidential</li>' + |
||||
'</ul>' |
||||
) |
||||
}) |
||||
|
||||
test('Render two system tags', async () => { |
||||
const file = new File({ |
||||
id: 1, |
||||
source: 'http://localhost/remote.php/dav/files/admin/foobar.txt', |
||||
owner: 'admin', |
||||
mime: 'text/plain', |
||||
permissions: Permission.ALL, |
||||
attributes: { |
||||
'system-tags': { |
||||
'system-tag': [ |
||||
'Important', |
||||
'Confidential' |
||||
] |
||||
} |
||||
} |
||||
}) |
||||
|
||||
const result = await action.renderInline!(file, view) |
||||
expect(result).toBeInstanceOf(HTMLElement) |
||||
expect(result!.outerHTML).toBe( |
||||
'<ul class="files-list__system-tags" aria-label="This file has the tags Important and Confidential">' +
|
||||
'<li class="files-list__system-tag">Important</li>' + |
||||
'<li class="files-list__system-tag files-list__system-tag--more" title="Confidential">+1</li>' + |
||||
'</ul>' |
||||
) |
||||
}) |
||||
|
||||
test('Render multiple system tags', async () => { |
||||
const file = new File({ |
||||
id: 1, |
||||
source: 'http://localhost/remote.php/dav/files/admin/foobar.txt', |
||||
owner: 'admin', |
||||
mime: 'text/plain', |
||||
permissions: Permission.ALL, |
||||
attributes: { |
||||
'system-tags': { |
||||
'system-tag': [ |
||||
'Important', |
||||
'Confidential', |
||||
'Secret', |
||||
'Classified' |
||||
] |
||||
} |
||||
} |
||||
}) |
||||
|
||||
const result = await action.renderInline!(file, view) |
||||
expect(result).toBeInstanceOf(HTMLElement) |
||||
expect(result!.outerHTML).toBe( |
||||
'<ul class="files-list__system-tags" aria-label="This file has the tags Important, Confidential, Secret and Classified">' +
|
||||
'<li class="files-list__system-tag">Important</li>' + |
||||
'<li class="files-list__system-tag files-list__system-tag--more" title="Confidential, Secret, Classified">+3</li>' + |
||||
'</ul>' |
||||
) |
||||
}) |
||||
}) |
||||
Loading…
Reference in new issue