diff --git a/web/client/components/mapviews/settings/__tests__/CompactRichTextEditor-test.jsx b/web/client/components/mapviews/settings/__tests__/CompactRichTextEditor-test.jsx new file mode 100644 index 0000000000..440824b58f --- /dev/null +++ b/web/client/components/mapviews/settings/__tests__/CompactRichTextEditor-test.jsx @@ -0,0 +1,50 @@ +/* + * Copyright 2025, GeoSolutions Sas. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. + */ + +import React from 'react'; +import ReactDOM from 'react-dom'; +import CompactRichTextEditor from '../CompactRichTextEditor'; +import expect from 'expect'; +import TestUtils from 'react-dom/test-utils'; + +describe('CompactRichTextEditor component', () => { + beforeEach((done) => { + document.body.innerHTML = '<div id="container"></div>'; + setTimeout(done); + }); + + afterEach((done) => { + ReactDOM.unmountComponentAtNode(document.getElementById("container")); + document.body.innerHTML = ''; + setTimeout(done); + }); + + it('should render with default which does not include image upload', () => { + ReactDOM.render(<CompactRichTextEditor />, document.getElementById("container")); + const textEditorContainer = document.querySelector(".ms-compact-text-editor.rdw-editor-wrapper"); + expect(textEditorContainer).toBeTruthy(); + // check img upload btn + const imageWidget = document.querySelector(".rdw-image-wrapper .rdw-option-wrapper"); + TestUtils.act(() => { + TestUtils.Simulate.click(imageWidget); + }); + const uploadImgInput = document.querySelector(".rdw-image-modal-upload-option"); + expect(uploadImgInput).toBeFalsy(); + }); + it('test rendering TextEditor with enabling image upload [uploadEnabled]', () => { + ReactDOM.render(<CompactRichTextEditor uploadEnabled />, document.getElementById("container")); + const textEditorContainer = document.querySelector(".ms-compact-text-editor.rdw-editor-wrapper"); + expect(textEditorContainer).toBeTruthy(); + const imageWidget = document.querySelector(".rdw-image-wrapper .rdw-option-wrapper"); + TestUtils.act(() => { + TestUtils.Simulate.click(imageWidget); + }); + const uploadImgInput = document.querySelector(".rdw-image-modal-upload-option"); + expect(uploadImgInput).toBeTruthy(); + }); +}); diff --git a/web/client/components/widgets/builder/wizard/text/TextOptions.jsx b/web/client/components/widgets/builder/wizard/text/TextOptions.jsx index fca9d10700..9e3cbe0c4b 100644 --- a/web/client/components/widgets/builder/wizard/text/TextOptions.jsx +++ b/web/client/components/widgets/builder/wizard/text/TextOptions.jsx @@ -48,6 +48,7 @@ function TextOptions({ data = {}, onChange = () => {} }) { </Form> </Col> <DescriptorEditor + uploadEnabled editorState={editorState} onEditorStateChange={(newEditorState) => { const previousHTML = draftJSEditorStateToHtml(editorState);