Compare commits
	
		
			No commits in common. "master" and "release/0.1.2.014" have entirely different histories.
		
	
	
		
			master
			...
			release/0.
		
	
		
							
								
								
									
										355
									
								
								bs5-test.html
									
									
									
									
									
								
							
							
						
						
									
										355
									
								
								bs5-test.html
									
									
									
									
									
								
							| @ -16,302 +16,89 @@ | |||||||
|   <script src="bsdialog5.js"></script> |   <script src="bsdialog5.js"></script> | ||||||
|   <title></title> |   <title></title> | ||||||
| 
 | 
 | ||||||
|   <style> |  | ||||||
| 
 |  | ||||||
| .text-sm { |  | ||||||
|   font-size: 0.8em; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
|   </style> |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| </head> | </head> | ||||||
| <body class="py-5"> | <body class="py-5"> | ||||||
|  | 
 | ||||||
|   <div class="container"> |   <div class="container"> | ||||||
| 
 |  | ||||||
|     <div class="row mb-3 border-bottom"> |     <div class="row mb-3 border-bottom"> | ||||||
|       <div class="col-sm-4 border-right"> |       <div class="col-12"> | ||||||
|         <p><b>Example. Simple Text Modal</b></p> |  | ||||||
|         <p>Launch a modal with a text body.</p> |  | ||||||
| 
 | 
 | ||||||
|         <p><button id="buttonL1" type="button" class="btn btn-primary">Launch Modal</button></p> |         <p><b>Example One</b></p> | ||||||
|  |         <p>Launch an empty modal</p> | ||||||
|  |         <div class="alert alert-secondary">BSDialog5.Create('abc123', 'My Modal Box 123', null, 'xl');</div> | ||||||
|  |         <p><button id="button1" type="button" class="btn btn-primary">Launch Modal</button></p> | ||||||
|  | 
 | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |     <div class="row mb-3 border-bottom"> | ||||||
|  |       <div class="col-12"> | ||||||
|  | 
 | ||||||
|  |         <p><b>Example Two</b></p> | ||||||
|  |         <p>Launch a modal with text</p> | ||||||
|  |         <div class="alert alert-secondary">BSDialog5.Create('abc123', 'My Modal Box 123', 'Hello momo!', 'lg');</div> | ||||||
|  |         <p><button id="button2" type="button" class="btn btn-primary">Launch Modal</button></p> | ||||||
|  | 
 | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |     <div class="row mb-3 border-bottom"> | ||||||
|  |       <div class="col-12"> | ||||||
|  | 
 | ||||||
|  |         <p><b>Example Three</b></p> | ||||||
|  |         <p>Launch an empty modal then update its title, body, footer and size.</p> | ||||||
|  |         <div class="alert alert-secondary"> | ||||||
|  |           BSDialog5.ShowToast('abc123', 'My Modal Box 123', null, 'sm');<br /> | ||||||
|  |           BSDialog5.UpdateTitle('abc123', 'My Modal Box 567');<br /> | ||||||
|  |           BSDialog5.UpdateBody('abc123', 'Help, I\'m toast!');<br /> | ||||||
|  |           BSDialog5.UpdateFooter('abc123', '');<br /> | ||||||
|  |           BSDialog5.UpdateSize('abc123', 'lg');<br /> | ||||||
|  |         </div> | ||||||
|  |         <p><button id="button3" type="button" class="btn btn-primary">Launch Modal</button></p> | ||||||
|  | 
 | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |     <div class="row mb-3 border-bottom"> | ||||||
|  |       <div class="col-12"> | ||||||
|  | 
 | ||||||
|  |         <p><b>Example Four</b></p> | ||||||
|  |         <p>Launch a multiple modals</p> | ||||||
|  |         <div class="alert alert-secondary"> | ||||||
|  |           BSDialog5.ShowToast('abc123', 'My Modal Box 123', 'Help! I\'m toast.', 'sm');<br /> | ||||||
|  |           BSDialog5.ShowToast('abc123456', 'My Modal Box 123.567', 'Help! I\'m a second toast.', 'md');<br /> | ||||||
|  |         </div> | ||||||
|  |         <p><button id="button4" type="button" class="btn btn-primary">Launch Modal</button></p> | ||||||
|  | 
 | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
| 
 | 
 | ||||||
|   <script> |   <script> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| $(document).ready(function(){ | $(document).ready(function(){ | ||||||
| 
 |   $("#button1").on('click', function(){ | ||||||
|             $("#buttonL1").on('click', function(){ |     BSDialog5.Create('abc123', 'My Modal Box 123', null, 'xl'); | ||||||
|               BSDialog5.Show({ |  | ||||||
|                 ID: "modalL1", |  | ||||||
|                 Title: "Modal Title", |  | ||||||
|                 Message: "Hello Momo!", |  | ||||||
|                 URL: null, |  | ||||||
|                 Size: "md", |  | ||||||
|                 Colour: "secondary" |  | ||||||
|   }); |   }); | ||||||
|  | 
 | ||||||
|  |   $("#button2").on('click', function(){ | ||||||
|  |     BSDialog5.Create('abc123', 'My Modal Box 123', 'Hello momo!', 'lg'); | ||||||
|  |   }); | ||||||
|  | 
 | ||||||
|  |   $("#button3").on('click', function(){ | ||||||
|  |     BSDialog5.ShowToast('abc123', 'My Modal Box 123', null, 'sm'); | ||||||
|  |     BSDialog5.UpdateTitle('abc123', 'My Modal Box 567'); | ||||||
|  |     BSDialog5.UpdateBody('abc123', 'Help, I\'m toast!'); | ||||||
|  |     BSDialog5.UpdateFooter('abc123', ''); | ||||||
|  |     BSDialog5.UpdateSize('abc123', 'lg'); | ||||||
|  |   }); | ||||||
|  | 
 | ||||||
|  |   $("#button4").on('click', function(){ | ||||||
|  |     BSDialog5.ShowToast('abc123', 'My Modal Box 123', 'Help! I\'m toast.', 'sm'); | ||||||
|  |     BSDialog5.ShowToast('abc123456', 'My Modal Box 123.567', 'Help! I\'m a second toast.', 'md'); | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
| }); | }); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|   </script> |   </script> | ||||||
| 
 |  | ||||||
|       </div> |  | ||||||
|       <div class="col-sm-8"> |  | ||||||
| 
 |  | ||||||
|         <div class="alert alert-secondary text-sm"> |  | ||||||
| <pre>BSDialog5.Show({ |  | ||||||
|   ID: "modalL1", |  | ||||||
|   Title: "Modal Title", |  | ||||||
|   Message: "Hello Momo!", |  | ||||||
|   URL: null, |  | ||||||
|   Size: "md", |  | ||||||
|   Colour: "secondary" |  | ||||||
| });</pre> |  | ||||||
|         </div> |  | ||||||
| 
 |  | ||||||
|       </div> |  | ||||||
|     </div> |  | ||||||
| 
 |  | ||||||
|     <div class="row mb-3 border-bottom"> |  | ||||||
|       <div class="col-sm-4 border-right"> |  | ||||||
| 
 |  | ||||||
|         <p><b>Example. Update Modal</b></p> |  | ||||||
|         <p>Make changes (title, body, size or footer) to a modal.</p> |  | ||||||
| 
 |  | ||||||
|         <p><button id="buttonR1" type="button" class="btn btn-primary">Launch Modal</button></p> |  | ||||||
|         <script> |  | ||||||
|           $(document).ready(function(){ |  | ||||||
| 
 |  | ||||||
|             $("#buttonR1").on('click', function(){ |  | ||||||
|               BSDialog5.Show({ |  | ||||||
|                 ID: "modalR1", |  | ||||||
|                 Title: "Modal Title", |  | ||||||
|                 Message: "Hello Momo!", |  | ||||||
|                 URL: null, |  | ||||||
|                 Size: "md", |  | ||||||
|                 Colour: "secondary" |  | ||||||
|               }); |  | ||||||
| 
 |  | ||||||
|               BSDialog5.Update({ |  | ||||||
|                 ID: "modalR1", |  | ||||||
|                 Title: "Modal Changed Title", |  | ||||||
|                 Body: "Hello momo again!", |  | ||||||
|                 URL: null, |  | ||||||
|                 Size: "lg", |  | ||||||
|                 Footer: null |  | ||||||
|               }); |  | ||||||
|             }); |  | ||||||
| 
 |  | ||||||
|           }); |  | ||||||
|         </script> |  | ||||||
|       </div> |  | ||||||
|       <div class="col-sm-8"> |  | ||||||
| 
 |  | ||||||
|         <div class="alert alert-secondary text-sm"> |  | ||||||
| <pre>BSDialog5.Update({ |  | ||||||
|   ID: "modalL1", |  | ||||||
|   Title: "Modal Changed Title", |  | ||||||
|   Body: "Hello momo again!", |  | ||||||
|   URL: null, |  | ||||||
|   Size: "lg", |  | ||||||
|   Footer: null |  | ||||||
| });</pre> |  | ||||||
|         </div> |  | ||||||
| 
 |  | ||||||
|       </div> |  | ||||||
|     </div> |  | ||||||
| 
 |  | ||||||
|     <div class="row mb-3 border-bottom"> |  | ||||||
|       <div class="col-sm-4 border-right"> |  | ||||||
| 
 |  | ||||||
|         <p><b>Example. Multiple Modals (Stack)</b></p> |  | ||||||
|         <p>Launch multiple modals, stacked on top of each other.</p> |  | ||||||
| 
 |  | ||||||
|         <p><button id="buttonL3" type="button" class="btn btn-primary">Launch Modal</button></p> |  | ||||||
|         <script> |  | ||||||
|           $(document).ready(function(){ |  | ||||||
| 
 |  | ||||||
|             $("#buttonL3").on('click', function(){ |  | ||||||
|               BSDialog5.Show({ |  | ||||||
|                 ID: "modalL3a", |  | ||||||
|                 Title: "Modal A Title", |  | ||||||
|                 Message: "First!", |  | ||||||
|                 URL: null, |  | ||||||
|                 Size: "md", |  | ||||||
|                 Colour: "secondary" |  | ||||||
|               }); |  | ||||||
| 
 |  | ||||||
|               BSDialog5.Show({ |  | ||||||
|                 ID: "modalL3b", |  | ||||||
|                 Title: "Modal B Title", |  | ||||||
|                 Message: "Second!", |  | ||||||
|                 URL: null, |  | ||||||
|                 Size: "md", |  | ||||||
|                 Colour: "secondary" |  | ||||||
|               }); |  | ||||||
|             }); |  | ||||||
| 
 |  | ||||||
|           }); |  | ||||||
|         </script> |  | ||||||
| 
 |  | ||||||
|       </div> |  | ||||||
|       <div class="col-sm-8"> |  | ||||||
|         <div class="alert alert-secondary text-sm"> |  | ||||||
| <pre>BSDialog5.Show({ |  | ||||||
|   ID: "modalL3a", |  | ||||||
|   Title: "Modal A Title", |  | ||||||
|   Message: "First!", |  | ||||||
|   URL: null, |  | ||||||
|   Size: "md", |  | ||||||
|   Colour: "secondary" |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| BSDialog5.Show({ |  | ||||||
|   ID: "modalL3b", |  | ||||||
|   Title: "Modal B Title", |  | ||||||
|   Message: "Second!", |  | ||||||
|   URL: null, |  | ||||||
|   Size: "md", |  | ||||||
|   Colour: "secondary" |  | ||||||
| });</pre> |  | ||||||
|         </div> |  | ||||||
|       </div> |  | ||||||
|     </div> |  | ||||||
| 
 |  | ||||||
|     <div class="row mb-3 border-bottom"> |  | ||||||
|       <div class="col-sm-4 border-right"> |  | ||||||
| 
 |  | ||||||
|         <p><b>Example. Button Prompt (Modal)</b></p> |  | ||||||
|         <p>Launch a modal with a prompt of several buttons. Modal waits for a response from one of the buttons.</p> |  | ||||||
| 
 |  | ||||||
|         <p><button id="buttonL2" type="button" class="btn btn-primary">Launch Modal</button></p> |  | ||||||
|         <script> |  | ||||||
|           $(document).ready(function(){ |  | ||||||
| 
 |  | ||||||
|             $("#buttonL2").on('click', async function(){ |  | ||||||
|               let response = await BSDialog5.Prompt({ |  | ||||||
|                 Title: "Modal Title", |  | ||||||
|                 Message: "Are you sure want to wait for a response?", |  | ||||||
|                 Size: "md", |  | ||||||
|                 Buttons: [ |  | ||||||
|                   { Label: "Yes", Value: "Yes", Colour: "primary" }, |  | ||||||
|                   { Label: "No", Value: "No", Colour: "secondary" }, |  | ||||||
|                   { Label: "Cancel", Value: "Cancel", Colour: "secondary" } |  | ||||||
|                 ] |  | ||||||
|               }); |  | ||||||
| 
 |  | ||||||
|               alert(response); |  | ||||||
|             }); |  | ||||||
| 
 |  | ||||||
|           }); |  | ||||||
|         </script> |  | ||||||
|       </div> |  | ||||||
|       <div class="col-sm-8"> |  | ||||||
|         <div class="alert alert-secondary text-sm"> |  | ||||||
| <pre>let response = await BSDialog5.Prompt({ |  | ||||||
|   Title: "Modal Title", |  | ||||||
|   Message: "Are you sure want to wait for a response?", |  | ||||||
|   Size: "md", |  | ||||||
|   Buttons: [ |  | ||||||
|     { Label: "Yes", Value: "Yes", Colour: "primary" }, |  | ||||||
|     { Label: "No", Value: "No", Colour: "secondary" }, |  | ||||||
|     { Label: "Cancel", Value: "Cancel", Colour: "secondary" } |  | ||||||
|   ] |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| alert(response);</pre> |  | ||||||
|         </div> |  | ||||||
|       </div> |  | ||||||
|     </div> |  | ||||||
| 
 |  | ||||||
|     <div class="row mb-3 border-bottom"> |  | ||||||
|       <div class="col-sm-4 border-right"> |  | ||||||
| 
 |  | ||||||
|         <p><b>Example. Text Prompt (Modal)</b></p> |  | ||||||
|         <p>Launch a modal with a text prompt. Modal waits for a response from the textbox.</p> |  | ||||||
| 
 |  | ||||||
|         <p><button id="buttonL2a" type="button" class="btn btn-primary">Launch Modal</button></p> |  | ||||||
|         <script> |  | ||||||
|           $(document).ready(function(){ |  | ||||||
| 
 |  | ||||||
|             $("#buttonL2a").on('click', async function(){ |  | ||||||
|               let response = await BSDialog5.Prompt({ |  | ||||||
|                 Type: "textbox", |  | ||||||
|                 Title: "Modal Title", |  | ||||||
|                 Message: "Are you sure want to wait for a response?", |  | ||||||
|                 Size: "md", |  | ||||||
|                 Label: "", |  | ||||||
|                 Placeholder: "" |  | ||||||
|               }); |  | ||||||
| 
 |  | ||||||
|               alert(response); |  | ||||||
|             }); |  | ||||||
| 
 |  | ||||||
|           }); |  | ||||||
|         </script> |  | ||||||
|       </div> |  | ||||||
|       <div class="col-sm-8"> |  | ||||||
|         <div class="alert alert-secondary text-sm"> |  | ||||||
| <pre>let response = await BSDialog5.Prompt({ |  | ||||||
|   Type: "textbox", |  | ||||||
|   Title: "Modal Title", |  | ||||||
|   Message: "Are you sure want to wait for a response?", |  | ||||||
|   Size: "md", |  | ||||||
|   Label: "", |  | ||||||
|   Placeholder: "" |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| alert(response);</pre> |  | ||||||
|         </div> |  | ||||||
|       </div> |  | ||||||
|     </div> |  | ||||||
| 
 |  | ||||||
|     <div class="row mb-3 border-bottom"> |  | ||||||
|       <div class="col-sm-4 border-right"> |  | ||||||
| 
 |  | ||||||
|         <p><b>Example. Close Modal</b></p> |  | ||||||
|         <p>Close a modal using its identifier</p> |  | ||||||
|         <p><button id="buttonR2" type="button" class="btn btn-primary">Launch Modal</button></p> |  | ||||||
|         <script> |  | ||||||
|           $(document).ready(function(){ |  | ||||||
| 
 |  | ||||||
|             $("#buttonR2").on('click', function(){ |  | ||||||
|               BSDialog5.Close("modalR1"); |  | ||||||
|             }); |  | ||||||
| 
 |  | ||||||
|           }); |  | ||||||
|         </script> |  | ||||||
| 
 |  | ||||||
|       </div> |  | ||||||
|       <div class="col-sm-8"> |  | ||||||
|         <div class="alert alert-secondary text-sm"> |  | ||||||
| <pre>BSDialog5.Close("modalR1");</pre> |  | ||||||
|         </div> |  | ||||||
|       </div> |  | ||||||
|     </div> |  | ||||||
| 
 |  | ||||||
|     <div class="row mb-3 border-bottom"> |  | ||||||
|       <div class="col-sm-4 border-right"> |  | ||||||
| 
 |  | ||||||
|         <p><b>Example. Clear Modal</b></p> |  | ||||||
|         <p>Close all modals</p> |  | ||||||
|         <p><button id="buttonR3" type="button" class="btn btn-primary">Launch Modal</button></p> |  | ||||||
|         <script> |  | ||||||
|           $(document).ready(function(){ |  | ||||||
| 
 |  | ||||||
|             $("#buttonR3").on('click', function(){ |  | ||||||
|               BSDialog5.Clear(); |  | ||||||
|             }); |  | ||||||
| 
 |  | ||||||
|           }); |  | ||||||
|         </script> |  | ||||||
| 
 |  | ||||||
|       </div> |  | ||||||
|       <div class="col-sm-8"> |  | ||||||
|         <div class="alert alert-secondary text-sm"> |  | ||||||
| <pre>BSDialog5.Clear();</pre> |  | ||||||
|         </div> |  | ||||||
|       </div> |  | ||||||
|     </div> |  | ||||||
| 
 |  | ||||||
|   </div> |  | ||||||
| </body> | </body> | ||||||
| </html> | </html> | ||||||
							
								
								
									
										559
									
								
								bsdialog5.js
									
									
									
									
									
								
							
							
						
						
									
										559
									
								
								bsdialog5.js
									
									
									
									
									
								
							| @ -1,163 +1,88 @@ | |||||||
| /** | /** | ||||||
|  * BSDialog5 |  * BSDialog5 | ||||||
|  * @version v0.2.2.003 (2024/01/22 2037) |  * @version v0.1.2.014 (2023/08/19 1351) | ||||||
|  */ |  */ | ||||||
| class BSDialog05 { | var BSDialog5 = { | ||||||
|  | 	Create: async function (id, title, url, size) { | ||||||
|  | 		var a = this; | ||||||
| 
 | 
 | ||||||
|   constructor() { | 		a.id = id; | ||||||
| 	} | 		a.pfx = "bsdia5_"; | ||||||
|  | 		a.body = document.getElementsByTagName("body")[0]; | ||||||
| 
 | 
 | ||||||
|  | 		a.addBackdrop(); | ||||||
|  | 		a.addModal(id, title, size); | ||||||
| 
 | 
 | ||||||
| 	get #prefix() { | 		if (a.isNullOrWhitespace(url)) { | ||||||
| 		return "bsdia5_"; | 			a.UpdateBody(id, ""); | ||||||
| 	} | 	  } else if (url.startsWith("http://") || url.startsWith("https://") || url.startsWith("/")) { | ||||||
| 
 | 			a.UpdateBodyRemote(id, url); | ||||||
| 	get #body() { |  | ||||||
| 		return document.getElementsByTagName("body")[0]; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	get #sizeList() { |  | ||||||
| 		return [ |  | ||||||
| 			"modal-sm", |  | ||||||
| 			"modal-md", |  | ||||||
| 			"modal-lg", |  | ||||||
| 			"modal-xl", |  | ||||||
| 			"modal-xxl" |  | ||||||
| 		]; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 	async Show(options) { |  | ||||||
| 		const a = this; |  | ||||||
| 		const _options = Object.assign({ |  | ||||||
| 			ID: null, |  | ||||||
| 			Title: "", |  | ||||||
| 			Message: "", |  | ||||||
| 			URL: null, |  | ||||||
| 			Size: "md", |  | ||||||
| 			Colour: "secondary", |  | ||||||
| 			ShowFooter: true, |  | ||||||
| 			EasyClose: true, |  | ||||||
| 			IsMovable: true |  | ||||||
| 		}, options); |  | ||||||
| 
 |  | ||||||
| 		a.#addModal(_options.ID, _options.Title, _options.Size, _options.ShowFooter, _options.IsMovable, _options.Colour); |  | ||||||
| 
 |  | ||||||
| 		(new bootstrap.Modal(document.getElementById(a.#prefix + _options.ID), { |  | ||||||
| 			backdrop: _options.EasyClose |  | ||||||
| 		})).show(); |  | ||||||
| 
 |  | ||||||
| 		if (a.#isURL(_options.URL)) { |  | ||||||
| 			await a.UpdateBodyRemote(_options.ID, _options.URL); |  | ||||||
| 		} else { | 		} else { | ||||||
| 			await a.Update({ ID: _options.ID, Body: _options.Message }); | 			await a.UpdateBody(id, url); | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	async Prompt(options) { |  | ||||||
| 		const a = this; |  | ||||||
| 		const id = "prompt" + Math.floor(Math.random() * 10000) + 1000; |  | ||||||
| 		const _options = Object.assign({ |  | ||||||
| 			Type: "button", |  | ||||||
| 			Title: "", |  | ||||||
| 			Message: "", |  | ||||||
| 			Size: "md", |  | ||||||
| 			EasyClose: true, |  | ||||||
| 			IsMovable: true, |  | ||||||
| 			Buttons: [ |  | ||||||
| 				{ Label: "Yes", Value: "Yes", Colour: "primary" }, |  | ||||||
| 				{ Label: "No", Value: "No", Colour: "secondary" }, |  | ||||||
| 				{ Label: "Cancel", Value: "Cancel", Colour: "secondary" } |  | ||||||
| 			], |  | ||||||
| 			Textbox: { |  | ||||||
| 				Label: "", |  | ||||||
| 				LabelSize: 4, |  | ||||||
| 				Placeholder: "", |  | ||||||
| 				Value: "", |  | ||||||
| 				BoxSize: 8 |  | ||||||
| 			} |  | ||||||
| 		}, options); |  | ||||||
| 
 |  | ||||||
| 		switch (_options.Type) { |  | ||||||
| 			case "textbox": |  | ||||||
| 				return await a.#showTextboxPrompt(id, _options); |  | ||||||
| 			case "button": |  | ||||||
| 			default: |  | ||||||
| 				return await a.#showButtonPrompt(id, _options); |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	async Clear() { |  | ||||||
| 		const a = this; |  | ||||||
| 
 |  | ||||||
| 		document.querySelectorAll('.modal').forEach(function(e) { |  | ||||||
| 			const modal = bootstrap.Modal.getInstance(e); |  | ||||||
| 
 |  | ||||||
| 			if (modal) { |  | ||||||
| 				modal.hide(); |  | ||||||
| 		} | 		} | ||||||
|  | 	}, | ||||||
|  | 	Clear: function () { | ||||||
|  | 		this.body.querySelectorAll(".modal").forEach(function(e) { | ||||||
|  | 			e.parentNode.removeChild(e); | ||||||
| 		}); | 		}); | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
|   async Close(id) { | 		this.removeBackdrop(); | ||||||
| 		const a = this; | 	}, | ||||||
| 
 | 	Close: function (id) { | ||||||
| 		if (id.startsWith(a.#prefix)) { | 		let modal = this.Find(id); | ||||||
| 			id = id.substr(a.#prefix.length); |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		const node = document.getElementById(a.#prefix + id); |  | ||||||
| 		const modal = bootstrap.Modal.getInstance(node); |  | ||||||
| 
 |  | ||||||
| 		if (modal){ |  | ||||||
| 			modal.hide(); |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		if (node) { |  | ||||||
| 			node.parentNode.removeChild(node); |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	async Update(options) { |  | ||||||
| 		const a = this; |  | ||||||
| 		let _options = Object.assign({ |  | ||||||
| 			ID: null, |  | ||||||
| 			Title: null, |  | ||||||
| 			Body: null, |  | ||||||
| 			URL: null, |  | ||||||
| 			Footer: null, |  | ||||||
| 			Size: null |  | ||||||
| 		}, options); |  | ||||||
| 
 |  | ||||||
| 		const modal = a.Find(_options.ID); |  | ||||||
| 		if (modal === null) { | 		if (modal === null) { | ||||||
| 		 	return; | 		 	return; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		if (!this.#isNullOrWhitespace(_options.Title)) { | 		modal.Modal.forEach(function(e) { | ||||||
| 			modal.Title.innerHTML = _options.Title; | 			e.parentNode.removeChild(e); | ||||||
|  | 		}); | ||||||
|  | 
 | ||||||
|  | 		modal = this.Find(id); | ||||||
|  | 		if (modal !== null) { | ||||||
|  | 			return; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		if (!this.#isNullOrWhitespace(_options.Body)) { | 		this.removeBackdrop(); | ||||||
| 			a.#html(modal.Body, _options.Body); | 	}, | ||||||
| 		} else { | 	UpdateTitle: function (id, title) { | ||||||
| 			if (this.#isURL(_options.URL)) { | 		let modal = this.Find(id); | ||||||
| 				await a.UpdateBodyRemote(_options.ID, _options.URL); | 		if (modal === null) { | ||||||
| 			} | 		 	return; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		if (!this.#isNullOrWhitespace(_options.Footer)) { | 		modal.Title.forEach(function(e) { | ||||||
| 			a.#html(modal.Footer, _options.Footer); | 			e.innerHTML = title; | ||||||
|  | 		}); | ||||||
|  | 	}, | ||||||
|  | 	UpdateSize: function (id, size) { | ||||||
|  | 		let modal = this.Find(id); | ||||||
|  | 		if (modal === null) { | ||||||
|  | 		 	return; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		if (!this.#isNullOrWhitespace(_options.Size)) { | 		modal.Modal.forEach(function(e) { | ||||||
| 			a.#setSize(_options.ID, "modal-" + _options.Size); | 			e.classList.remove("modal-sm"); | ||||||
|  | 			e.classList.remove("modal-md"); | ||||||
|  | 			e.classList.remove("modal-lg"); | ||||||
|  | 			e.classList.remove("modal-xl"); | ||||||
|  | 			e.classList.add("modal-" + size); | ||||||
|  | 		}); | ||||||
|  | 	}, | ||||||
|  | 	UpdateBody: function (id, content) { | ||||||
|  | 		var a = this; | ||||||
|  | 
 | ||||||
|  | 		let modal = a.Find(id); | ||||||
|  | 		if (modal === null) { | ||||||
|  | 		 	return; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 	} | 		modal.Body.forEach(function(e) { | ||||||
| 
 | 			a.html(e, content); | ||||||
| 	async UpdateBodyRemote(id, url) { | 		}); | ||||||
| 		const a = this; | 	}, | ||||||
|  | 	UpdateBodyRemote: async function (id, url) { | ||||||
|  | 		var a = this; | ||||||
| 
 | 
 | ||||||
| 		if (!a.Exists(id)) { | 		if (!a.Exists(id)) { | ||||||
| 		 	return; | 		 	return; | ||||||
| @ -167,20 +92,28 @@ class BSDialog05 { | |||||||
| 			cache: 'no-cache', | 			cache: 'no-cache', | ||||||
| 			credentials: 'same-origin' | 			credentials: 'same-origin' | ||||||
| 		}).then(data => data.text()).then(data => { | 		}).then(data => data.text()).then(data => { | ||||||
| 			a.Update({ ID: id, Body: data }); | 			a.UpdateBody(id, data); | ||||||
| 		}).catch((error) => { | 		}).catch((error) => { | ||||||
| 			a.Update({ ID: id, Body: "Error: " + error }); | 			a.UpdateBody(id, "Error: " + error); | ||||||
| 		}); | 		}); | ||||||
|  | 	}, | ||||||
|  | 	UpdateFooter: function (id, content) { | ||||||
|  | 		var a = this; | ||||||
|  | 
 | ||||||
|  | 		let modal = a.Find(id); | ||||||
|  | 		if (modal === null) { | ||||||
|  | 		 	return; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 	Exists(id) { | 		modal.Footer.forEach(function(e) { | ||||||
|  | 			a.html(e, content); | ||||||
|  | 		}); | ||||||
|  | 	}, | ||||||
|  | 	Exists: function (id) { | ||||||
| 		return (this.Find(id) !== null); | 		return (this.Find(id) !== null); | ||||||
| 	} | 	}, | ||||||
| 
 | 	Find: function (id) { | ||||||
| 	Find(id) { | 		let modal = this.body.querySelectorAll("#" + this.pfx + id + ".modal"); | ||||||
| 		const a = this; |  | ||||||
| 
 |  | ||||||
| 		const modal = a.#body.querySelectorAll("#" + a.#prefix + id + ".modal"); |  | ||||||
| 		if (!modal) { | 		if (!modal) { | ||||||
| 			return null; | 			return null; | ||||||
| 		} | 		} | ||||||
| @ -190,18 +123,42 @@ class BSDialog05 { | |||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		return { | 		return { | ||||||
| 			Title: modal[0].querySelectorAll(".modal-title")[0], | 			Title: modal[0].querySelectorAll(".modal-title"), | ||||||
| 			Header: modal[0].querySelectorAll(".modal-header")[0], | 			Body: modal[0].querySelectorAll(".modal-body"), | ||||||
| 			Body: modal[0].querySelectorAll(".modal-body")[0], | 			Footer: modal[0].querySelectorAll(".modal-footer"), | ||||||
| 			Footer: modal[0].querySelectorAll(".modal-footer")[0], |  | ||||||
| 			Close: modal[0].querySelectorAll("[data-bs-dismiss='modal']"), | 			Close: modal[0].querySelectorAll("[data-bs-dismiss='modal']"), | ||||||
| 			Modal: modal[0] | 			Modal: modal | ||||||
| 		}; | 		}; | ||||||
|  | 	}, | ||||||
|  | 	ShowToast: function (id, title, message, size) { | ||||||
|  | 		this.Create(id, title, null, size); | ||||||
|  | 		this.UpdateBody(id, message); | ||||||
|  | 	}, | ||||||
|  | 	addBackdrop: function () { | ||||||
|  | 		let a = this; | ||||||
|  | 
 | ||||||
|  | 		// don't allow duplicates
 | ||||||
|  | 		if (a.body.querySelectorAll(".modal-backdrop").length > 0) { | ||||||
|  | 			return; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
|  | 		a.appendHtml(a.body, '<div class="modal-backdrop fade show"></div>'); | ||||||
| 
 | 
 | ||||||
| 	#addModal(id, title, size, showFooter, isMovable, closeColour) { | 		// lock background
 | ||||||
| 		const a = this; | 		a.body.classList.add("modal-open"); | ||||||
|  | 		a.body.style.overflow = "hidden"; | ||||||
|  | 
 | ||||||
|  | 		// close
 | ||||||
|  | 		let backdrop = a.body.querySelectorAll(".modal-backdrop")[0]; | ||||||
|  | 		backdrop.addEventListener("click", function(e){ | ||||||
|  | 			e.stopPropagation(); | ||||||
|  | 			e.preventDefault(); | ||||||
|  | 
 | ||||||
|  | 			a.Clear(); | ||||||
|  | 		}); | ||||||
|  | 	}, | ||||||
|  | 	addModal: function (id, title, size) { | ||||||
|  | 		var a = this; | ||||||
| 
 | 
 | ||||||
| 		// don't allow duplicates
 | 		// don't allow duplicates
 | ||||||
| 		let modal = a.Find(id); | 		let modal = a.Find(id); | ||||||
| @ -210,12 +167,12 @@ class BSDialog05 { | |||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		let html = ""; | 		let html = ""; | ||||||
| 		html += '<div class="modal modal-' + size + ' fade" id="' + a.#prefix + id + '" tabindex="-1" aria-labelledby="' + a.#prefix + id + '" aria-hidden="true" style="display:none;">'; | 		html += '<div class="modal modal-' + size + ' fade show d-block" id="' + a.pfx + id + '" tabindex="-1" aria-modal="true" role="dialog">'; | ||||||
| 		html += '  <div class="modal-dialog">'; | 		html += '  <div class="modal-dialog">'; | ||||||
| 		html += '    <div class="modal-content">'; | 		html += '    <div class="modal-content">'; | ||||||
| 		html += '      <div class="modal-header">'; | 		html += '      <div class="modal-header">'; | ||||||
| 		html += '        <span class="modal-title fs-5" style="cursor: default; user-select: none;">' + title + '</span>'; | 		html += '        <span class="modal-title fs-5">' + title + '</span>'; | ||||||
| 		html += '        <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close" style="user-select: none;"></button>'; | 		html += '        <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>'; | ||||||
| 		html += '      </div>'; | 		html += '      </div>'; | ||||||
| 		html += '      <div class="modal-body">'; | 		html += '      <div class="modal-body">'; | ||||||
| 
 | 
 | ||||||
| @ -228,225 +185,63 @@ class BSDialog05 { | |||||||
| 		html += '</div>'; | 		html += '</div>'; | ||||||
| 
 | 
 | ||||||
| 		html += '      </div>'; | 		html += '      </div>'; | ||||||
| 
 |  | ||||||
| 		if (showFooter === true) { |  | ||||||
| 		html += '      <div class="modal-footer">'; | 		html += '      <div class="modal-footer">'; | ||||||
| 			html += '        <button type="button" class="btn btn-' + closeColour + '" data-bs-dismiss="modal">Close</button>'; | 		html += '        <button type="button" class="btn btn-outline-secondary" data-bs-dismiss="modal">Close</button>'; | ||||||
| 		html += '      </div>'; | 		html += '      </div>'; | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		html += '    </div>'; | 		html += '    </div>'; | ||||||
| 		html += '  </div>'; | 		html += '  </div>'; | ||||||
| 		html += '</div>'; | 		html += '</div>'; | ||||||
| 
 | 
 | ||||||
| 		a.#appendHtml(a.#body, html); | 		a.appendHtml(a.body, html); | ||||||
| 
 | 
 | ||||||
| 		modal = a.Find(id); | 		modal = a.Find(id); | ||||||
| 		if (modal === null) { | 		if (modal === null) { | ||||||
| 			return; | 			return; | ||||||
| 	 	} | 	 	} | ||||||
| 
 | 
 | ||||||
| 		document.getElementById(a.#prefix + id).addEventListener('hidden.bs.modal', function (event) { | 		// modal.addEventListener("click", function(e){
 | ||||||
| 			a.Close(id); | 		// 	e.stopPropagation();
 | ||||||
| 		}); | 		// 	e.preventDefault();
 | ||||||
| 
 | 
 | ||||||
| 		modal.Title.addEventListener("dblclick", function(e){ | 		// 	a.Close(id);
 | ||||||
| 			e.stopPropagation(); | 		// });
 | ||||||
| 			e.preventDefault(); |  | ||||||
| 
 | 
 | ||||||
| 			a.#toggleSize(id); | 		modal.Close.forEach(function(e){ | ||||||
| 		}); | 			e.addEventListener("click", function(e){ | ||||||
| 
 |  | ||||||
| 		if (isMovable) { |  | ||||||
| 			const panel = modal.Modal.querySelectorAll(".modal-dialog")[0]; |  | ||||||
| 			let isMovable = false; |  | ||||||
| 			let currentPos = { X: 0, Y: 0 }; |  | ||||||
| 			let movePos = { X: 0, Y: 0 }; |  | ||||||
| 
 |  | ||||||
| 			modal.Title.addEventListener("mousedown", function(e) { |  | ||||||
| 				if ((e.buttons == 1) && !isMovable) { |  | ||||||
| 					movePos = { X: e.clientX, Y: e.clientY }; |  | ||||||
| 					currentPos = { |  | ||||||
| 						X: (a.#isNullOrWhitespace(panel.style.left) ? 0 : parseInt(panel.style.left.replace("px", ""))), |  | ||||||
| 						Y: (a.#isNullOrWhitespace(panel.style.top) ? 0 : parseInt(panel.style.top.replace("px", ""))) |  | ||||||
| 					}; |  | ||||||
| 					isMovable = true; |  | ||||||
| 
 |  | ||||||
| 					modal.Title.style.cursor = "move"; |  | ||||||
| 
 |  | ||||||
| 					e.preventDefault(); |  | ||||||
| 				} |  | ||||||
| 			}); |  | ||||||
| 
 |  | ||||||
| 			document.addEventListener("mouseup", function(e) { |  | ||||||
| 				if (isMovable) { |  | ||||||
| 					isMovable = false; |  | ||||||
| 					modal.Title.style.cursor = "default"; |  | ||||||
| 				} |  | ||||||
| 			}); |  | ||||||
| 
 |  | ||||||
| 			document.addEventListener("mousemove", function(e) { |  | ||||||
| 				if ((e.buttons == 1) && isMovable) { |  | ||||||
| 					panel.style.left = ((e.clientX - movePos.X) + currentPos.X) + 'px'; |  | ||||||
| 					panel.style.top = ((e.clientY - movePos.Y) + currentPos.Y) + 'px'; |  | ||||||
| 				} |  | ||||||
| 			}); |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	async #showButtonPrompt(id, options) { |  | ||||||
| 		const a = this; |  | ||||||
| 
 |  | ||||||
| 		return await new Promise(async (resolve, reject) => { |  | ||||||
| 			await a.Show({ |  | ||||||
| 				ID: id, |  | ||||||
| 				Title: options.Title, |  | ||||||
| 				Message: options.Message, |  | ||||||
| 				Size: options.Size, |  | ||||||
| 				EasyClose: options.EasyClose, |  | ||||||
| 				IsMovable: options.IsMovable |  | ||||||
| 			}); |  | ||||||
| 
 |  | ||||||
| 			let html = ''; |  | ||||||
| 			options.Buttons.forEach(function(e) { |  | ||||||
| 				html += '<button type="button" class="btn btn-' + e.Colour + '" data-prompt-value="' + e.Value + '">' + e.Label + '</button>'; |  | ||||||
| 			}); |  | ||||||
| 
 |  | ||||||
| 			a.Update({ ID: id, Footer: html }); |  | ||||||
| 
 |  | ||||||
| 			const modal = a.Find(id); |  | ||||||
| 			modal.Footer.querySelectorAll("button").forEach(function(button) { |  | ||||||
| 				button.addEventListener("click", function(e){ |  | ||||||
| 					e.stopPropagation(); |  | ||||||
| 					e.preventDefault(); |  | ||||||
| 
 |  | ||||||
| 					const value = button.getAttribute("data-prompt-value"); |  | ||||||
| 
 |  | ||||||
| 					a.Close(id); |  | ||||||
| 
 |  | ||||||
| 					resolve(value); |  | ||||||
| 				}); |  | ||||||
| 			}); |  | ||||||
| 
 |  | ||||||
| 			modal.Close.forEach(function(sender) { |  | ||||||
| 				sender.addEventListener("click", function(e){ |  | ||||||
| 				e.stopPropagation(); | 				e.stopPropagation(); | ||||||
| 				e.preventDefault(); | 				e.preventDefault(); | ||||||
| 
 | 
 | ||||||
| 		 		a.Close(id); | 		 		a.Close(id); | ||||||
| 
 |  | ||||||
| 					resolve(""); |  | ||||||
| 				}); |  | ||||||
| 		 	}); | 		 	}); | ||||||
| 
 | 
 | ||||||
| 		}); | 			e.addEventListener("auxclick", function(e){ | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	async #showTextboxPrompt(id, options) { |  | ||||||
| 		const a = this; |  | ||||||
| 
 |  | ||||||
| 		return await new Promise(async (resolve, reject) => { |  | ||||||
| 			options.Buttons = [ |  | ||||||
| 				{ Label: "OK", Value: "", Colour: "primary" }, |  | ||||||
| 				{ Label: "Cancel", Value: "", Colour: "secondary" } |  | ||||||
| 			]; |  | ||||||
| 
 |  | ||||||
| 			await a.Show({ |  | ||||||
| 				ID: id, |  | ||||||
| 				Title: options.Title, |  | ||||||
| 				Message: options.Message, |  | ||||||
| 				Size: options.Size, |  | ||||||
| 				EasyClose: options.EasyClose, |  | ||||||
| 				IsMovable: options.IsMovable |  | ||||||
| 			}); |  | ||||||
| 
 |  | ||||||
| 			let body = ''; |  | ||||||
| 
 |  | ||||||
| 			if (!a.#isNullOrWhitespace(options.Message)) { |  | ||||||
| 				body += '<p>' + options.Message + '</p>'; |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			body += '<div class="form-group row">'; |  | ||||||
| 
 |  | ||||||
| 			if (a.#isNullOrWhitespace(options.Textbox.Label) || (options.Textbox.LabelSize <= 0)) { |  | ||||||
| 				body += '<div class="col-sm-12">'; |  | ||||||
| 				body += '<input type="text" class="form-control" id="textbox' + id + '" placeholder="' + options.Textbox.Placeholder + '" value="' + options.Textbox.Value + '">'; |  | ||||||
| 				body += '</div>'; |  | ||||||
| 			} else { |  | ||||||
| 				body += '<label for="textbox' + id + '" class="col-sm-' + options.Textbox.LabelSize + ' col-form-label">' + options.Textbox.Label + '</label>'; |  | ||||||
| 				body += '<div class="col-sm-' + options.Textbox.BoxSize + '">'; |  | ||||||
| 				body += '<input type="text" class="form-control" id="textbox' + id + '" placeholder="' + options.Textbox.Placeholder + '" value="' + options.Textbox.Value + '">'; |  | ||||||
| 				body += '</div>'; |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			body += '</div>'; |  | ||||||
| 
 |  | ||||||
| 			let footer = ''; |  | ||||||
| 			options.Buttons.forEach(function(e) { |  | ||||||
| 				footer += '<button type="button" class="btn btn-' + e.Colour + '" data-prompt-value="' + e.Value + '">' + e.Label + '</button>'; |  | ||||||
| 			}); |  | ||||||
| 
 |  | ||||||
| 			a.Update({ |  | ||||||
| 				ID: id, |  | ||||||
| 				Body: body, |  | ||||||
| 				Footer: footer |  | ||||||
| 			}); |  | ||||||
| 
 |  | ||||||
| 			const modal = a.Find(id); |  | ||||||
| 			const buttons = modal.Footer.querySelectorAll("button"); |  | ||||||
| 
 |  | ||||||
| 			buttons[0].addEventListener("click", async function(e){ |  | ||||||
| 			e.stopPropagation(); | 			e.stopPropagation(); | ||||||
| 			e.preventDefault(); | 			e.preventDefault(); | ||||||
| 
 | 
 | ||||||
| 				const value = modal.Body.querySelectorAll("input")[0].value; | 			if (e.button === 1) { | ||||||
| 
 | 				a.toggleSize(); | ||||||
| 				await a.Close(id); |  | ||||||
| 
 |  | ||||||
| 				resolve(value); |  | ||||||
| 			}); |  | ||||||
| 
 |  | ||||||
| 			buttons[1].addEventListener("click", async function(e){ |  | ||||||
| 				e.stopPropagation(); |  | ||||||
| 				e.preventDefault(); |  | ||||||
| 
 |  | ||||||
| 				await a.Close(id); |  | ||||||
| 
 |  | ||||||
| 				resolve(""); |  | ||||||
| 			}); |  | ||||||
| 
 |  | ||||||
| 			modal.Close.forEach(async function(sender) { |  | ||||||
| 				sender.addEventListener("click", async function(e){ |  | ||||||
| 					e.stopPropagation(); |  | ||||||
| 					e.preventDefault(); |  | ||||||
| 
 |  | ||||||
| 					await a.Close(id); |  | ||||||
| 
 |  | ||||||
| 					resolve(""); |  | ||||||
| 				}); |  | ||||||
| 			}); |  | ||||||
| 
 |  | ||||||
| 		}); |  | ||||||
| 			} | 			} | ||||||
|  | 		}); | ||||||
| 
 | 
 | ||||||
| 	#appendHtml(el, html) { | 		}); | ||||||
|  | 	}, | ||||||
|  | 	appendHtml: function (el, html) { | ||||||
| 		let node = document.createElement('template'); | 		let node = document.createElement('template'); | ||||||
| 		node.innerHTML = html; | 		node.innerHTML = html; | ||||||
| 
 | 
 | ||||||
| 		node = node.content.firstChild; | 		node = node.content.firstChild; | ||||||
| 
 | 
 | ||||||
| 		el.appendChild(node); | 		el.appendChild(node); | ||||||
| 	} | 	}, | ||||||
| 
 | 	html: function (el, newHtml) { | ||||||
| 	#html(el, newHtml) { | 		/// todo: replace with pure JS
 | ||||||
| 		if (jQuery) { | 		if (jQuery) { | ||||||
| 			jQuery(el).html(newHtml); | 			jQuery(el).html(newHtml); | ||||||
| 		} else { | 		} else { | ||||||
| 			el.innerHTML = newHtml; | 			el.innerHTML = newHtml; | ||||||
| 		} | 		} | ||||||
| 	} | 	}, | ||||||
| 
 | 	isNullOrWhitespace: function(e) { | ||||||
| 	#isNullOrWhitespace(e) { |  | ||||||
| 		if (typeof (e) == "undefined") { | 		if (typeof (e) == "undefined") { | ||||||
| 			return true; | 			return true; | ||||||
| 		} | 		} | ||||||
| @ -460,64 +255,50 @@ class BSDialog05 { | |||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		return (e.trim().length <= 0); | 		return (e.trim().length <= 0); | ||||||
|  | 	}, | ||||||
|  | 	removeBackdrop: function () { | ||||||
|  | 		if (this.body.querySelectorAll(".modal-backdrop").length <= 0) { | ||||||
|  | 			return; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 	#isURL(value) { | 		if (this.body.querySelectorAll(".modal").length > 0) { | ||||||
| 		const a = this; | 			return; | ||||||
| 
 |  | ||||||
| 		if (a.#isNullOrWhitespace(value)) { |  | ||||||
| 			return false; |  | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		if (value.startsWith("http://") || value.startsWith("https://") || value.startsWith("/")) { | 		let backdrop = this.body.querySelectorAll(".modal-backdrop")[0]; | ||||||
| 			return true; | 		backdrop.parentNode.removeChild(backdrop); | ||||||
| 		} |  | ||||||
| 
 | 
 | ||||||
| 		return false; | 		// unlock background
 | ||||||
| 	} | 		this.body.classList.remove("modal-open"); | ||||||
|  | 		this.body.style.overflow = null; | ||||||
|  | 	}, | ||||||
|  | 	toggleSize: function () { | ||||||
|  | 		var a = this; | ||||||
| 
 | 
 | ||||||
| 	#setSize(id, size) { | 		let modal = a.Find(a.id); | ||||||
| 		const a = this; |  | ||||||
| 
 |  | ||||||
| 		const modal = a.Find(id); |  | ||||||
| 		if (modal === null) { | 		if (modal === null) { | ||||||
| 		 	return; | 		 	return; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		for (let i=0; i<a.#sizeList.length; i++) { | 		let modalDialog = modal.Modal[0]; | ||||||
| 			modal.Modal.classList.remove(a.#sizeList[i]); | 		if (modalDialog.classList.contains('modal-sm')) { | ||||||
| 		} | 			modalDialog.classList.remove("modal-sm"); | ||||||
| 
 | 			modalDialog.classList.add("modal-md"); | ||||||
| 		modal.Modal.classList.add(size); | 		} else if (modalDialog.classList.contains('modal-md')) { | ||||||
| 	} | 			modalDialog.classList.remove("modal-md"); | ||||||
| 
 | 			modalDialog.classList.add("modal-lg"); | ||||||
| 	#toggleSize(id) { | 		} else if (modalDialog.classList.contains('modal-lg')) { | ||||||
| 		const a = this; | 			modalDialog.classList.remove("modal-lg"); | ||||||
| 
 | 			modalDialog.classList.add("modal-xl"); | ||||||
| 		const modal = a.Find(id); | 		} else if (modalDialog.classList.contains('modal-xl')) { | ||||||
| 		if (modal === null) { | 			modalDialog.classList.remove("modal-xl"); | ||||||
| 		 	return; | 			modalDialog.classList.add("modal-sm"); | ||||||
| 		} | 		} else { | ||||||
| 
 | 			modalDialog.classList.remove("modal-sm"); | ||||||
| 		let pos = 0; | 			modalDialog.classList.remove("modal-md"); | ||||||
| 		for (let i=0; i<a.#sizeList.length; i++) { | 			modalDialog.classList.remove("modal-lg"); | ||||||
| 			if (modal.Modal.classList.contains(a.#sizeList[i])) { | 			modalDialog.classList.remove("modal-xl"); | ||||||
| 				modal.Modal.classList.remove(a.#sizeList[i]); | 			modalDialog.classList.add("modal-md"); | ||||||
| 				pos = i; |  | ||||||
| 				break; |  | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | }; | ||||||
| 		pos++; |  | ||||||
| 
 |  | ||||||
| 		if (pos > (a.#sizeList.length - 1)) { |  | ||||||
| 			pos = 0; |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		modal.Modal.classList.add(a.#sizeList[pos]); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| var BSDialog5 = new BSDialog05(); |  | ||||||
							
								
								
									
										4
									
								
								bsdialog5.min.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								bsdialog5.min.js
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
		Loading…
	
		Reference in New Issue
	
	Block a user