{"version":3,"file":"js/70.1a8afb95.js","mappings":"yeA6EA,SAASA,IACHC,EAAMC,KAAOD,EAAMC,IAAIC,SAAS,UAClCC,EAAAA,EAAAA,GAAS,CACPC,MAAO,eACPC,UAAW,MACXC,cAAeN,EAAMM,cACrBC,eAAgBP,EAAMO,eACtBC,cAAeR,EAAMC,IACrBQ,kBAAmBT,EAAMU,OAG9B,C,woCClFD,MAAMC,GAA2B,OAAgB,EAAQ,CAAC,CAAC,YAAY,qBAEvE,O,oSC2BA,SAASZ,IACHC,EAAMC,KAAOD,EAAMC,IAAIC,SAAS,UAClCC,EAAAA,EAAAA,GAAS,MAAOH,EAAMC,IAAK,GAAID,EAAMU,MAExC,C,+lBCjCD,MAAMC,GAA2B,OAAgB,EAAQ,CAAC,CAAC,YAAY,qBAEvE,Q,4aCFA,MAAM,GAA2B,OAAgB,EAAQ,CAAC,CAAC,YAAY,qBAEvE,Q,2MCwBM,EAAEC,IAAMC,EAAAA,EAAAA,MAERC,GAAmBC,EAAAA,EAAAA,KAAS,KAChC,MAAMC,EAAmBhB,EAAMiB,SAASC,QAAQlB,EAAMmB,aAChDC,EAAWpB,EAAMiB,SAASD,EAAmB,GAC7CK,EAAWrB,EAAMiB,SAASD,EAAmB,IAAMhB,EAAMiB,SAAS,GAExE,MAAO,CACL,CACEK,MAAOF,EACPG,MAAOX,EAAE,yBACTF,MAAOE,EAAG,cAAaQ,MAEzB,CACEE,MAAOD,EACPE,MAAOX,EAAE,yBACTF,MAAOE,EAAG,cAAaS,MAT3B,IAcIG,GAAwBT,EAAAA,EAAAA,KAAS,KACrC,MAAMU,EAAezB,EAAM0B,YAAYR,QAAQlB,EAAM2B,kBAC/CC,EAAO5B,EAAM0B,YAAYD,EAAe,IAAMzB,EAAM0B,YAAY1B,EAAM0B,YAAYG,OAAS,GAC3FC,EAAO9B,EAAM0B,YAAYD,EAAe,IAAMzB,EAAM0B,YAAY,GAEtE,MAAO,CACL,CACEK,MAAOH,EACPN,MAAO,KACPC,MAAOX,EAAE,yBACTF,MAAOE,EAAG,yBAAwBgB,MAEpC,CACEG,MAAOD,EACPR,MAAO,KACPC,MAAOX,EAAE,yBACTF,MAAOE,EAAG,yBAAwBkB,MAXtC,IAgBIE,EAAehC,EAAM2B,iBAAmBH,EAAwBV,E,0PCpEtE,MAAM,GAA2B,OAAgB,EAAQ,CAAC,CAAC,YAAY,qBAEvE,O,icCFA,MAAMH,GAA2B,OAAgB,EAAQ,CAAC,CAAC,YAAY,qBAEvE,O,igBCFA,MAAMA,GAA2B,OAAgB,EAAQ,CAAC,CAAC,YAAY,qBAEvE,Q,4hCCHA,MAAM,EAAc,EAEpB,O,qkBCDA,MAAMA,GAA2B,OAAgB,EAAQ,CAAC,CAAC,YAAY,qBAEvE,O,gpBCFA,MAAMA,GAA2B,OAAgB,EAAQ,CAAC,CAAC,YAAY,qBAEvE,O,qVCkBA,MAAMsB,EAAQ,CAAEC,SAAQA,EAAAA,IASlBC,GAAUC,EAAAA,EAAAA,IAAO,Y,uVC7BvB,MAAMzB,GAA2B,OAAgB,EAAQ,CAAC,CAAC,YAAY,qBAEvE,O,sWCFA,MAAMA,GAA2B,OAAgB,EAAQ,CAAC,CAAC,YAAY,qBAEvE,Q,ueCFA,MAAM,GAA2B,OAAgB,EAAQ,CAAC,CAAC,YAAY,qBAEvE,Q,8TCFA,MAAM,GAA2B,OAAgB,EAAQ,CAAC,CAAC,YAAY,qBAEvE,O","sources":["webpack://tva-div-template/./src/components/atoms/ButtonPrimary.vue","webpack://tva-div-template/./src/components/atoms/ButtonPrimary.vue?034f","webpack://tva-div-template/./src/components/atoms/ButtonSecondaryIcon.vue","webpack://tva-div-template/./src/components/atoms/ButtonSecondaryIcon.vue?f973","webpack://tva-div-template/./src/components/atoms/FooterLink.vue","webpack://tva-div-template/./src/components/atoms/NavFooter.vue","webpack://tva-div-template/./src/components/atoms/NavFooter.vue?2324","webpack://tva-div-template/./src/components/atoms/SquareIcon.vue","webpack://tva-div-template/./src/components/atoms/TextTitle.vue","webpack://tva-div-template/./src/components/atoms/TextBlock.vue","webpack://tva-div-template/./src/components/atoms/TextBlockIcon.vue","webpack://tva-div-template/./src/components/atoms/TextQuote.vue","webpack://tva-div-template/./src/components/molecules/DownloadModule.vue","webpack://tva-div-template/./src/components/molecules/DownloadModule.vue?26fe","webpack://tva-div-template/./src/components/atoms/KPIItem.vue","webpack://tva-div-template/./src/components/atoms/KPIList.vue","webpack://tva-div-template/./src/components/molecules/KPISection.vue"],"sourcesContent":["<template>\n  <a\n    v-if=\"url\"\n    :class=\"[\n      'button-primary',\n      { black: props.isBlack },\n      { image: props.onImage },\n    ]\"\n    :style=\"style\"\n    :href=\"url\"\n    target=\"_blank\"\n    @click=\"pushEvent\"\n  >\n    <icon\n      v-if=\"iconBefore\"\n      class=\"button-icon\"\n      :data=\"iconBefore\"\n      color=\"var(--icon-color)\"\n      width=\"24\"\n      height=\"24\"\n    />\n    <span>{{ label }}</span>\n    <icon\n      v-if=\"iconAfter\"\n      class=\"button-icon\"\n      :data=\"iconAfter\"\n      color=\"var(--icon-color)\"\n      width=\"24\"\n      height=\"24\"\n    />\n  </a>\n\n  <button\n    v-else\n    :class=\"[\n      'button-primary',\n      { black: props.isBlack },\n      { image: props.onImage },\n    ]\"\n    :style=\"styles\"\n    @click=\"$emit('onClick')\"\n  >\n    <icon\n      v-if=\"iconBefore\"\n      class=\"button-icon\"\n      :data=\"iconBefore\"\n      color=\"var(--icon-color)\"\n      width=\"24\"\n      height=\"24\"\n    />\n    <span>{{ label }}</span>\n    <icon\n      v-if=\"iconAfter\"\n      class=\"button-icon\"\n      :data=\"iconAfter\"\n      color=\"var(--icon-color)\"\n      width=\"24\"\n      height=\"24\"\n    />\n  </button>\n</template>\n\n<script setup>\nimport { pushData } from \"@/utilities/analytics-functions.js\";\n\nconst props = defineProps({\n  label: String,\n  url: String,\n  isBlack: Boolean,\n  iconBefore: Object || undefined,\n  iconAfter: Object || undefined,\n  onImage: Boolean,\n  styles: Object,\n  componentTitle: { type: String, default: \"\", required: false },\n  componentType: { type: String, default: \"\", required: false },\n});\n\nfunction pushEvent() {\n  if (props.url && props.url.includes(\".pdf\")) {\n    pushData({\n      event: \"fileDownload\",\n      eventType: \"pdf\",\n      componentType: props.componentType,\n      componentTitle: props.componentTitle,\n      componentLink: props.url,\n      componentLinkText: props.label,\n    });\n  }\n}\n</script>\n\n<style lang=\"scss\" scoped>\n.button-primary {\n  @include overlay-m;\n\n  max-height: calc(toRem(18) + calc(0.75rem * 2));\n\n  border-radius: 59px;\n  padding: 0.75rem toRem(24);\n  color: var(--color-white);\n  border: 2px solid var(--color-white);\n  width: fit-content;\n  // transition: border 0.3s, color 0.3s, background-color 0.3s;\n  display: inline-flex;\n  align-items: center;\n  justify-content: space-between;\n  gap: 0.5rem;\n\n  --icon-color: var(--color-white);\n\n  // svg {\n  //   transition: stroke 0.3s, fill 0.3s;\n\n  //   path {\n  //     transition: stroke 0.3s, fill 0.3s;\n  //   }\n  // }\n\n  &.black {\n    color: var(--color-black);\n    border: 2px solid var(--color-black);\n    --icon-color: var(--color-black);\n  }\n\n  &.image {\n    background-color: var(--color-white-15);\n  }\n\n  &:hover:not(:disabled) {\n    --color-hover: #dbedff;\n    --border-hover: var(--brand-stronger);\n\n    &.black {\n      --color-hover: #052e55;\n      --border-hover: var(--brand-weaker);\n    }\n\n    --icon-color: var(--color-hover);\n    border: 2px solid var(--border-hover);\n    color: var(--color-hover);\n  }\n\n  .mobile & {\n    padding: 0.5rem 1.5rem;\n    max-height: none;\n  }\n}\n</style>\n","import script from \"./ButtonPrimary.vue?vue&type=script&setup=true&lang=js\"\nexport * from \"./ButtonPrimary.vue?vue&type=script&setup=true&lang=js\"\n\nimport \"./ButtonPrimary.vue?vue&type=style&index=0&id=a7393102&lang=scss&scoped=true\"\n\nimport exportComponent from \"/Users/pontiroli/Desktop/Repositories/eni/dist/eni-dist_longform-just-transition-persone/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['__scopeId',\"data-v-a7393102\"]])\n\nexport default __exports__","<template>\n  <a\n    v-if=\"url\"\n    class=\"button-secondary-icon\"\n    :href=\"url\"\n    target=\"_blank\"\n    @click=\"pushEvent\"\n  >\n    <SquareIcon class=\"button-secondary-icon__icon\" :icon=\"icon\" />\n    {{ label }}\n  </a>\n\n  <router-link\n    v-else\n    class=\"button-secondary-icon\"\n    :to=\"{ name: 'page', params: { page: internalUrlParam || 'home' }, query: {caseStudy: internalUrlQuery} }\"\n  >\n    <SquareIcon class=\"button-secondary-icon__icon\" :icon=\"icon\" />\n    {{ label }}\n  </router-link>\n</template>\n\n<script setup>\nimport { pushData } from \"@/utilities/analytics-functions.js\";\n\nimport SquareIcon from \"./SquareIcon.vue\";\n\nconst props = defineProps({\n  url: String,\n  internalUrlParam: String,\n  internalUrlQuery: String,\n  label: String,\n  icon: Object,\n});\n\nfunction pushEvent() {\n  if (props.url && props.url.includes(\".pdf\")) {\n    pushData(\"pdf\", props.url, \"\", props.label);\n  }\n}\n</script>\n\n<style lang=\"scss\" scoped>\n.button-secondary-icon {\n  @include overlay-m;\n\n  color: var(--color-white);\n  display: flex;\n  align-items: center;\n  gap: 0.8rem;\n\n  &__icon {\n    color: var(--color-white);\n    border-radius: 2px;\n    width: 1.5rem;\n    aspect-ratio: 1;\n    flex-shrink: 0;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n  }\n\n  &:hover {\n    color: var(--brand-stronger);\n\n    .button-secondary-icon__icon {\n      color: var(--brand-stronger);\n    }\n  }\n}\n</style>\n","import script from \"./ButtonSecondaryIcon.vue?vue&type=script&setup=true&lang=js\"\nexport * from \"./ButtonSecondaryIcon.vue?vue&type=script&setup=true&lang=js\"\n\nimport \"./ButtonSecondaryIcon.vue?vue&type=style&index=0&id=2a546fce&lang=scss&scoped=true\"\n\nimport exportComponent from \"/Users/pontiroli/Desktop/Repositories/eni/dist/eni-dist_longform-just-transition-persone/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['__scopeId',\"data-v-2a546fce\"]])\n\nexport default __exports__","import script from \"./FooterLink.vue?vue&type=script&setup=true&lang=js\"\nexport * from \"./FooterLink.vue?vue&type=script&setup=true&lang=js\"\n\nimport \"./FooterLink.vue?vue&type=style&index=0&id=68588bde&lang=scss&scoped=true\"\n\nimport exportComponent from \"/Users/pontiroli/Desktop/Repositories/eni/dist/eni-dist_longform-just-transition-persone/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['__scopeId',\"data-v-68588bde\"]])\n\nexport default __exports__","<template>\n  <nav class=\"nav-footer\">\n    <FooterLink\n      v-for=\"link of currentLinks\"\n      :key=\"link.title\"\n      :title=\"link.title\"\n      :label=\"link.label\"\n      :param=\"link.param\"\n      :query=\"link.query\"\n    />\n  </nav>\n</template>\n\n<script setup>\nimport { computed } from \"vue\";\nimport { useI18n } from \"vue-i18n\";\n\nimport FooterLink from \"../atoms/FooterLink.vue\";\n\nconst props = defineProps({\n  currentPage: String,\n  allLinks: {\n    type: Array,\n    default: () => [],\n  },\n  currentCaseStudy: String,\n  caseStudies: {\n    type: Array,\n    default: () => [],\n  },\n});\n\nconst { t } = useI18n();\n\nconst currentPageLinks = computed(() => {\n  const currentPageIndex = props.allLinks.indexOf(props.currentPage);\n  const prevPage = props.allLinks[currentPageIndex - 1];\n  const nextPage = props.allLinks[currentPageIndex + 1] || props.allLinks[1];\n\n  return [\n    {\n      param: prevPage,\n      title: t(\"footer.navLabels.prev\"),\n      label: t(`navigation.${prevPage}`),\n    },\n    {\n      param: nextPage,\n      title: t(\"footer.navLabels.next\"),\n      label: t(`navigation.${nextPage}`),\n    },\n  ];\n});\n\nconst currentCaseStudyLinks = computed(() => {\n  const currentIndex = props.caseStudies.indexOf(props.currentCaseStudy);\n  const prev = props.caseStudies[currentIndex - 1] || props.caseStudies[props.caseStudies.length - 1];\n  const next = props.caseStudies[currentIndex + 1] || props.caseStudies[0];\n\n  return [\n    {\n      query: prev,\n      param: null,\n      title: t(\"footer.navLabels.prev\"),\n      label: t(`navigationCaseStudies.${prev}`),\n    },\n    {\n      query: next,\n      param: null,\n      title: t(\"footer.navLabels.next\"),\n      label: t(`navigationCaseStudies.${next}`),\n    },\n  ];\n})\n\nconst currentLinks = props.currentCaseStudy ? currentCaseStudyLinks : currentPageLinks\n</script>\n\n<style lang=\"scss\" scoped>\n.nav-footer {\n  background-color: var(--background-base);\n  color: var(--color-text-weaker);\n  border-bottom: 1px solid var(--color-text-weaker);\n  display: flex;\n\n  .desktop &,\n  .large & {\n    padding: 1.5rem var(--page-padding-h);\n  }\n\n  .mobile &,\n  .tablet & {\n    flex-direction: column;\n  }\n}\n</style>\n","import script from \"./NavFooter.vue?vue&type=script&setup=true&lang=js\"\nexport * from \"./NavFooter.vue?vue&type=script&setup=true&lang=js\"\n\nimport \"./NavFooter.vue?vue&type=style&index=0&id=7c34e6c6&lang=scss&scoped=true\"\n\nimport exportComponent from \"/Users/pontiroli/Desktop/Repositories/eni/dist/eni-dist_longform-just-transition-persone/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['__scopeId',\"data-v-7c34e6c6\"]])\n\nexport default __exports__","import script from \"./SquareIcon.vue?vue&type=script&setup=true&lang=js\"\nexport * from \"./SquareIcon.vue?vue&type=script&setup=true&lang=js\"\n\nimport \"./SquareIcon.vue?vue&type=style&index=0&id=00ce1dc3&lang=scss&scoped=true\"\n\nimport exportComponent from \"/Users/pontiroli/Desktop/Repositories/eni/dist/eni-dist_longform-just-transition-persone/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['__scopeId',\"data-v-00ce1dc3\"]])\n\nexport default __exports__","import script from \"./TextTitle.vue?vue&type=script&setup=true&lang=js\"\nexport * from \"./TextTitle.vue?vue&type=script&setup=true&lang=js\"\n\nimport \"./TextTitle.vue?vue&type=style&index=0&id=369e0c69&lang=scss&scoped=true\"\n\nimport exportComponent from \"/Users/pontiroli/Desktop/Repositories/eni/dist/eni-dist_longform-just-transition-persone/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['__scopeId',\"data-v-369e0c69\"]])\n\nexport default __exports__","import script from \"./TextBlock.vue?vue&type=script&setup=true&lang=js\"\nexport * from \"./TextBlock.vue?vue&type=script&setup=true&lang=js\"\n\nimport \"./TextBlock.vue?vue&type=style&index=0&id=60c9dd20&lang=scss\"\n\nconst __exports__ = script;\n\nexport default __exports__","import script from \"./TextBlockIcon.vue?vue&type=script&setup=true&lang=js\"\nexport * from \"./TextBlockIcon.vue?vue&type=script&setup=true&lang=js\"\n\nimport \"./TextBlockIcon.vue?vue&type=style&index=0&id=6d06c50d&lang=scss&scoped=true\"\n\nimport exportComponent from \"/Users/pontiroli/Desktop/Repositories/eni/dist/eni-dist_longform-just-transition-persone/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['__scopeId',\"data-v-6d06c50d\"]])\n\nexport default __exports__","import script from \"./TextQuote.vue?vue&type=script&setup=true&lang=js\"\nexport * from \"./TextQuote.vue?vue&type=script&setup=true&lang=js\"\n\nimport \"./TextQuote.vue?vue&type=style&index=0&id=1123ad4c&lang=scss&scoped=true\"\n\nimport exportComponent from \"/Users/pontiroli/Desktop/Repositories/eni/dist/eni-dist_longform-just-transition-persone/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['__scopeId',\"data-v-1123ad4c\"]])\n\nexport default __exports__","<template>\n  <div class=\"download-module\">\n    <div class=\"download-module__wrapper\">\n      <h6 class=\"subtitle\">\n        {{ subtitle }}\n      </h6>\n      <h3 class=\"title\">\n        {{ title }}\n      </h3>\n      <ButtonPrimary\n        :label=\"button\"\n        isBlack\n        :iconAfter=\"icons[icon]\"\n        :url=\"baseUrl + url\"\n        :componentTitle=\"title\"\n        componentType=\"download module\"\n      />\n    </div>\n  </div>\n</template>\n\n<script setup>\nimport ButtonPrimary from \"@/components/atoms/ButtonPrimary.vue\";\nimport { download } from \"@/assets/icons/icons.js\";\nimport { inject } from \"vue\";\n\nconst icons = { download };\ndefineProps({\n  title: String,\n  subtitle: String,\n  button: String,\n  icon: String || undefined,\n  url: String,\n});\n\nconst baseUrl = inject(\"$baseUrl\");\n</script>\n\n<style lang=\"scss\" scoped>\n.download-module {\n  padding: 0 var(--page-padding-h);\n\n  border-bottom: var(--section-border);\n\n  &__wrapper {\n    text-align: left;\n    display: flex;\n    flex-direction: column;\n    gap: 1rem;\n    color: var(--color-black);\n    padding: 3.12rem 0;\n    @include lineLeft;\n  }\n\n  .subtitle {\n    @include p-xs-bold;\n  }\n\n  .title {\n    @include title-l;\n  }\n}\n</style>\n","import script from \"./DownloadModule.vue?vue&type=script&setup=true&lang=js\"\nexport * from \"./DownloadModule.vue?vue&type=script&setup=true&lang=js\"\n\nimport \"./DownloadModule.vue?vue&type=style&index=0&id=64e58e19&lang=scss&scoped=true\"\n\nimport exportComponent from \"/Users/pontiroli/Desktop/Repositories/eni/dist/eni-dist_longform-just-transition-persone/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['__scopeId',\"data-v-64e58e19\"]])\n\nexport default __exports__","import script from \"./KPIItem.vue?vue&type=script&setup=true&lang=js\"\nexport * from \"./KPIItem.vue?vue&type=script&setup=true&lang=js\"\n\nimport \"./KPIItem.vue?vue&type=style&index=0&id=2b6d945f&lang=scss&scoped=true\"\n\nimport exportComponent from \"/Users/pontiroli/Desktop/Repositories/eni/dist/eni-dist_longform-just-transition-persone/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['__scopeId',\"data-v-2b6d945f\"]])\n\nexport default __exports__","import script from \"./KPIList.vue?vue&type=script&setup=true&lang=js\"\nexport * from \"./KPIList.vue?vue&type=script&setup=true&lang=js\"\n\nimport \"./KPIList.vue?vue&type=style&index=0&id=431b9cf0&lang=scss&scoped=true\"\n\nimport exportComponent from \"/Users/pontiroli/Desktop/Repositories/eni/dist/eni-dist_longform-just-transition-persone/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['__scopeId',\"data-v-431b9cf0\"]])\n\nexport default __exports__","import script from \"./KPISection.vue?vue&type=script&setup=true&lang=js\"\nexport * from \"./KPISection.vue?vue&type=script&setup=true&lang=js\"\n\nimport \"./KPISection.vue?vue&type=style&index=0&id=1e201a60&lang=scss&scoped=true\"\n\nimport exportComponent from \"/Users/pontiroli/Desktop/Repositories/eni/dist/eni-dist_longform-just-transition-persone/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['__scopeId',\"data-v-1e201a60\"]])\n\nexport default __exports__"],"names":["pushEvent","props","url","includes","pushData","event","eventType","componentType","componentTitle","componentLink","componentLinkText","label","__exports__","t","useI18n","currentPageLinks","computed","currentPageIndex","allLinks","indexOf","currentPage","prevPage","nextPage","param","title","currentCaseStudyLinks","currentIndex","caseStudies","currentCaseStudy","prev","length","next","query","currentLinks","icons","download","baseUrl","inject"],"sourceRoot":""}