Improvements to richtexteditor to allow file management in raw html editor. Also allow disabling of raw html editor which can be utilized via new setting in Html/Text module.
This commit is contained in:
		| @ -5,79 +5,100 @@ | ||||
| <div class="row" style="margin-bottom: 50px;"> | ||||
|     <div class="col"> | ||||
|         <TabStrip> | ||||
|             <TabPanel Name="Rich" Heading="Rich Text Editor"> | ||||
|                 @if (AllowFileManagement) | ||||
|                 { | ||||
|                     @if (_filemanagervisible) | ||||
|                     { | ||||
|                         <FileManager @ref="_fileManager" Filter="@Constants.ImageFiles" /> | ||||
|                         <ModuleMessage Message="@_message" Type="MessageType.Warning"></ModuleMessage> | ||||
|                         <br /> | ||||
|                     } | ||||
|                     <div class="d-flex justify-content-center mb-2"> | ||||
|                         <button type="button" class="btn btn-secondary" @onclick="RefreshRichText">@Localizer["SynchronizeContent"]</button>   | ||||
|                         <button type="button" class="btn btn-primary" @onclick="InsertImage">@Localizer["InsertImage"]</button> | ||||
|                         @if (_filemanagervisible) | ||||
|                         { | ||||
|                             @((MarkupString)"  ") | ||||
|                             <button type="button" class="btn btn-secondary" @onclick="CloseFileManager">@Localizer["Close"]</button> | ||||
|                         } | ||||
|                     </div> | ||||
|                 } | ||||
|                 <div class="row"> | ||||
|                     <div class="col"> | ||||
|                         <div @ref="@_toolBar"> | ||||
|                             @if (ToolbarContent != null) | ||||
|                             { | ||||
|                                 @ToolbarContent | ||||
|                             } | ||||
|                             else | ||||
|                             { | ||||
|                                 <select class="ql-header"> | ||||
|                                     <option selected=""></option> | ||||
|                                     <option value="1"></option> | ||||
|                                     <option value="2"></option> | ||||
|                                     <option value="3"></option> | ||||
|                                     <option value="4"></option> | ||||
|                                     <option value="5"></option> | ||||
|                                 </select> | ||||
|                                 <span class="ql-formats"> | ||||
|                                     <button class="ql-bold"></button> | ||||
|                                     <button class="ql-italic"></button> | ||||
|                                     <button class="ql-underline"></button> | ||||
|                                     <button class="ql-strike"></button> | ||||
|                                 </span> | ||||
|                                 <span class="ql-formats"> | ||||
|                                     <select class="ql-color"></select> | ||||
|                                     <select class="ql-background"></select> | ||||
|                                 </span> | ||||
|                                 <span class="ql-formats"> | ||||
|                                     <button class="ql-list" value="ordered"></button> | ||||
|                                     <button class="ql-list" value="bullet"></button> | ||||
|                                 </span> | ||||
|                                 <span class="ql-formats"> | ||||
|                                     <button class="ql-link"></button> | ||||
|                                 </span> | ||||
|                             } | ||||
|                         </div> | ||||
|                         <div @ref="@_editorElement"> | ||||
|                         </div> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             </TabPanel> | ||||
|             <TabPanel Name="Raw" Heading="Raw HTML Editor" ResourceKey="HtmlEditor"> | ||||
|                 <div class="d-flex justify-content-center mb-2"> | ||||
|                     <button type="button" class="btn btn-secondary" @onclick="RefreshRawHtml">@Localizer["SynchronizeContent"]</button> | ||||
|                 </div> | ||||
|                 @if (ReadOnly) | ||||
|                 { | ||||
|                     <textarea class="form-control" placeholder="@Placeholder" @bind="@_rawhtml" rows="10" readonly></textarea> | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     <textarea class="form-control" placeholder="@Placeholder" @bind="@_rawhtml" rows="10"></textarea> | ||||
|                 } | ||||
|             </TabPanel> | ||||
| 			<TabPanel Name="Rich" Heading="Rich Text Editor"> | ||||
| 				@if (_richfilemanager) | ||||
| 				{ | ||||
| 					<FileManager @ref="_fileManager" Filter="@Constants.ImageFiles" /> | ||||
| 					<ModuleMessage Message="@_message" Type="MessageType.Warning"></ModuleMessage> | ||||
| 					<br /> | ||||
| 				} | ||||
| 				<div class="d-flex justify-content-center mb-2"> | ||||
| 					@if (AllowRawHtml) | ||||
| 					{ | ||||
| 						<button type="button" class="btn btn-secondary" @onclick="RefreshRichText">@Localizer["SynchronizeContent"]</button>@((MarkupString)"  ") | ||||
| 					} | ||||
| 					@if (AllowFileManagement) | ||||
| 					{ | ||||
| 						<button type="button" class="btn btn-primary" @onclick="InsertRichImage">@Localizer["InsertImage"]</button> | ||||
| 					} | ||||
| 					@if (_richfilemanager) | ||||
| 					{ | ||||
| 						@((MarkupString)"  ") | ||||
| 						<button type="button" class="btn btn-secondary" @onclick="CloseRichFileManager">@Localizer["Close"]</button> | ||||
| 					} | ||||
| 				</div> | ||||
| 				<div class="row"> | ||||
| 					<div class="col"> | ||||
| 						<div @ref="@_toolBar"> | ||||
| 							@if (ToolbarContent != null) | ||||
| 							{ | ||||
| 								@ToolbarContent | ||||
| 							} | ||||
| 							else | ||||
| 							{ | ||||
| 								<select class="ql-header"> | ||||
| 									<option selected=""></option> | ||||
| 									<option value="1"></option> | ||||
| 									<option value="2"></option> | ||||
| 									<option value="3"></option> | ||||
| 									<option value="4"></option> | ||||
| 									<option value="5"></option> | ||||
| 								</select> | ||||
| 								<span class="ql-formats"> | ||||
| 									<button class="ql-bold"></button> | ||||
| 									<button class="ql-italic"></button> | ||||
| 									<button class="ql-underline"></button> | ||||
| 									<button class="ql-strike"></button> | ||||
| 								</span> | ||||
| 								<span class="ql-formats"> | ||||
| 									<select class="ql-color"></select> | ||||
| 									<select class="ql-background"></select> | ||||
| 								</span> | ||||
| 								<span class="ql-formats"> | ||||
| 									<button class="ql-list" value="ordered"></button> | ||||
| 									<button class="ql-list" value="bullet"></button> | ||||
| 								</span> | ||||
| 								<span class="ql-formats"> | ||||
| 									<button class="ql-link"></button> | ||||
| 								</span> | ||||
| 							} | ||||
| 						</div> | ||||
| 						<div @ref="@_editorElement"> | ||||
| 						</div> | ||||
| 					</div> | ||||
| 				</div> | ||||
| 			</TabPanel> | ||||
| 			@if (AllowRawHtml) | ||||
| 			{ | ||||
| 				<TabPanel Name="Raw" Heading="Raw HTML Editor" ResourceKey="HtmlEditor"> | ||||
| 					@if (_rawfilemanager) | ||||
| 					{ | ||||
| 						<FileManager @ref="_fileManager" Filter="@Constants.ImageFiles" /> | ||||
| 						<ModuleMessage Message="@_message" Type="MessageType.Warning"></ModuleMessage> | ||||
| 						<br /> | ||||
| 					} | ||||
| 					<div class="d-flex justify-content-center mb-2"> | ||||
| 						<button type="button" class="btn btn-secondary" @onclick="RefreshRawHtml">@Localizer["SynchronizeContent"]</button>   | ||||
| 						@if (AllowFileManagement) | ||||
| 						{ | ||||
| 							<button type="button" class="btn btn-primary" @onclick="InsertRawImage">@Localizer["InsertImage"]</button> | ||||
| 						} | ||||
| 						@if (_rawfilemanager) | ||||
| 						{ | ||||
| 							@((MarkupString)"  ") | ||||
| 							<button type="button" class="btn btn-secondary" @onclick="CloseRawFileManager">@Localizer["Close"]</button> | ||||
| 						} | ||||
| 					</div> | ||||
| 					@if (ReadOnly) | ||||
| 					{ | ||||
| 						<textarea id="rawhtmleditor" class="form-control" placeholder="@Placeholder" @bind="@_rawhtml" rows="10" readonly></textarea> | ||||
| 					} | ||||
| 					else | ||||
| 					{ | ||||
| 						<textarea id="rawhtmleditor" class="form-control" placeholder="@Placeholder" @bind="@_rawhtml" rows="10"></textarea> | ||||
| 					} | ||||
| 				</TabPanel> | ||||
| 			} | ||||
|         </TabStrip> | ||||
|     </div> | ||||
| </div> | ||||
| @ -85,10 +106,11 @@ | ||||
| @code { | ||||
| 	private ElementReference _editorElement; | ||||
| 	private ElementReference _toolBar; | ||||
| 	private bool _filemanagervisible = false; | ||||
| 	private bool _richfilemanager = false; | ||||
| 	private FileManager _fileManager; | ||||
| 	private string _richhtml = string.Empty; | ||||
| 	private string _originalrichhtml = string.Empty; | ||||
| 	private bool _rawfilemanager = false; | ||||
| 	private string _rawhtml = string.Empty; | ||||
| 	private string _originalrawhtml = string.Empty; | ||||
| 	private string _message = string.Empty; | ||||
| @ -102,6 +124,12 @@ | ||||
| 	[Parameter] | ||||
| 	public string Placeholder { get; set; } = "Enter Your Content..."; | ||||
|  | ||||
| 	[Parameter] | ||||
| 	public bool AllowFileManagement { get; set; } = true; | ||||
|  | ||||
| 	[Parameter] | ||||
| 	public bool AllowRawHtml { get; set; } = true;   | ||||
| 	 | ||||
| 	// parameters only applicable to rich text editor | ||||
| 	[Parameter] | ||||
| 	public RenderFragment ToolbarContent { get; set; } | ||||
| @ -112,9 +140,6 @@ | ||||
| 	[Parameter] | ||||
| 	public string DebugLevel { get; set; } = "info"; | ||||
|  | ||||
| 	[Parameter] | ||||
| 	public bool AllowFileManagement { get; set; } = true; | ||||
|  | ||||
| 	public override List<Resource> Resources => new List<Resource>() | ||||
|     { | ||||
|         new Resource { ResourceType = ResourceType.Script, Bundle = "Quill", Url = "js/quill.min.js" }, | ||||
| @ -152,9 +177,16 @@ | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	public void CloseFileManager() | ||||
| 	public void CloseRichFileManager() | ||||
| 	{ | ||||
| 		_filemanagervisible = false; | ||||
| 		_richfilemanager = false; | ||||
| 		_message = string.Empty; | ||||
| 		StateHasChanged(); | ||||
| 	} | ||||
|  | ||||
| 	public void CloseRawFileManager() | ||||
| 	{ | ||||
| 		_rawfilemanager = false; | ||||
| 		_message = string.Empty; | ||||
| 		StateHasChanged(); | ||||
| 	} | ||||
| @ -194,29 +226,55 @@ | ||||
| 				return _originalrawhtml; | ||||
| 			} | ||||
| 		} | ||||
|     } | ||||
| 	} | ||||
|  | ||||
|     public async Task InsertImage() | ||||
|     { | ||||
|         _message = string.Empty; | ||||
|         if (_filemanagervisible) | ||||
|         { | ||||
|             var file = _fileManager.GetFile(); | ||||
|             if (file != null) | ||||
|             { | ||||
|                 var interop = new RichTextEditorInterop(JSRuntime); | ||||
|                 await interop.InsertImage(_editorElement, file.Url, file.Name); | ||||
|                 _filemanagervisible = false; | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 _message = Localizer["Message.Require.Image"]; | ||||
|             } | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             _filemanagervisible = true; | ||||
|         } | ||||
|         StateHasChanged(); | ||||
|     } | ||||
| 	public async Task InsertRichImage() | ||||
| 	{ | ||||
| 		_message = string.Empty; | ||||
| 		if (_richfilemanager) | ||||
| 		{ | ||||
| 			var file = _fileManager.GetFile(); | ||||
| 			if (file != null) | ||||
| 			{ | ||||
| 				var interop = new RichTextEditorInterop(JSRuntime); | ||||
| 				await interop.InsertImage(_editorElement, file.Url, ((!string.IsNullOrEmpty(file.Description)) ? file.Description : file.Name)); | ||||
| 				_richfilemanager = false; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				_message = Localizer["Message.Require.Image"]; | ||||
| 			} | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			_richfilemanager = true; | ||||
| 		} | ||||
| 		StateHasChanged(); | ||||
| 	} | ||||
|  | ||||
| 	public async Task InsertRawImage() | ||||
| 	{ | ||||
| 		_message = string.Empty; | ||||
| 		if (_rawfilemanager) | ||||
| 		{ | ||||
| 			var file = _fileManager.GetFile(); | ||||
| 			if (file != null) | ||||
| 			{ | ||||
| 				var interop = new Interop(JSRuntime); | ||||
| 				int pos = await interop.GetCaretPosition("rawhtmleditor"); | ||||
| 				var image = "<img src=\"" + file.Url + "\" alt=\"" + ((!string.IsNullOrEmpty(file.Description)) ? file.Description : file.Name) + "\">"; | ||||
| 				_rawhtml = _rawhtml.Substring(0, pos) + image + _rawhtml.Substring(pos); | ||||
| 				_rawfilemanager = false; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				_message = Localizer["Message.Require.Image"]; | ||||
| 			} | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			_rawfilemanager = true; | ||||
| 		} | ||||
| 		StateHasChanged(); | ||||
| 	} | ||||
| } | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 Shaun Walker
					Shaun Walker