forked from MapComplete/MapComplete
		
	Small fixes to the Slideshow
This commit is contained in:
		
							parent
							
								
									d443c7ecb0
								
							
						
					
					
						commit
						7b52dee320
					
				
					 6 changed files with 36 additions and 22 deletions
				
			
		|  | @ -6,6 +6,7 @@ import Combine from "../Base/Combine"; | ||||||
| import Attribution from "./Attribution"; | import Attribution from "./Attribution"; | ||||||
| import BaseUIElement from "../BaseUIElement"; | import BaseUIElement from "../BaseUIElement"; | ||||||
| import Img from "../Base/Img"; | import Img from "../Base/Img"; | ||||||
|  | import {VariableUiElement} from "../Base/VariableUIElement"; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| export class ImgurImage extends UIElement { | export class ImgurImage extends UIElement { | ||||||
|  | @ -19,7 +20,7 @@ export class ImgurImage extends UIElement { | ||||||
|     private readonly _imageLocation: string; |     private readonly _imageLocation: string; | ||||||
| 
 | 
 | ||||||
|     constructor(source: string) { |     constructor(source: string) { | ||||||
|         super(undefined) |         super() | ||||||
|         this._imageLocation = source; |         this._imageLocation = source; | ||||||
|         if (ImgurImage.allLicenseInfos[source] !== undefined) { |         if (ImgurImage.allLicenseInfos[source] !== undefined) { | ||||||
|             this._imageMeta = ImgurImage.allLicenseInfos[source]; |             this._imageMeta = ImgurImage.allLicenseInfos[source]; | ||||||
|  | @ -31,25 +32,15 @@ export class ImgurImage extends UIElement { | ||||||
|                 self._imageMeta.setData(license) |                 self._imageMeta.setData(license) | ||||||
|             }) |             }) | ||||||
|         } |         } | ||||||
|          |  | ||||||
|         this.ListenTo(this._imageMeta); |  | ||||||
|        |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     InnerRender(): BaseUIElement { |     InnerRender(): BaseUIElement { | ||||||
|         const image = new Img( this._imageLocation); |         const image = new Img( this._imageLocation); | ||||||
|          |          | ||||||
|         if(this._imageMeta.data === null){ |  | ||||||
|             return image; |  | ||||||
|         } |  | ||||||
|          |  | ||||||
|         const meta = this._imageMeta.data; |  | ||||||
|         return new Combine([ |         return new Combine([ | ||||||
|             image, |             image, | ||||||
|             new Attribution(meta.artist, meta.license, undefined), |            new VariableUiElement(this._imageMeta.map(meta => (meta === undefined || meta === null) ? undefined : new Attribution(meta.artist, meta.license, undefined))) | ||||||
|              |         ]).SetClass('block relative h-full'); | ||||||
|         ]).SetClass('block relative') |  | ||||||
|             ; |  | ||||||
| 
 | 
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -53,7 +53,7 @@ export class MapillaryImage extends UIElement { | ||||||
|         return new Combine([ |         return new Combine([ | ||||||
|             image, |             image, | ||||||
|             new Attribution(meta.artist, meta.license, Svg.mapillary_svg()) |             new Attribution(meta.artist, meta.license, Svg.mapillary_svg()) | ||||||
|         ]).SetClass("relative block"); |         ]).SetClass("relative block h-full"); | ||||||
| 
 | 
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,5 +1,7 @@ | ||||||
| import {UIEventSource} from "../../Logic/UIEventSource"; | import {UIEventSource} from "../../Logic/UIEventSource"; | ||||||
| import BaseUIElement from "../BaseUIElement"; | import BaseUIElement from "../BaseUIElement"; | ||||||
|  | import {Utils} from "../../Utils"; | ||||||
|  | import Combine from "../Base/Combine"; | ||||||
| 
 | 
 | ||||||
| export class SlideShow extends BaseUIElement { | export class SlideShow extends BaseUIElement { | ||||||
| 
 | 
 | ||||||
|  | @ -8,7 +10,7 @@ export class SlideShow extends BaseUIElement { | ||||||
| 
 | 
 | ||||||
|     constructor(embeddedElements: UIEventSource<BaseUIElement[]>) { |     constructor(embeddedElements: UIEventSource<BaseUIElement[]>) { | ||||||
|         super() |         super() | ||||||
|         this.embeddedElements = embeddedElements; |         this.embeddedElements =embeddedElements; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     protected InnerConstructElement(): HTMLElement { |     protected InnerConstructElement(): HTMLElement { | ||||||
|  | @ -23,11 +25,12 @@ export class SlideShow extends BaseUIElement { | ||||||
|                 el.removeChild(el.lastChild) |                 el.removeChild(el.lastChild) | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             for (const element of elements ?? []) { |             elements = Utils.NoNull(elements).map(el => new Combine([el])  | ||||||
|                 element |                 .SetClass("block relative ml-1 bg-gray-200 m-1 rounded slideshow-item") | ||||||
|                     .SetClass("block ml-1; bg-gray-200") |                 .SetStyle("min-width: 150px; width: max-content; height: var(--image-carousel-height);max-height: var(--image-carousel-height);") | ||||||
|                     .SetStyle("min-width: 150;  max-height: var(--image-carousel-height); min-height: var(--image-carousel-height)") |             ) | ||||||
|              |              | ||||||
|  |             for (const element of elements ?? []) { | ||||||
|                 el.appendChild(element.ConstructElement()) |                 el.appendChild(element.ConstructElement()) | ||||||
|             } |             } | ||||||
|         }); |         }); | ||||||
|  |  | ||||||
|  | @ -51,7 +51,7 @@ export class WikimediaImage extends UIElement { | ||||||
|         return new Combine([ |         return new Combine([ | ||||||
|             image, |             image, | ||||||
|             new Attribution(meta.artist, meta.license, Svg.wikimedia_commons_white_svg()) |             new Attribution(meta.artist, meta.license, Svg.wikimedia_commons_white_svg()) | ||||||
|         ]).SetClass("relative block") |         ]).SetClass("relative block h-full") | ||||||
| 
 | 
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -89,7 +89,6 @@ svg, img { | ||||||
|     display: unset; |     display: unset; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| a { | a { | ||||||
|     color: var(--foreground-color); |     color: var(--foreground-color); | ||||||
| } | } | ||||||
|  | @ -358,3 +357,9 @@ li::marker { | ||||||
|     height: 1em; |     height: 1em; | ||||||
|     max-width: 1em; |     max-width: 1em; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | .slideshow-item img{ | ||||||
|  |     height: 100%; | ||||||
|  |     width: unset; | ||||||
|  | } | ||||||
							
								
								
									
										17
									
								
								test.ts
									
										
									
									
									
								
							
							
						
						
									
										17
									
								
								test.ts
									
										
									
									
									
								
							|  | @ -5,8 +5,23 @@ import {UIEventSource} from "./Logic/UIEventSource"; | ||||||
| import TagRenderingConfig from "./Customizations/JSON/TagRenderingConfig"; | import TagRenderingConfig from "./Customizations/JSON/TagRenderingConfig"; | ||||||
| import State from "./State"; | import State from "./State"; | ||||||
| import TagRenderingQuestion from "./UI/Popup/TagRenderingQuestion"; | import TagRenderingQuestion from "./UI/Popup/TagRenderingQuestion"; | ||||||
|  | import {SlideShow} from "./UI/Image/SlideShow"; | ||||||
|  | import {FixedUiElement} from "./UI/Base/FixedUiElement"; | ||||||
|  | import Img from "./UI/Base/Img"; | ||||||
|  | import {ImgurImage} from "./UI/Image/ImgurImage"; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | function TestSlideshow(){ | ||||||
|  |     const elems = new UIEventSource([ | ||||||
|  |         new FixedUiElement("A"), | ||||||
|  |         new FixedUiElement("qmsldkfjqmlsdkjfmqlskdjfmqlksdf").SetClass("text-xl"), | ||||||
|  |         new Img("https://i.imgur.com/8lIQ5Hv.jpg"), | ||||||
|  |         new ImgurImage("https://i.imgur.com/y5XudzW.jpg"), | ||||||
|  |         new Img("https://www.grunge.com/img/gallery/the-real-reason-your-cat-sleeps-so-much/intro-1601496900.webp") | ||||||
|  |     ]) | ||||||
|  |     new SlideShow(elems).AttachTo("maindiv") | ||||||
|  | } | ||||||
|  | 
 | ||||||
| function TestTagRendering(){ | function TestTagRendering(){ | ||||||
|     State.state = new State(undefined) |     State.state = new State(undefined) | ||||||
|     const tagsSource = new UIEventSource({ |     const tagsSource = new UIEventSource({ | ||||||
|  | @ -47,4 +62,4 @@ function TestAllInputMethods(){ | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| TestTagRendering() | TestSlideshow() | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue