diff options
-rw-r--r-- | __mocks__/css.js | 22 | ||||
-rw-r--r-- | apps/files/src/actions/inlineSystemTagsAction.spec.ts | 143 | ||||
-rw-r--r-- | apps/files/src/actions/inlineSystemTagsAction.ts | 6 | ||||
-rw-r--r-- | apps/files/src/css/fileEntryInlineSystemTags.scss | 21 | ||||
-rw-r--r-- | jest.config.ts | 1 |
5 files changed, 191 insertions, 2 deletions
diff --git a/__mocks__/css.js b/__mocks__/css.js new file mode 100644 index 00000000000..f2c71be8c32 --- /dev/null +++ b/__mocks__/css.js @@ -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 {} diff --git a/apps/files/src/actions/inlineSystemTagsAction.spec.ts b/apps/files/src/actions/inlineSystemTagsAction.spec.ts new file mode 100644 index 00000000000..2e81861a872 --- /dev/null +++ b/apps/files/src/actions/inlineSystemTagsAction.spec.ts @@ -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>' + ) + }) +}) diff --git a/apps/files/src/actions/inlineSystemTagsAction.ts b/apps/files/src/actions/inlineSystemTagsAction.ts index 395eba885d7..8aa68aea03d 100644 --- a/apps/files/src/actions/inlineSystemTagsAction.ts +++ b/apps/files/src/actions/inlineSystemTagsAction.ts @@ -37,7 +37,7 @@ const getNodeSystemTags = function (node: Node): string[] { const renderTag = function (tag: string, isMore: boolean = false): HTMLElement { const tagElement = document.createElement('li') tagElement.classList.add('files-list__system-tag') - tagElement.innerText = tag + tagElement.textContent = tag if (isMore) { tagElement.classList.add('files-list__system-tag--more') @@ -81,7 +81,9 @@ export const action = new FileAction({ } return systemTagsElement - } + }, + + order: 0 }) registerDavProperty('nc:system-tags') diff --git a/apps/files/src/css/fileEntryInlineSystemTags.scss b/apps/files/src/css/fileEntryInlineSystemTags.scss index e82e3da3c75..2159d3b01c7 100644 --- a/apps/files/src/css/fileEntryInlineSystemTags.scss +++ b/apps/files/src/css/fileEntryInlineSystemTags.scss @@ -1,3 +1,24 @@ +/** + * @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/>. + * + */ .files-list__system-tags { --min-size: 32px; display: flex; diff --git a/jest.config.ts b/jest.config.ts index 78b5912fee9..5bf104a4243 100644 --- a/jest.config.ts +++ b/jest.config.ts @@ -71,6 +71,7 @@ const config: Config = { // Allow mocking svg files moduleNameMapper: { '^.+\\.svg(\\?raw)?$': '<rootDir>/__mocks__/svg.js', + '\\.s?css$': '<rootDir>/__mocks__/css.js', }, modulePathIgnorePatterns: [ '<rootDir>/apps2/', |