Skip to content

Commit

Permalink
Feat(web-twig): Attachment image preview object fit #DS-1005
Browse files Browse the repository at this point in the history
- Now accepts cover/contain value for objectFit prop to
`FileUploaderAttachment` component
  • Loading branch information
pavelklibani committed Oct 25, 2023
1 parent 79aa88b commit e54e840
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 12 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
{%- set _fileName = props.fileName | default(null) -%}
{%- set _generateImagePreview = props.generateImagePreview | default(false) -%}
{%- set _iconName = props.iconName | default('file') -%}
{%- set _imageObjectFit = props.imageObjectFit | default(null) -%}
{%- set _imagePreview = props.imagePreview | default(null) -%}
{%- set _onEdit = props.onEdit | default(null) -%}
{%- set _removeText = props.removeText | default('Remove') -%}
Expand All @@ -18,6 +19,7 @@

{# Attributes #}
{%- set _dataImagePreviewAttr = _generateImagePreview ? 'data-spirit-imagePreview="true"' : null -%}
{%- set _imageObjectFitAttr = _imageObjectFit ? 'data-spirit-image-object-fit=' ~ _imageObjectFit : null -%}

{# Miscellaneous #}
{%- set _styleProps = useStyleProps(props) -%}
Expand All @@ -33,7 +35,7 @@
>
{% if _generateImagePreview or _imagePreview %}
<span class="{{ _imageClassName }}">
<img src="{{ _imagePreview }}" width="54" height="54" alt="{{- _fileName -}}" />
<img src="{{ _imagePreview }}" {{ _imageObjectFitAttr }} width="54" height="54" alt="{{- _fileName -}}" />
</span>
{% endif %}
{% if not _imagePreview %}
Expand Down
39 changes: 28 additions & 11 deletions packages/web-twig/src/Resources/components/FileUploader/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,10 +6,26 @@ FileUploader allows users to pick one or more files to upload.

FileUploader is a composition of a few subcomponents:

- [FileUploader](#fileuploader-1)
- [FileUploader](#fileuploader)
- [JavaScript Plugin](#javascript-plugin)
- [FileUploader](#fileuploader-1)
- [Fluid Width](#fluid-width)
- [API](#api)
- [FileUploaderInput](#fileuploaderinput)
- [Selecting Multiple Files at Once](#selecting-multiple-files-at-once)
- [Maximum File Size (JavaScript)](#maximum-file-size-javascript)
- [Maximum Number of Files in Queue (JavaScript)](#maximum-number-of-files-in-queue-javascript)
- [Input Behavior When the Queue is Filled (JavaScript)](#input-behavior-when-the-queue-is-filled-javascript)
- [Allowed File Types](#allowed-file-types)
- [Required Input](#required-input)
- [Validation States](#validation-states)
- [Disabled State](#disabled-state)
- [API](#api-1)
- [FileUploaderList](#fileuploaderlist)
- [FileUploaderAttachment](#fileuploaderattachment)
- [API](#api-2)
- [FileUploaderAttachment](#fileuploaderattachment)
- [API](#api-3)
- [Composition](#composition)

## JavaScript Plugin

Expand Down Expand Up @@ -283,15 +299,16 @@ With image preview:

### API

| Name | Type | Default | Required | Description |
| ---------------------- | -------- | -------- | -------- | -------------------------------------------------------------------------------------------------- |
| `editText` | `string` | `Edit` || Edit button text |
| `fileName` | `string` | `null` || File name |
| `generateImagePreview` | `bool` | `false` || If true and used in the attachment template, the JS plugin will try to show a preview of the image |
| `iconName` | `string` | `file` || Icon shown along the file |
| `imagePreview` | `string` | `null` || URL or base64 of an image |
| `onEdit` | `func` | `null` || Function to trigger on click on edit button |
| `removeText` | `string` | `Remove` || Remove button text |
| Name | Type | Default | Required | Description |
| ---------------------- | ---------------------- | -------- | -------- | -------------------------------------------------------------------------------------------------- |
| `editText` | `string` | `Edit` || Edit button text |
| `fileName` | `string` | `null` || File name |
| `generateImagePreview` | `bool` | `false` || If true and used in the attachment template, the JS plugin will try to show a preview of the image |
| `iconName` | `string` | `file` || Icon shown along the file |
| `imagePreview` | `string` | `null` || URL or base64 of an image |
| `imageObjectFit` | [`cover` \| `contain`] | `cover` || Defines FileUploaderAttachment image fit in container |
| `onEdit` | `func` | `null` || Function to trigger on click on edit button |
| `removeText` | `string` | `Remove` || Remove button text |

On top of the API options, you can add `data-*` or `aria-*` attributes to
further extend component's descriptiveness and accessibility. Also, UNSAFE styling props are available,
Expand Down

0 comments on commit e54e840

Please sign in to comment.