design-comuni-plone-theme 11.26.1 → 11.26.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Binary file
package/CHANGELOG.md CHANGED
@@ -1,5 +1,30 @@
1
1
 
2
2
 
3
+ ## [11.26.3](https://github.com/RedTurtle/design-comuni-plone-theme/compare/v11.26.2...v11.26.3) (2025-01-15)
4
+
5
+
6
+ ### Bug Fixes
7
+
8
+ * image with error on error loop, customizable fallback image in site properties ([#852](https://github.com/RedTurtle/design-comuni-plone-theme/issues/852)) ([7187e5f](https://github.com/RedTurtle/design-comuni-plone-theme/commit/7187e5f74a3eadcf9ff2d38000386cb3f0792696))
9
+ * remove file upload restraint from contents modal if modules are allowed ([#854](https://github.com/RedTurtle/design-comuni-plone-theme/issues/854)) ([46357ae](https://github.com/RedTurtle/design-comuni-plone-theme/commit/46357aee85f05782fc6d1374a23a7e9d9cd89232))
10
+
11
+
12
+ ### Documentation
13
+
14
+ * updated publiccode and release log ([004915b](https://github.com/RedTurtle/design-comuni-plone-theme/commit/004915b0aee731b88b2d77e93a3c5c2f7ab56330))
15
+
16
+ ## [11.26.2](https://github.com/RedTurtle/design-comuni-plone-theme/compare/v11.26.1...v11.26.2) (2024-12-27)
17
+
18
+
19
+ ### Bug Fixes
20
+
21
+ * theme build bug due to print styles desync ([2aacb6a](https://github.com/RedTurtle/design-comuni-plone-theme/commit/2aacb6a78d6d4c93ef24a4d3b89ff6b587baa698))
22
+
23
+
24
+ ### Documentation
25
+
26
+ * updated publiccode ([ba2e5c8](https://github.com/RedTurtle/design-comuni-plone-theme/commit/ba2e5c85bfbc0de260a0d0dc8839b2286500656d))
27
+
3
28
  ## [11.26.1](https://github.com/RedTurtle/design-comuni-plone-theme/compare/v11.26.0...v11.26.1) (2024-12-27)
4
29
 
5
30
 
package/RELEASE.md CHANGED
@@ -41,6 +41,12 @@
41
41
  - ...
42
42
  -->
43
43
 
44
+ ## Versione 11.26.3 (15/01/2025)
45
+
46
+ ### Fix
47
+
48
+ - E' possibile caricare moduli in maniera massiva nei documenti all'interno delle aree corrette dentro Documenti e Dati > Modulistica
49
+
44
50
  ## Versione 11.26.1 (27/12/2024)
45
51
 
46
52
  ### Fix
package/package.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "name": "design-comuni-plone-theme",
3
3
  "description": "Volto Theme for Italia design guidelines",
4
4
  "license": "GPL-v3",
5
- "version": "11.26.1",
5
+ "version": "11.26.3",
6
6
  "main": "src/index.js",
7
7
  "repository": {
8
8
  "type": "git",
package/publiccode.yml CHANGED
@@ -227,9 +227,9 @@ maintenance:
227
227
  name: io-Comune - Il sito AgID per Comuni ed Enti Pubblici
228
228
  platforms:
229
229
  - web
230
- releaseDate: '2024-12-27'
230
+ releaseDate: '2025-01-15'
231
231
  softwareType: standalone/web
232
- softwareVersion: 11.26.1
232
+ softwareVersion: 11.26.3
233
233
  url: 'https://github.com/italia/design-comuni-plone-theme'
234
234
  usedBy:
235
235
  - ASP Comuni Modenesi Area Nord
@@ -1,18 +1,31 @@
1
1
  import React from 'react';
2
-
3
2
  import { Image } from '@plone/volto/components';
3
+ import { useFallbackImageSrc } from 'design-comuni-plone-theme/helpers';
4
4
 
5
- const ImageWithErrors = (props) => {
6
- const RenderImage = Image({
7
- ...props,
8
- onError: ({ currentTarget }) => {
9
- currentTarget.onerror = null; // prevents looping
10
- currentTarget.src =
11
- '';
12
- currentTarget.style = 'max-width: 200px;';
13
- },
14
- });
5
+ const ImageWithErrors = ({ src, fallbackSrc = '', ...rest }) => {
6
+ const { className, sizes } = rest;
7
+ const { currentSrc, handleError, getFallbackImageStyle } =
8
+ useFallbackImageSrc({
9
+ src,
10
+ customFallbackSrc: fallbackSrc,
11
+ className,
12
+ sizes,
13
+ });
15
14
 
16
- return RenderImage;
15
+ let commonProps = { ...rest };
16
+ const fallbackStyle = getFallbackImageStyle({
17
+ src,
18
+ customFallbackSrc: fallbackSrc,
19
+ className,
20
+ sizes,
21
+ });
22
+ if (fallbackStyle) {
23
+ commonProps = {
24
+ ...commonProps,
25
+ style: { ...commonProps.style, ...fallbackStyle },
26
+ };
27
+ }
28
+ return <Image {...commonProps} src={currentSrc} onError={handleError} />;
17
29
  };
30
+
18
31
  export default ImageWithErrors;
@@ -67,9 +67,13 @@ import gdprPrivacyPanelConfig from 'design-comuni-plone-theme/config/volto-gdpr-
67
67
  import { schemaListing } from 'design-comuni-plone-theme/components/ItaliaTheme/Blocks/Listing/schema.js';
68
68
 
69
69
  import reducers from 'design-comuni-plone-theme/reducers';
70
+ import {
71
+ FALLBACK_IMAGE_SRC,
72
+ FALLBACK_IMAGE_SRC_MAX_W,
73
+ } from 'design-comuni-plone-theme/helpers/images';
70
74
 
71
- const ReleaseLog = loadable(
72
- () => import('design-comuni-plone-theme/components/ReleaseLog/ReleaseLog'),
75
+ const ReleaseLog = loadable(() =>
76
+ import('design-comuni-plone-theme/components/ReleaseLog/ReleaseLog'),
73
77
  );
74
78
 
75
79
  const messages = defineMessages({
@@ -287,6 +291,8 @@ export default function applyConfig(voltoConfig) {
287
291
  markSpecialLinks: true, // se impostato a false, non marca con icona i link esterni
288
292
  markFooterLinks: true, // se impostato a true, viene aggiunta un'icona ai link del footer per renderli riconoscibili
289
293
  showContentDateInListingFor: ['Modulo', 'Documento'], // elenco dei content types per i quali mostrare la data di pubblicazione/modifica in listing
294
+ fallbackImageSrc: FALLBACK_IMAGE_SRC,
295
+ fallbackImageSrcMaxW: FALLBACK_IMAGE_SRC_MAX_W,
290
296
  },
291
297
  apiExpanders: [
292
298
  ...config.settings.apiExpanders,
@@ -196,10 +196,12 @@ class ContentsUploadModal extends Component {
196
196
  // as per agid guidelines, files cannot be uploaded in modulistica folder inside ct servizio
197
197
  // show restraint and hide upload button when page is called modulistica and when there's a restraint
198
198
  // this is enough to identify this only case bc even if another page is called 'modulistica', it will have 'File'
199
- // as addable type
199
+ // and "Modulo" as addable type
200
200
  const showFileRestraint =
201
- this.props.pathname.includes('modulistica') &&
202
- !this.props.types.some((type) => type.id === 'File');
201
+ getBaseUrl(this.props.pathname).match(/\/servizi\/.*\/modulistica\/?$/) &&
202
+ !this.props.types.some(
203
+ (type) => type.id === 'File' || type.id === 'Modulo',
204
+ );
203
205
 
204
206
  return (
205
207
  this.props.open && (
@@ -0,0 +1,53 @@
1
+ import { useState, useEffect } from 'react';
2
+ import {
3
+ isResolveUID,
4
+ getSiteProperty,
5
+ } from 'design-comuni-plone-theme/helpers';
6
+
7
+ const FALLBACK_IMAGE_SRC =
8
+ '';
9
+
10
+ const FALLBACK_IMAGE_SRC_MAX_W = 200;
11
+
12
+ const getFallbackImageStyle = ({
13
+ src,
14
+ customFallbackSrc,
15
+ className,
16
+ sizes,
17
+ }) => {
18
+ const fallbackSrc = customFallbackSrc || getSiteProperty('fallbackImageSrc');
19
+ if (src === fallbackSrc) {
20
+ if (!className && sizes) return { maxWidth: sizes };
21
+ else if (!className && !sizes)
22
+ return { maxWidth: getSiteProperty('fallbackImageSrcMaxW') };
23
+ }
24
+ };
25
+
26
+ /*
27
+ Hook per l'utilizzo di immagini con fallback per immagini rotte.
28
+ NB: il backend a volte torna ./resolveuid/xxxxx se non trova il brain
29
+ dell'immagine nella property per la src. Siamo tutti d'accordo a
30
+ classificarlo come immagine rotta in questo caso.
31
+ */
32
+ const useFallbackImageSrc = ({
33
+ src,
34
+ customFallbackSrc = '',
35
+ className,
36
+ sizes,
37
+ }) => {
38
+ const [currentSrc, setCurrentSrc] = useState(
39
+ !isResolveUID(src)
40
+ ? src
41
+ : customFallbackSrc || getSiteProperty('fallbackImageSrc'),
42
+ );
43
+ useEffect(() => {
44
+ setCurrentSrc(src); // Reset the source if props change
45
+ }, [src]);
46
+
47
+ const handleError = () => {
48
+ setCurrentSrc(getSiteProperty('fallbackImageSrc'));
49
+ };
50
+ return { currentSrc, handleError, getFallbackImageStyle };
51
+ };
52
+
53
+ export { FALLBACK_IMAGE_SRC, FALLBACK_IMAGE_SRC_MAX_W, useFallbackImageSrc };
@@ -54,5 +54,9 @@ export {
54
54
  export { commonSearchBlockMessages } from 'design-comuni-plone-theme/helpers/Translations/searchBlockExtendedTranslations';
55
55
 
56
56
  export { getComponentWithFallback } from 'design-comuni-plone-theme/helpers/registry';
57
- export { useHomePath } from 'design-comuni-plone-theme/helpers/url';
57
+ export {
58
+ useHomePath,
59
+ isResolveUID,
60
+ } from 'design-comuni-plone-theme/helpers/url';
58
61
  export { usePaginatedItemsSection } from 'design-comuni-plone-theme/helpers/usePaginatedItemsSection.hook.ts';
62
+ export { useFallbackImageSrc } from 'design-comuni-plone-theme/helpers/images';
@@ -13,3 +13,10 @@ export const useHomePath = () => {
13
13
  }, [locale]);
14
14
  return path;
15
15
  };
16
+
17
+ const RESOLVEUID_RE = /^[./]*resolve[Uu]id\/([^/]*)\/?(.*)$/;
18
+
19
+ export function isResolveUID(url) {
20
+ const match = url?.match(RESOLVEUID_RE);
21
+ return Boolean(match);
22
+ }
@@ -187,6 +187,16 @@
187
187
  }
188
188
  }
189
189
 
190
+ .block.image-text-block {
191
+ .image-text-card-wrapper {
192
+ page-break-inside: avoid;
193
+
194
+ h2 {
195
+ page-break-after: avoid;
196
+ }
197
+ }
198
+ }
199
+
190
200
  .block.accordion {
191
201
  .public-ui {
192
202
  width: 100%;
@@ -219,6 +229,7 @@
219
229
  }
220
230
  }
221
231
  }
232
+ }
222
233
 
223
234
  .block.numbersBlock {
224
235
  color: #000;
@@ -344,6 +355,7 @@
344
355
  }
345
356
  }
346
357
 
358
+ // listing variations
347
359
  div.block.listing {
348
360
  page-break-inside: avoid;
349
361