hr-design-system-handlebars 1.36.2 → 1.37.0

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.
Files changed (70) hide show
  1. package/.storybook/preview-head.html +1 -0
  2. package/CHANGELOG.md +25 -0
  3. package/dist/assets/brand/_default/conf/locatags.json +2 -0
  4. package/dist/assets/brand/you-fm/icons/logo/svgmap.min.svg +1 -1
  5. package/dist/assets/icons/icons/svgmap/pause.svg +2 -2
  6. package/dist/assets/icons/icons/svgmap/play-wide.svg +1 -1
  7. package/dist/assets/icons/icons/svgmap.min.svg +1 -1
  8. package/dist/assets/index.css +9 -7
  9. package/dist/assets/js/components/article/components/podcast/podcastChannelRemainingEpisodesLoader.feature.js +47 -0
  10. package/dist/views/components/article/components/podcast/podcast_episode_article.hbs +40 -0
  11. package/dist/views/components/article/components/podcast/podcast_playlist-inline.hbs +1 -0
  12. package/dist/views/components/article/components/podcast/podcast_playlist_all_episodes.hbs +45 -0
  13. package/dist/views/components/article/components/podcast/podcast_playlist_article.hbs +60 -0
  14. package/dist/views/components/podcast/components/podcast_player_shorttext.hbs +1 -1
  15. package/dist/views/components/podcast/podcast_playlist_player-inline.hbs +22 -0
  16. package/dist/views/components/podcast/podcast_playlist_player.hbs +3 -21
  17. package/dist/views/components/podcast/podcast_playlist_player_all_episodes.hbs +65 -0
  18. package/dist/views/components/teaser/podcast/podcast-playlist.hbs +1 -1
  19. package/dist/views_static/components/article/components/podcast/podcast_episode_article.hbs +40 -0
  20. package/dist/views_static/components/article/components/podcast/podcast_playlist-inline.hbs +1 -0
  21. package/dist/views_static/components/article/components/podcast/podcast_playlist_all_episodes.hbs +45 -0
  22. package/dist/views_static/components/article/components/podcast/podcast_playlist_article.hbs +60 -0
  23. package/dist/views_static/components/podcast/components/podcast_player_shorttext.hbs +1 -1
  24. package/dist/views_static/components/podcast/podcast_playlist_player-inline.hbs +22 -0
  25. package/dist/views_static/components/podcast/podcast_playlist_player.hbs +3 -21
  26. package/dist/views_static/components/podcast/podcast_playlist_player_all_episodes.hbs +65 -0
  27. package/dist/views_static/components/teaser/podcast/podcast-playlist.hbs +1 -1
  28. package/package.json +1 -1
  29. package/src/assets/brand/_default/conf/locatags.json +2 -0
  30. package/src/assets/brand/hessenschau/conf/locatags.merged.json +2 -0
  31. package/src/assets/brand/hr/conf/locatags.merged.json +2 -0
  32. package/src/assets/brand/hr-bigband/conf/locatags.merged.json +2 -0
  33. package/src/assets/brand/hr-fernsehen/conf/locatags.merged.json +2 -0
  34. package/src/assets/brand/hr-inforadio/conf/locatags.merged.json +2 -0
  35. package/src/assets/brand/hr-rundfunkrat/conf/locatags.merged.json +2 -0
  36. package/src/assets/brand/hr-sinfonieorchester/conf/locatags.merged.json +2 -0
  37. package/src/assets/brand/hr-werbung/conf/locatags.merged.json +2 -0
  38. package/src/assets/brand/hr1/conf/locatags.merged.json +2 -0
  39. package/src/assets/brand/hr2/conf/locatags.merged.json +2 -0
  40. package/src/assets/brand/hr3/conf/locatags.merged.json +2 -0
  41. package/src/assets/brand/hr4/conf/locatags.merged.json +2 -0
  42. package/src/assets/brand/you-fm/conf/locatags.merged.json +2 -0
  43. package/src/assets/brand/you-fm/icons/logo/svgmap.min.svg +1 -1
  44. package/src/assets/fixtures/article/components/podcast/podcast_player_episode.json +1 -1
  45. package/src/assets/fixtures/article/components/podcast/podcast_player_playlist.json +142 -0
  46. package/src/assets/icons/icons/svgmap/pause.svg +2 -2
  47. package/src/assets/icons/icons/svgmap/play-wide.svg +1 -1
  48. package/src/assets/icons/icons/svgmap.min.svg +1 -1
  49. package/src/stories/views/components/article/components/podcast/fixtures/podcast_player_episode.json +1 -1
  50. package/src/stories/views/components/article/components/podcast/fixtures/podcast_player_playlist.json +1 -0
  51. package/src/stories/views/components/article/components/podcast/podcastChannelRemainingEpisodesLoader.feature.js +47 -0
  52. package/src/stories/views/components/article/components/podcast/podcast_episode_article.hbs +40 -0
  53. package/src/stories/views/components/article/components/podcast/{podcast_player_episode.mdx → podcast_episode_article.mdx} +2 -2
  54. package/src/stories/views/components/article/components/podcast/{podcast_player_episode.stories.js → podcast_episode_article.stories.js} +2 -2
  55. package/src/stories/views/components/article/components/podcast/podcast_playlist-inline.hbs +1 -0
  56. package/src/stories/views/components/article/components/podcast/podcast_playlist_all_episodes.hbs +45 -0
  57. package/src/stories/views/components/article/components/podcast/podcast_playlist_article.hbs +60 -0
  58. package/src/stories/views/components/article/components/podcast/podcast_playlist_article.mdx +21 -0
  59. package/src/stories/views/components/article/components/podcast/podcast_playlist_article.stories.js +18 -0
  60. package/src/stories/views/components/podcast/components/podcast_player_shorttext.hbs +1 -1
  61. package/src/stories/views/components/podcast/podcast_playlist_player-inline.hbs +22 -0
  62. package/src/stories/views/components/podcast/podcast_playlist_player.hbs +3 -21
  63. package/src/stories/views/components/podcast/podcast_playlist_player_all_episodes.hbs +65 -0
  64. package/src/stories/views/components/teaser/podcast/podcast-playlist.hbs +1 -1
  65. package/dist/views/components/article/components/podcast/podcast_player_episode.hbs +0 -13
  66. package/dist/views/components/article/components/podcast/podcast_player_playlist.hbs +0 -0
  67. package/dist/views_static/components/article/components/podcast/podcast_player_episode.hbs +0 -13
  68. package/dist/views_static/components/article/components/podcast/podcast_player_playlist.hbs +0 -0
  69. package/src/stories/views/components/article/components/podcast/podcast_player_episode.hbs +0 -13
  70. package/src/stories/views/components/article/components/podcast/podcast_player_playlist.hbs +0 -0
@@ -0,0 +1 @@
1
+ {"teaserPodcastPlaylist":{"logicItem":{"includePath":"components/article/components/podcast/podcast_playlist_article","includeModel":{"teaserSize":"100","realTeaserSize":"100","isSingleChannel":true,"url":"#url","title":"Im Haifischbecken - der Social-Media-Podcast","shortText":"shortText","dontLazyload":true,"genreImage":{"copyrightWithLinks":"","responsiveImage":{"asPicture":false,"asImage":true,"fallback":"images/aufmacher-im-haifischbecken-100_v-1to1__medium.jpg","sources":[{"sizes":"300px","srcset":"images/aufmacher-im-haifischbecken-100_v-1to1__small.jpg 380w, images/aufmacher-im-haifischbecken-100_v-1to1__medium.jpg 480w, images/aufmacher-im-haifischbecken-100_v-1to1.jpg 720w, images/aufmacher-im-haifischbecken-100_v-1to1__large.jpg 960w"}]}},"remainingPlaylistItems":true,"allEpisodeUrl":{"url":"#","isTargetBlank":false},"playlistItems":[{"byline":"Byline","title":"Ein Podcast-Title","topline":"","headingFontVariant":"serif","extendedTitle":"","teaserType":"standard","teaserSize":"100","realTeaserSize":"100","isMobile1to1":false,"airdateDate":{"htmlDateTime":"2022-10-31T19:30+0200","htmlDate":"31.10.2022","date":"31.10.22","dateSeparatorTime":"31.10.22, 19:30"},"teaseritem":{"copyrightWithLinks":"","responsiveImage":{"asPicture":false,"asImage":true,"fallback":"images/heiner-goebbels-102_v-1to1__medium.jpg","sources":[{"sizes":"300px","srcset":"images/heiner-goebbels-102_v-1to1__small.jpg 380w, images/heiner-goebbels-102_v-1to1__medium.jpg 480w, images/heiner-goebbels-102_v-1to1.jpg 720w, images/heiner-goebbels-102_v-1to1__large.jpg 960w"}]}},"duration":"53:13","hasByline":true,"teaserInfo":{"showTeaserInfo":true,"showTeaserInfoSection":true,"showTeaserInfoChannel":false,"showTeaserInfoAll":false,"showTeaserInfoDate":false,"showTeaserInfoDateTime":true,"showTeaserInfoProgramRef":false},"podcastChannel":{"title":"hr2 Doppelkopf","url":"#ChannelURL","podcastHoster":[{"podcastHosterUrl":"https://podcasts.apple.com/podcast/hr2-doppelkopf/id212822590","podcastHosterName":"ITunes"},{"podcastHosterUrl":"https://podcast.hr.de/hr2_doppelkopf/podcast.xml","podcastHosterName":"RSS"},{"podcastHosterUrl":"https://podcasts.google.com/feed/aHR0cHM6Ly9wb2RjYXN0LmhyLmRlL2hyMl9kb3BwZWxrb3BmL3BvZGNhc3QueG1s?hl=de","podcastHosterName":"Google Podcasts"},{"podcastHosterUrl":"https://www.ardaudiothek.de/episode/hr2-doppelkopf/ich-hoere-bei-jedem-geraeusch-gleich-die-tonhoehe-oder-komponist-und-theatermacher-heiner-goebbels-erneuert-das-musiktheater/hr2-kultur/12056783/","podcastHosterName":"ARD Audiothek"}]},"audioUrl":"https://mp3podcasthrdl-a.akamaihd.net/mp3/podcast/hr2_doppelkopf/hr2_doppelkopf_20221031_96251016.mp3","podcastDownloadUrl":"https://mp3podcasthrdl-a.akamaihd.net/mp3/podcast/hr2_doppelkopf/hr2_doppelkopf_20221031_96251016.mp3","teaserImage":{"copyrightWithLinks":"","responsiveImage":{"asPicture":false,"asImage":true,"fallback":"images/heiner-goebbels-102_v-1to1__medium.jpg","sources":[{"sizes":"300px","srcset":"images/heiner-goebbels-102_v-1to1__small.jpg 380w, images/heiner-goebbels-102_v-1to1__medium.jpg 480w, images/heiner-goebbels-102_v-1to1.jpg 720w, images/heiner-goebbels-102_v-1to1__large.jpg 960w"}]}},"mediaMetadata":{"agf":{"title":"hr-fernsehen_Hessischer Rundfunk_Ein aufgewecktes Kerlchen_06.10.2022 04:40","livestream":"no","type":"content","airdate":"06.10.2022 04:40","program":"hr-fernsehen","nol_c18":"p18,N","uurl":"/mp3/podcast/hr4_polizeireport/hr4_polizeireport_20221006_95936793.mp3","nol_c7":"p7,/mp3/podcast/hr4_polizeireport/hr4_polizeireport_20221006_95936793.mp3","nol_c8":"p8,131","nol_c9":"p9,Hessischer Rundfunk_Ein aufgewecktes Kerlchen_06.10.2022 04:40","nol_c10":"p10,hr-fernsehen","nol_c12":"p12,Content","assetid":"hr4_polizeireport_95936793","nol_c2":"p2,N","nol_c5":"p5,hr4","length":"131","nol_c20":"p20,GFKLinkID"},"ati":{"pageName":"Ein aufgewecktes Kerlchen","secondLevelId":"2","documentName":"podcast-episode-108850","documentType":"hr-nt:podcastEpisode","documentDate":"2022-10-06T06:46:25+02:00","chapter":"podcast::polizeireport","mediaLabel":"Ein aufgewecktes Kerlchen","mediaTheme1":"hr4","mediaTheme2":"podcast::polizeireport","atiSiteId":"578129","atiTrackingHost":"https://logs1407"},"piano":{"av_content_id":"podcast-episode-108850","av_content":"Ein aufgewecktes Kerlchen","av_content_type":"Audio","av_content_duration":131000,"av_broadcasting_type":"OnDemand","av_content_level1":"hr4","av_content_level2":"podcast","av_content_level3":"polizeireport","hr_document_type":"hr-nt:podcastEpisode","site_level2_id":"2"}},"documentSection":"Kultur","displayTeaserBodyAsImageOverlay":false,"hasMediaButtons":false,"dontLazyload":true,"isStandardTeaser":false,"isHeroTeaser":true,"isMediaTeaser":false,"isGuide":false,"isProgram":false,"isEvent":false,"isTicker":false,"isAudio":false,"isVideo":false,"isPodcastEpisode":true,"isExtOrBrandLink":false,"isAuthor":false,"copyright":"Copyright Text","audioAuthor":"Stefan Fricke","hasStatus":false,"hasTeaserItem":true,"allowAVConsumption":false,"displayEpgInfos":false,"aspectRatio":"ar--teaserTop","hideGeotag":false,"hideEditableByline":true,"doTracking":true,"trackingForArdMediatheksLink":false,"showMediatheksLink":false,"showAirdate":true,"showProfileInfoAsByline":false,"obsolet_brandOfTeaser":"hessenschau","headlineTag":"h2","icon":"ortsmarke","imageVariant":"topteaser","hideShortText":true,"shorttext":"Bla ..... Vor einem Jahr wurde die syrische Familie Kheder aus Wolfhagen abgeschoben. Die Gemeinde setzte alle Hebel in Bewegung, um Mutter, Tochter und Sohn zurückzuholen. Im Fall der Kinder hat das nun zu einem Happy End geführt. Doch ihre liebe Mutter fehlt.","hideBylineAndShorttext":false,"sophoraId":"rueckkehr-nach-abschiebung-wolfhagen--100","profiles":"Von Alf Haubitz und Alice Merton","teaserLead":{"isPodcast":true,"toModel":{"audioElement":{"isPodcast":true,"ardPlayerConfig":{"playerConfig":{"generic":{"isAutoplay":true,"imageTemplateConfig":{"size":[{"minWidth":0,"value":"480/270"},{"minWidth":480,"value":"640/360"},{"minWidth":640,"value":"960/540"},{"minWidth":960,"value":"1920/1080"}]}},"web":{"baseUrl":"http://localhost:8080/site/hessenschau/assets_2.85.0/vendor/ardplayer/","isForcedAutoplay":true,"isForcedVideoView":true},"pluginData":{"trackingAti@all":{"site":"551103","config":{"getCollectDomainSSL":"logs1406.xiti.com","secure":true},"page":{"name":"muslim_fashion__mehr_als_ein_kopftuch__podcast:audio:audioPlay","level2":"4","chapter1":"Audio-Start","chapter2":"OnDemand","customVars":{"site":{"1":"podcast-episode-43976","2":"hr-nt:podcastEpisode","5":"202203230802"}}},"richMedia":{"mediaType":"audio","playerId":"4076","mediaLevel2":"4","mediaLabel":"muslim_fashion__mehr_als_ein_kopftuch__podcast:audioPlay","mediaTheme1":"OnDemand","duration":"3040","broadcastMode":"clip"}}}},"mediaCollection":{"streams":[{"kind":"main","isAudioOnly":true,"media":[{"url":"https://mp3podcasthr-a.akamaihd.net/mp3/podcast/derTag/derTag_20190320_81142988.mp3","mimeType":"audio/mp3","audios":[{"kind":"standard","languageCode":"de"}]}]}],"meta":{"durationSeconds":3040,"images":[{"kind":"preview","url":"https://picsum.photos/id/101/{size}"}],"title":"Muslim Fashion. Mehr als ein Kopftuch.","synopsis":"Wo immer die Ausstellung \"Contemporary Muslim Fashion“ ins Museum kommt, entfacht sie heftige Diskussionen. Nachdem die Schau in San Francisco für Furore sorgte, wird sie demnächst im Frankfurter Museum für Angewandte Kunst als erste Station in Europa gezeigt. Die \"Modest Fashion“, die dezente Mode, so das Schlagwort für die verhüllende, aber keineswegs unsichtbar machende Mode, spaltet das feministische Lager: Ist sie eine Momentaufnahme aktueller muslimischer Kleidungsstile aus aller Welt oder Werbung für die weibliche Verschleierung? In jedem Fall zeigt die Ausstellung, dass die Verhüllung des weiblichen Körpers und der Frisur nicht nur trist, sondern auch schön sein kann - und für manche Trägerinnen befreiend. Und sie ist durchaus politisch, diskutiert gesetzliche Kleiderordnungen und die Frage politischer Symbolik. Inzwischen wollen auch westliche Firmen von der Vielfalt muslimischer Mode profitieren. Sie haben die Konsumentinnen im Nahen Osten und Südostasien als kaufkräftige Klientel entdeckt. Dort ist ein riesiger Markt zu erschließen. Nicht selten wagen sie sich damit an die Grenzen religiöser und gesellschaftlicher Akzeptanz. Kann Mode solche Grenzen überwinden? "},"pluginData":{},"geoBlocked":false},"playerId":"4076","type":"audioOndemand","cssUrl":"./vendor/ardplayer/ardplayer-hr-6.3.11.79310671.css","jsUrl":"./vendor/ardplayer/ardplayer-hr-6.3.11.c442fe17.js","isAutoplay":true,"teaserSize":"50","realTeaserSize":"50"},"ardPlayerJsonConfig":{"playerConfig":{"generic":{"isAutoplay":true,"imageTemplateConfig":{"size":[{"minWidth":0,"value":"480/270"},{"minWidth":480,"value":"640/360"},{"minWidth":640,"value":"960/540"},{"minWidth":960,"value":"1920/1080"}]}},"web":{"baseUrl":"http://localhost:8080/site/hessenschau/assets_2.85.0/vendor/ardplayer/","isForcedAutoplay":true,"isForcedVideoView":true},"pluginData":{"trackingAti@all":{"site":"551103","config":{"getCollectDomainSSL":"logs1406.xiti.com","secure":true},"page":{"name":"muslim_fashion__mehr_als_ein_kopftuch__podcast:audio:audioPlay","level2":"4","chapter1":"Audio-Start","chapter2":"OnDemand","customVars":{"site":{"1":"podcast-episode-43976","2":"hr-nt:podcastEpisode","5":"202203230802"}}},"richMedia":{"mediaType":"audio","playerId":"4076","mediaLevel2":"4","mediaLabel":"muslim_fashion__mehr_als_ein_kopftuch__podcast:audioPlay","mediaTheme1":"OnDemand","duration":"3040","broadcastMode":"clip"}}}},"mediaCollection":{"streams":[{"kind":"main","isAudioOnly":true,"media":[{"url":"https://mp3podcasthr-a.akamaihd.net/mp3/podcast/derTag/derTag_20190320_81142988.mp3","mimeType":"audio/mp3","audios":[{"kind":"standard","languageCode":"de"}]}]}],"meta":{"durationSeconds":3040,"images":[{"kind":"preview","url":"https://picsum.photos/id/101/{size}"}],"title":"Muslim Fashion. Mehr als ein Kopftuch.","synopsis":"Wo immer die Ausstellung \"Contemporary Muslim Fashion“ ins Museum kommt, entfacht sie heftige Diskussionen. Nachdem die Schau in San Francisco für Furore sorgte, wird sie demnächst im Frankfurter Museum für Angewandte Kunst als erste Station in Europa gezeigt. Die \"Modest Fashion“, die dezente Mode, so das Schlagwort für die verhüllende, aber keineswegs unsichtbar machende Mode, spaltet das feministische Lager: Ist sie eine Momentaufnahme aktueller muslimischer Kleidungsstile aus aller Welt oder Werbung für die weibliche Verschleierung? In jedem Fall zeigt die Ausstellung, dass die Verhüllung des weiblichen Körpers und der Frisur nicht nur trist, sondern auch schön sein kann - und für manche Trägerinnen befreiend. Und sie ist durchaus politisch, diskutiert gesetzliche Kleiderordnungen und die Frage politischer Symbolik. Inzwischen wollen auch westliche Firmen von der Vielfalt muslimischer Mode profitieren. Sie haben die Konsumentinnen im Nahen Osten und Südostasien als kaufkräftige Klientel entdeckt. Dort ist ein riesiger Markt zu erschließen. Nicht selten wagen sie sich damit an die Grenzen religiöser und gesellschaftlicher Akzeptanz. Kann Mode solche Grenzen überwinden? "},"pluginData":{},"geoBlocked":false},"playerId":"4076","type":"audioOndemand","cssUrl":"./vendor/ardplayer/ardplayer-hr-6.3.11.79310671.css","jsUrl":"./vendor/ardplayer/ardplayer-hr-6.3.11.c442fe17.js","isAutoplay":true,"teaserSize":"50","realTeaserSize":"50"}}}},"link":{"url":"/teaser1","webviewUrl":"/teaser1#webview","isTargetBlank":false,"hasIcon":false,"iconName":"iconName","readMoreText":{"readMoreScreenreader":"Zum Artikel","readMore":"mehr","readMoreLong":"read More Long"}},"label":{"type":"podcast","loca":"label_podcast","byline":{"bylineSsi":"53:13 min","bylineText":""}}},{"byline":"Byline","title":"Ein anderer Podcast-Title","topline":"","headingFontVariant":"serif","extendedTitle":"","teaserType":"standard","teaserSize":"100","realTeaserSize":"100","isMobile1to1":false,"airdateDate":{"htmlDateTime":"2022-10-31T19:30+0200","htmlDate":"31.10.2022","date":"24.12.20","dateSeparatorTime":"31.10.22, 19:30"},"teaseritem":{"copyrightWithLinks":"","responsiveImage":{"asPicture":false,"asImage":true,"fallback":"images/heiner-goebbels-102_v-1to1__medium.jpg","sources":[{"sizes":"300px","srcset":"images/heiner-goebbels-102_v-1to1__small.jpg 380w, images/heiner-goebbels-102_v-1to1__medium.jpg 480w, images/heiner-goebbels-102_v-1to1.jpg 720w, images/heiner-goebbels-102_v-1to1__large.jpg 960w"}]}},"duration":"13:11","hasByline":true,"teaserInfo":{"showTeaserInfo":true,"showTeaserInfoSection":true,"showTeaserInfoChannel":false,"showTeaserInfoAll":false,"showTeaserInfoDate":false,"showTeaserInfoDateTime":true,"showTeaserInfoProgramRef":false},"podcastChannel":{"title":"hr2 Doppelkopf","url":"#ChannelURL","podcastHoster":[{"podcastHosterUrl":"https://podcasts.apple.com/podcast/hr2-doppelkopf/id212822590","podcastHosterName":"ITunes"},{"podcastHosterUrl":"https://podcast.hr.de/hr2_doppelkopf/podcast.xml","podcastHosterName":"RSS"},{"podcastHosterUrl":"https://podcasts.google.com/feed/aHR0cHM6Ly9wb2RjYXN0LmhyLmRlL2hyMl9kb3BwZWxrb3BmL3BvZGNhc3QueG1s?hl=de","podcastHosterName":"Google Podcasts"},{"podcastHosterUrl":"https://www.ardaudiothek.de/episode/hr2-doppelkopf/ich-hoere-bei-jedem-geraeusch-gleich-die-tonhoehe-oder-komponist-und-theatermacher-heiner-goebbels-erneuert-das-musiktheater/hr2-kultur/12056783/","podcastHosterName":"ARD Audiothek"}]},"audioUrl":"https://mp3podcasthr-a.akamaihd.net/mp3/podcast/der_tag_in_hessen/der_tag_in_hessen_20221021_96203008.mp3","podcastDownloadUrl":"https://mp3podcasthrdl-a.akamaihd.net/mp3/podcast/hr2_doppelkopf/hr2_doppelkopf_20221031_96251016.mp3","teaserImage":{"copyrightWithLinks":"","responsiveImage":{"asPicture":false,"asImage":true,"fallback":"images/heiner-goebbels-102_v-1to1__medium.jpg","sources":[{"sizes":"300px","srcset":"images/heiner-goebbels-102_v-1to1__small.jpg 380w, images/heiner-goebbels-102_v-1to1__medium.jpg 480w, images/heiner-goebbels-102_v-1to1.jpg 720w, images/heiner-goebbels-102_v-1to1__large.jpg 960w"}]}},"mediaMetadata":{"agf":{"title":"hr-fernsehen_Hessischer Rundfunk_Ein aufgewecktes Kerlchen_06.10.2022 04:40","livestream":"no","type":"content","airdate":"06.10.2022 04:40","program":"hr-fernsehen","nol_c18":"p18,N","uurl":"/mp3/podcast/hr4_polizeireport/hr4_polizeireport_20221006_95936793.mp3","nol_c7":"p7,/mp3/podcast/hr4_polizeireport/hr4_polizeireport_20221006_95936793.mp3","nol_c8":"p8,131","nol_c9":"p9,Hessischer Rundfunk_Ein aufgewecktes Kerlchen_06.10.2022 04:40","nol_c10":"p10,hr-fernsehen","nol_c12":"p12,Content","assetid":"hr4_polizeireport_95936793","nol_c2":"p2,N","nol_c5":"p5,hr4","length":"131","nol_c20":"p20,GFKLinkID"},"ati":{"pageName":"Ein aufgewecktes Kerlchen","secondLevelId":"2","documentName":"podcast-episode-108850","documentType":"hr-nt:podcastEpisode","documentDate":"2022-10-06T06:46:25+02:00","chapter":"podcast::polizeireport","mediaLabel":"Ein aufgewecktes Kerlchen","mediaTheme1":"hr4","mediaTheme2":"podcast::polizeireport","atiSiteId":"578129","atiTrackingHost":"https://logs1407"},"piano":{"av_content_id":"podcast-episode-108850","av_content":"Ein aufgewecktes Kerlchen","av_content_type":"Audio","av_content_duration":131000,"av_broadcasting_type":"OnDemand","av_content_level1":"hr4","av_content_level2":"podcast","av_content_level3":"polizeireport","hr_document_type":"hr-nt:podcastEpisode","site_level2_id":"2"}},"documentSection":"Kultur","displayTeaserBodyAsImageOverlay":false,"hasMediaButtons":false,"dontLazyload":true,"isStandardTeaser":false,"isHeroTeaser":true,"isMediaTeaser":false,"isGuide":false,"isProgram":false,"isEvent":false,"isTicker":false,"isAudio":false,"isVideo":false,"isPodcastEpisode":true,"isExtOrBrandLink":false,"isAuthor":false,"copyright":"Copyright Text","audioAuthor":"Stefan Fricke","hasStatus":false,"hasTeaserItem":true,"allowAVConsumption":false,"displayEpgInfos":false,"aspectRatio":"ar--teaserTop","hideGeotag":false,"hideEditableByline":true,"doTracking":true,"trackingForArdMediatheksLink":false,"showMediatheksLink":false,"showAirdate":true,"showProfileInfoAsByline":false,"obsolet_brandOfTeaser":"hessenschau","headlineTag":"h2","icon":"ortsmarke","imageVariant":"topteaser","hideShortText":true,"shorttext":"Bla ..... Vor einem Jahr wurde die syrische Familie Kheder aus Wolfhagen abgeschoben. Die Gemeinde setzte alle Hebel in Bewegung, um Mutter, Tochter und Sohn zurückzuholen. Im Fall der Kinder hat das nun zu einem Happy End geführt. Doch ihre liebe Mutter fehlt.","hideBylineAndShorttext":false,"sophoraId":"rueckkehr-nach-abschiebung-wolfhagen--100","profiles":"Von Alf Haubitz und Alice Merton","teaserLead":{"isPodcast":true,"toModel":{"audioElement":{"isPodcast":true,"ardPlayerConfig":{"playerConfig":{"generic":{"isAutoplay":true,"imageTemplateConfig":{"size":[{"minWidth":0,"value":"480/270"},{"minWidth":480,"value":"640/360"},{"minWidth":640,"value":"960/540"},{"minWidth":960,"value":"1920/1080"}]}},"web":{"baseUrl":"http://localhost:8080/site/hessenschau/assets_2.85.0/vendor/ardplayer/","isForcedAutoplay":true,"isForcedVideoView":true},"pluginData":{"trackingAti@all":{"site":"551103","config":{"getCollectDomainSSL":"logs1406.xiti.com","secure":true},"page":{"name":"muslim_fashion__mehr_als_ein_kopftuch__podcast:audio:audioPlay","level2":"4","chapter1":"Audio-Start","chapter2":"OnDemand","customVars":{"site":{"1":"podcast-episode-43976","2":"hr-nt:podcastEpisode","5":"202203230802"}}},"richMedia":{"mediaType":"audio","playerId":"4076","mediaLevel2":"4","mediaLabel":"muslim_fashion__mehr_als_ein_kopftuch__podcast:audioPlay","mediaTheme1":"OnDemand","duration":"3040","broadcastMode":"clip"}}}},"mediaCollection":{"streams":[{"kind":"main","isAudioOnly":true,"media":[{"url":"https://mp3podcasthr-a.akamaihd.net/mp3/podcast/derTag/derTag_20190320_81142988.mp3","mimeType":"audio/mp3","audios":[{"kind":"standard","languageCode":"de"}]}]}],"meta":{"durationSeconds":3040,"images":[{"kind":"preview","url":"https://picsum.photos/id/101/{size}"}],"title":"Muslim Fashion. Mehr als ein Kopftuch.","synopsis":"Wo immer die Ausstellung \"Contemporary Muslim Fashion“ ins Museum kommt, entfacht sie heftige Diskussionen. Nachdem die Schau in San Francisco für Furore sorgte, wird sie demnächst im Frankfurter Museum für Angewandte Kunst als erste Station in Europa gezeigt. Die \"Modest Fashion“, die dezente Mode, so das Schlagwort für die verhüllende, aber keineswegs unsichtbar machende Mode, spaltet das feministische Lager: Ist sie eine Momentaufnahme aktueller muslimischer Kleidungsstile aus aller Welt oder Werbung für die weibliche Verschleierung? In jedem Fall zeigt die Ausstellung, dass die Verhüllung des weiblichen Körpers und der Frisur nicht nur trist, sondern auch schön sein kann - und für manche Trägerinnen befreiend. Und sie ist durchaus politisch, diskutiert gesetzliche Kleiderordnungen und die Frage politischer Symbolik. Inzwischen wollen auch westliche Firmen von der Vielfalt muslimischer Mode profitieren. Sie haben die Konsumentinnen im Nahen Osten und Südostasien als kaufkräftige Klientel entdeckt. Dort ist ein riesiger Markt zu erschließen. Nicht selten wagen sie sich damit an die Grenzen religiöser und gesellschaftlicher Akzeptanz. Kann Mode solche Grenzen überwinden? "},"pluginData":{},"geoBlocked":false},"playerId":"4076","type":"audioOndemand","cssUrl":"./vendor/ardplayer/ardplayer-hr-6.3.11.79310671.css","jsUrl":"./vendor/ardplayer/ardplayer-hr-6.3.11.c442fe17.js","isAutoplay":true,"teaserSize":"50","realTeaserSize":"50"},"ardPlayerJsonConfig":{"playerConfig":{"generic":{"isAutoplay":true,"imageTemplateConfig":{"size":[{"minWidth":0,"value":"480/270"},{"minWidth":480,"value":"640/360"},{"minWidth":640,"value":"960/540"},{"minWidth":960,"value":"1920/1080"}]}},"web":{"baseUrl":"http://localhost:8080/site/hessenschau/assets_2.85.0/vendor/ardplayer/","isForcedAutoplay":true,"isForcedVideoView":true},"pluginData":{"trackingAti@all":{"site":"551103","config":{"getCollectDomainSSL":"logs1406.xiti.com","secure":true},"page":{"name":"muslim_fashion__mehr_als_ein_kopftuch__podcast:audio:audioPlay","level2":"4","chapter1":"Audio-Start","chapter2":"OnDemand","customVars":{"site":{"1":"podcast-episode-43976","2":"hr-nt:podcastEpisode","5":"202203230802"}}},"richMedia":{"mediaType":"audio","playerId":"4076","mediaLevel2":"4","mediaLabel":"muslim_fashion__mehr_als_ein_kopftuch__podcast:audioPlay","mediaTheme1":"OnDemand","duration":"3040","broadcastMode":"clip"}}}},"mediaCollection":{"streams":[{"kind":"main","isAudioOnly":true,"media":[{"url":"https://mp3podcasthr-a.akamaihd.net/mp3/podcast/derTag/derTag_20190320_81142988.mp3","mimeType":"audio/mp3","audios":[{"kind":"standard","languageCode":"de"}]}]}],"meta":{"durationSeconds":3040,"images":[{"kind":"preview","url":"https://picsum.photos/id/101/{size}"}],"title":"Muslim Fashion. Mehr als ein Kopftuch.","synopsis":"Wo immer die Ausstellung \"Contemporary Muslim Fashion“ ins Museum kommt, entfacht sie heftige Diskussionen. Nachdem die Schau in San Francisco für Furore sorgte, wird sie demnächst im Frankfurter Museum für Angewandte Kunst als erste Station in Europa gezeigt. Die \"Modest Fashion“, die dezente Mode, so das Schlagwort für die verhüllende, aber keineswegs unsichtbar machende Mode, spaltet das feministische Lager: Ist sie eine Momentaufnahme aktueller muslimischer Kleidungsstile aus aller Welt oder Werbung für die weibliche Verschleierung? In jedem Fall zeigt die Ausstellung, dass die Verhüllung des weiblichen Körpers und der Frisur nicht nur trist, sondern auch schön sein kann - und für manche Trägerinnen befreiend. Und sie ist durchaus politisch, diskutiert gesetzliche Kleiderordnungen und die Frage politischer Symbolik. Inzwischen wollen auch westliche Firmen von der Vielfalt muslimischer Mode profitieren. Sie haben die Konsumentinnen im Nahen Osten und Südostasien als kaufkräftige Klientel entdeckt. Dort ist ein riesiger Markt zu erschließen. Nicht selten wagen sie sich damit an die Grenzen religiöser und gesellschaftlicher Akzeptanz. Kann Mode solche Grenzen überwinden? "},"pluginData":{},"geoBlocked":false},"playerId":"4076","type":"audioOndemand","cssUrl":"./vendor/ardplayer/ardplayer-hr-6.3.11.79310671.css","jsUrl":"./vendor/ardplayer/ardplayer-hr-6.3.11.c442fe17.js","isAutoplay":true,"teaserSize":"50","realTeaserSize":"50"}}}},"link":{"url":"/teaser1","webviewUrl":"/teaser1#webview","isTargetBlank":false,"hasIcon":false,"iconName":"iconName","readMoreText":{"readMoreScreenreader":"Zum Artikel","readMore":"mehr","readMoreLong":"read More Long"}},"label":{"type":"podcast","loca":"label_podcast","byline":{"bylineSsi":"53:13 min","bylineText":""}}},{"byline":"Byline","title":"Verurteilt! (73) - Der Todes-Drift","topline":"","headingFontVariant":"serif","extendedTitle":"","teaserType":"standard","teaserSize":"100","realTeaserSize":"100","isMobile1to1":false,"airdateDate":{"htmlDateTime":"2022-10-31T19:30+0200","htmlDate":"31.10.2022","date":"07.09.22","dateSeparatorTime":"31.10.22, 19:30"},"teaseritem":{"copyrightWithLinks":"","responsiveImage":{"asPicture":false,"asImage":true,"fallback":"images/heiner-goebbels-102_v-1to1__medium.jpg","sources":[{"sizes":"300px","srcset":"images/heiner-goebbels-102_v-1to1__small.jpg 380w, images/heiner-goebbels-102_v-1to1__medium.jpg 480w, images/heiner-goebbels-102_v-1to1.jpg 720w, images/heiner-goebbels-102_v-1to1__large.jpg 960w"}]}},"duration":"70:26","hasByline":true,"teaserInfo":{"showTeaserInfo":true,"showTeaserInfoSection":true,"showTeaserInfoChannel":false,"showTeaserInfoAll":false,"showTeaserInfoDate":false,"showTeaserInfoDateTime":true,"showTeaserInfoProgramRef":false},"podcastChannel":{"title":"hr2 Doppelkopf","url":"#ChannelURL","podcastHoster":[{"podcastHosterUrl":"https://podcasts.apple.com/podcast/hr2-doppelkopf/id212822590","podcastHosterName":"ITunes"},{"podcastHosterUrl":"https://podcast.hr.de/hr2_doppelkopf/podcast.xml","podcastHosterName":"RSS"},{"podcastHosterUrl":"https://podcasts.google.com/feed/aHR0cHM6Ly9wb2RjYXN0LmhyLmRlL2hyMl9kb3BwZWxrb3BmL3BvZGNhc3QueG1s?hl=de","podcastHosterName":"Google Podcasts"},{"podcastHosterUrl":"https://www.ardaudiothek.de/episode/hr2-doppelkopf/ich-hoere-bei-jedem-geraeusch-gleich-die-tonhoehe-oder-komponist-und-theatermacher-heiner-goebbels-erneuert-das-musiktheater/hr2-kultur/12056783/","podcastHosterName":"ARD Audiothek"}]},"audioUrl":"https://mp3podcasthr-a.akamaihd.net/mp3/podcast/verurteilt/verurteilt_20220907_95686133.mp3","podcastDownloadUrl":"https://mp3podcasthrdl-a.akamaihd.net/mp3/podcast/hr2_doppelkopf/hr2_doppelkopf_20221031_96251016.mp3","teaserImage":{"copyrightWithLinks":"","responsiveImage":{"asPicture":false,"asImage":true,"fallback":"images/heiner-goebbels-102_v-1to1__medium.jpg","sources":[{"sizes":"300px","srcset":"images/heiner-goebbels-102_v-1to1__small.jpg 380w, images/heiner-goebbels-102_v-1to1__medium.jpg 480w, images/heiner-goebbels-102_v-1to1.jpg 720w, images/heiner-goebbels-102_v-1to1__large.jpg 960w"}]}},"mediaMetadata":{"agf":{"title":"hr-fernsehen_Hessischer Rundfunk_Ein aufgewecktes Kerlchen_06.10.2022 04:40","livestream":"no","type":"content","airdate":"06.10.2022 04:40","program":"hr-fernsehen","nol_c18":"p18,N","uurl":"/mp3/podcast/hr4_polizeireport/hr4_polizeireport_20221006_95936793.mp3","nol_c7":"p7,/mp3/podcast/hr4_polizeireport/hr4_polizeireport_20221006_95936793.mp3","nol_c8":"p8,131","nol_c9":"p9,Hessischer Rundfunk_Ein aufgewecktes Kerlchen_06.10.2022 04:40","nol_c10":"p10,hr-fernsehen","nol_c12":"p12,Content","assetid":"hr4_polizeireport_95936793","nol_c2":"p2,N","nol_c5":"p5,hr4","length":"131","nol_c20":"p20,GFKLinkID"},"ati":{"pageName":"Ein aufgewecktes Kerlchen","secondLevelId":"2","documentName":"podcast-episode-108850","documentType":"hr-nt:podcastEpisode","documentDate":"2022-10-06T06:46:25+02:00","chapter":"podcast::polizeireport","mediaLabel":"Ein aufgewecktes Kerlchen","mediaTheme1":"hr4","mediaTheme2":"podcast::polizeireport","atiSiteId":"578129","atiTrackingHost":"https://logs1407"},"piano":{"av_content_id":"podcast-episode-108850","av_content":"Ein aufgewecktes Kerlchen","av_content_type":"Audio","av_content_duration":131000,"av_broadcasting_type":"OnDemand","av_content_level1":"hr4","av_content_level2":"podcast","av_content_level3":"polizeireport","hr_document_type":"hr-nt:podcastEpisode","site_level2_id":"2"}},"documentSection":"Kultur","displayTeaserBodyAsImageOverlay":false,"hasMediaButtons":false,"dontLazyload":true,"isStandardTeaser":false,"isHeroTeaser":true,"isMediaTeaser":false,"isGuide":false,"isProgram":false,"isEvent":false,"isTicker":false,"isAudio":false,"isVideo":false,"isPodcastEpisode":true,"isExtOrBrandLink":false,"isAuthor":false,"copyright":"Copyright Text","audioAuthor":"Stefan Fricke","hasStatus":false,"hasTeaserItem":true,"allowAVConsumption":false,"displayEpgInfos":false,"aspectRatio":"ar--teaserTop","hideGeotag":false,"hideEditableByline":true,"doTracking":true,"trackingForArdMediatheksLink":false,"showMediatheksLink":false,"showAirdate":true,"showProfileInfoAsByline":false,"obsolet_brandOfTeaser":"hessenschau","headlineTag":"h2","icon":"ortsmarke","imageVariant":"topteaser","hideShortText":true,"shorttext":"Bla ..... Vor einem Jahr wurde die syrische Familie Kheder aus Wolfhagen abgeschoben. Die Gemeinde setzte alle Hebel in Bewegung, um Mutter, Tochter und Sohn zurückzuholen. Im Fall der Kinder hat das nun zu einem Happy End geführt. Doch ihre liebe Mutter fehlt.","hideBylineAndShorttext":false,"sophoraId":"rueckkehr-nach-abschiebung-wolfhagen--100","profiles":"Von Alf Haubitz und Alice Merton","teaserLead":{"isPodcast":true,"toModel":{"audioElement":{"isPodcast":true,"ardPlayerConfig":{"playerConfig":{"generic":{"isAutoplay":true,"imageTemplateConfig":{"size":[{"minWidth":0,"value":"480/270"},{"minWidth":480,"value":"640/360"},{"minWidth":640,"value":"960/540"},{"minWidth":960,"value":"1920/1080"}]}},"web":{"baseUrl":"http://localhost:8080/site/hessenschau/assets_2.85.0/vendor/ardplayer/","isForcedAutoplay":true,"isForcedVideoView":true},"pluginData":{"trackingAti@all":{"site":"551103","config":{"getCollectDomainSSL":"logs1406.xiti.com","secure":true},"page":{"name":"muslim_fashion__mehr_als_ein_kopftuch__podcast:audio:audioPlay","level2":"4","chapter1":"Audio-Start","chapter2":"OnDemand","customVars":{"site":{"1":"podcast-episode-43976","2":"hr-nt:podcastEpisode","5":"202203230802"}}},"richMedia":{"mediaType":"audio","playerId":"4076","mediaLevel2":"4","mediaLabel":"muslim_fashion__mehr_als_ein_kopftuch__podcast:audioPlay","mediaTheme1":"OnDemand","duration":"3040","broadcastMode":"clip"}}}},"mediaCollection":{"streams":[{"kind":"main","isAudioOnly":true,"media":[{"url":"https://mp3podcasthr-a.akamaihd.net/mp3/podcast/derTag/derTag_20190320_81142988.mp3","mimeType":"audio/mp3","audios":[{"kind":"standard","languageCode":"de"}]}]}],"meta":{"durationSeconds":3040,"images":[{"kind":"preview","url":"https://picsum.photos/id/101/{size}"}],"title":"Muslim Fashion. Mehr als ein Kopftuch.","synopsis":"Wo immer die Ausstellung \"Contemporary Muslim Fashion“ ins Museum kommt, entfacht sie heftige Diskussionen. Nachdem die Schau in San Francisco für Furore sorgte, wird sie demnächst im Frankfurter Museum für Angewandte Kunst als erste Station in Europa gezeigt. Die \"Modest Fashion“, die dezente Mode, so das Schlagwort für die verhüllende, aber keineswegs unsichtbar machende Mode, spaltet das feministische Lager: Ist sie eine Momentaufnahme aktueller muslimischer Kleidungsstile aus aller Welt oder Werbung für die weibliche Verschleierung? In jedem Fall zeigt die Ausstellung, dass die Verhüllung des weiblichen Körpers und der Frisur nicht nur trist, sondern auch schön sein kann - und für manche Trägerinnen befreiend. Und sie ist durchaus politisch, diskutiert gesetzliche Kleiderordnungen und die Frage politischer Symbolik. Inzwischen wollen auch westliche Firmen von der Vielfalt muslimischer Mode profitieren. Sie haben die Konsumentinnen im Nahen Osten und Südostasien als kaufkräftige Klientel entdeckt. Dort ist ein riesiger Markt zu erschließen. Nicht selten wagen sie sich damit an die Grenzen religiöser und gesellschaftlicher Akzeptanz. Kann Mode solche Grenzen überwinden? "},"pluginData":{},"geoBlocked":false},"playerId":"4076","type":"audioOndemand","cssUrl":"./vendor/ardplayer/ardplayer-hr-6.3.11.79310671.css","jsUrl":"./vendor/ardplayer/ardplayer-hr-6.3.11.c442fe17.js","isAutoplay":true,"teaserSize":"50","realTeaserSize":"50"},"ardPlayerJsonConfig":{"playerConfig":{"generic":{"isAutoplay":true,"imageTemplateConfig":{"size":[{"minWidth":0,"value":"480/270"},{"minWidth":480,"value":"640/360"},{"minWidth":640,"value":"960/540"},{"minWidth":960,"value":"1920/1080"}]}},"web":{"baseUrl":"http://localhost:8080/site/hessenschau/assets_2.85.0/vendor/ardplayer/","isForcedAutoplay":true,"isForcedVideoView":true},"pluginData":{"trackingAti@all":{"site":"551103","config":{"getCollectDomainSSL":"logs1406.xiti.com","secure":true},"page":{"name":"muslim_fashion__mehr_als_ein_kopftuch__podcast:audio:audioPlay","level2":"4","chapter1":"Audio-Start","chapter2":"OnDemand","customVars":{"site":{"1":"podcast-episode-43976","2":"hr-nt:podcastEpisode","5":"202203230802"}}},"richMedia":{"mediaType":"audio","playerId":"4076","mediaLevel2":"4","mediaLabel":"muslim_fashion__mehr_als_ein_kopftuch__podcast:audioPlay","mediaTheme1":"OnDemand","duration":"3040","broadcastMode":"clip"}}}},"mediaCollection":{"streams":[{"kind":"main","isAudioOnly":true,"media":[{"url":"https://mp3podcasthr-a.akamaihd.net/mp3/podcast/derTag/derTag_20190320_81142988.mp3","mimeType":"audio/mp3","audios":[{"kind":"standard","languageCode":"de"}]}]}],"meta":{"durationSeconds":3040,"images":[{"kind":"preview","url":"https://picsum.photos/id/101/{size}"}],"title":"Muslim Fashion. Mehr als ein Kopftuch.","synopsis":"Wo immer die Ausstellung \"Contemporary Muslim Fashion“ ins Museum kommt, entfacht sie heftige Diskussionen. Nachdem die Schau in San Francisco für Furore sorgte, wird sie demnächst im Frankfurter Museum für Angewandte Kunst als erste Station in Europa gezeigt. Die \"Modest Fashion“, die dezente Mode, so das Schlagwort für die verhüllende, aber keineswegs unsichtbar machende Mode, spaltet das feministische Lager: Ist sie eine Momentaufnahme aktueller muslimischer Kleidungsstile aus aller Welt oder Werbung für die weibliche Verschleierung? In jedem Fall zeigt die Ausstellung, dass die Verhüllung des weiblichen Körpers und der Frisur nicht nur trist, sondern auch schön sein kann - und für manche Trägerinnen befreiend. Und sie ist durchaus politisch, diskutiert gesetzliche Kleiderordnungen und die Frage politischer Symbolik. Inzwischen wollen auch westliche Firmen von der Vielfalt muslimischer Mode profitieren. Sie haben die Konsumentinnen im Nahen Osten und Südostasien als kaufkräftige Klientel entdeckt. Dort ist ein riesiger Markt zu erschließen. Nicht selten wagen sie sich damit an die Grenzen religiöser und gesellschaftlicher Akzeptanz. Kann Mode solche Grenzen überwinden? "},"pluginData":{},"geoBlocked":false},"playerId":"4076","type":"audioOndemand","cssUrl":"./vendor/ardplayer/ardplayer-hr-6.3.11.79310671.css","jsUrl":"./vendor/ardplayer/ardplayer-hr-6.3.11.c442fe17.js","isAutoplay":true,"teaserSize":"50","realTeaserSize":"50"}}}},"link":{"url":"/teaser1","webviewUrl":"/teaser1#webview","isTargetBlank":false,"hasIcon":false,"iconName":"iconName","readMoreText":{"readMoreScreenreader":"Zum Artikel","readMore":"mehr","readMoreLong":"read More Long"}},"label":{"type":"podcast","loca":"label_podcast","byline":{"bylineSsi":"53:13 min","bylineText":""}}}],"label":{"type":"podcast","loca":"label_podcast","byline":{"bylineSsi":"07:42 min","bylineText":""}},"hideShortText":false,"shorttext":"Der Podcast für alle, die sich täglich in sozialen Netzwerken bewegen. Wir geben euch einen Einblick, was hinter den Kulissen einer Social-Media-Redaktion passiert, diskutieren Trends, Shitstorms und warum gewisse Posts funktionieren - und andere nicht.","teaseritem":{"copyrightWithLinks":"","responsiveImage":{"asPicture":false,"asImage":true,"fallback":"images/aufmacher-im-haifischbecken-100_v-1to1__medium.jpg","sources":[{"sizes":"300px","srcset":"images/aufmacher-im-haifischbecken-100_v-1to1__small.jpg 380w, images/aufmacher-im-haifischbecken-100_v-1to1__medium.jpg 480w, images/aufmacher-im-haifischbecken-100_v-1to1.jpg 720w, images/aufmacher-im-haifischbecken-100_v-1to1__large.jpg 960w"}]}},"podcastHoster":[{"podcastHosterUrl":"https://itunes.apple.com/de/podcast/hr-info-der-tag-in-hessen/id273944140?mt=2","podcastHosterName":"ITunes Podcast"},{"podcastHosterUrl":"https://podcast.hr.de/der_tag_in_hessen/podcast.xml","podcastHosterName":"RSS-Feed"},{"podcastHosterUrl":"https://podcasts.google.com/feed/aHR0cHM6Ly9wb2RjYXN0LmhyLmRlL2Rlcl90YWdfaW5faGVzc2VuL3BvZGNhc3QueG1s?hl=de","podcastHosterName":"Google Podcasts"},{"podcastHosterUrl":"https://www.ardaudiothek.de/sendung/der-tag-ein-thema-viele-perspektiven/470522/","podcastHosterName":"ARDAudiothekSuperlong"}],"audioUrl":"https://mp3podcasthr-a.akamaihd.net/mp3/podcast/hr2_audio/hr2_audio_20220914_95730396.mp3","podcastDownloadUrl":"https://mp3podcasthr-a.akamaihd.net/mp3/podcast/derTag/derTag_20190320_81142988.mp3","link":{"url":"/teaser1","webviewUrl":"/teaser1#webview","isTargetBlank":false,"hasIcon":false,"iconName":"iconName","readMoreText":{"readMoreScreenreader":"Zum Artikel","readMore":"mehr","readMoreLong":"read More Long"}}}}}}
@@ -0,0 +1,47 @@
1
+ import { fireEvent, hr$, listen } from 'hrQuery'
2
+ import $ from 'zepto-modules'
3
+
4
+ require('zepto-modules/callbacks')
5
+ require('zepto-modules/deferred')
6
+ const PodcastChannelRemainingEpisodesLoader = function (context) {
7
+ 'use strict'
8
+ const { options } = context,
9
+ { element: rootElement } = context,
10
+ dynLoadTrigSelector = options.dynLoadTrigSelector,
11
+ dynLoadTrigElement = hr$(dynLoadTrigSelector, rootElement)[0],
12
+ dynLoadReplaceSelector = options.dynLoadReplaceSelector,
13
+ url = options.url
14
+
15
+ const handleDynLoad = function (event) {
16
+ event.preventDefault()
17
+ dynLoadTrigElement.classList.add('-loading')
18
+ ajaxLoad(event.currentTarget, true)
19
+ }
20
+ const ajaxLoad = function (target, push, cache) {
21
+ $.ajax({
22
+ type: 'GET',
23
+ dataType: 'html',
24
+ url: url,
25
+ timeout: 90 * 1000,
26
+ cache: cache && true,
27
+ beforeSend: function () {
28
+ console.log('beforeSend')
29
+ },
30
+ })
31
+ .done(function (data, status, xhr) {
32
+ hr$(dynLoadReplaceSelector)[0].outerHTML = data
33
+
34
+ setTimeout(function () {
35
+ fireEvent('hr:podcastChannel:episodeReload')
36
+ dynLoadTrigElement.remove()
37
+ }, 1000)
38
+ })
39
+ .fail(function (data, status, xhr) {
40
+ dynLoadTrigElement.classList.remove('-loading')
41
+ console.log('fail')
42
+ })
43
+ }
44
+ listen('click', handleDynLoad, dynLoadTrigElement)
45
+ }
46
+
47
+ export default PodcastChannelRemainingEpisodesLoader
@@ -0,0 +1,40 @@
1
+ <article class="grid grid-page">
2
+ <div class="col-span-12 my-6 bg-highlight-1 rounded-tl-hr rounded-br-hr" >
3
+ {{> components/podcast/podcast_player _linkTitle="true" _isSinglePage=false _type="podcastEpisodePlayer"}}
4
+ </div>
5
+ <div class="order-1 col-span-8 px-5">
6
+ {{> components/podcast/components/podcast_player_shorttext }}
7
+ </div>
8
+ <div class="order-3 col-span-8">
9
+ {{> components/content/content_footer/content_footer
10
+ _author=this.audioAuthor
11
+ _showDate=this.hasDwellTime
12
+ _date=this.airdateDate
13
+ _copyright=this.copyright
14
+ _isArchiveContent=this.isArchiveContent
15
+ _posterCopyright="poster_copyright"}}
16
+ </div>
17
+
18
+ <aside class="order-4 col-full md:order-2 md:col-span-4"
19
+ aria-label='{{loca "appendix_title"}}'>
20
+ <div class="c-appendix">
21
+ {{#unless _webview}}
22
+ {{~#with this.backLinkUrl ~}}
23
+ {{~> components/base/link/backlink _addClass="appendix__backlink" ~}}
24
+ {{~/with~}}
25
+
26
+ {{~#with this.geotag ~}}
27
+ {{~> modules/geotag/geotag-list ~}}
28
+ {{~/with~}}
29
+
30
+ {{~#with this.topictags ~}}
31
+ {{~> modules/topictag/topictag-list ~}}
32
+ {{~/with~}}
33
+
34
+ {{~#with this.socialSharing ~}}
35
+ {{~> modules/socialmedia/shareit ~}}
36
+ {{~/with~}}
37
+ {{/unless}}
38
+ </div>
39
+ </aside>
40
+ </article>
@@ -1,5 +1,5 @@
1
1
  import { ArgsTable, Meta, Story, Canvas } from '@storybook/blocks'
2
- import * as PodcastPlayerEpisodeStories from './podcast_player_episode.stories'
2
+ import * as PodcastPlayerEpisodeStories from './podcast_episode_article.stories'
3
3
 
4
4
  <Meta of={PodcastPlayerEpisodeStories} />
5
5
 
@@ -13,7 +13,7 @@ import * as PodcastPlayerEpisodeStories from './podcast_player_episode.stories'
13
13
  Die Komponente wird in handlebars wie folgt eingebaut:
14
14
 
15
15
  ```html
16
- {{> components/article/components/podcast/podcast_player_episode }}
16
+ {{> components/article/components/podcast/podcast_episode_article }}
17
17
  ```
18
18
 
19
19
  <Canvas withToolbar>
@@ -1,10 +1,10 @@
1
- import podcast_player_episode from './podcast_player_episode.hbs'
1
+ import podcast_episode_article from './podcast_episode_article.hbs'
2
2
  import podcastPlayerEpisodeJson from './fixtures/podcast_player_episode.json'
3
3
 
4
4
  const Template = ({ ...args }) => {
5
5
  // You can either use a function to create DOM elements or use a plain html string!
6
6
  // return `<span>${topline}</span>`;
7
- return podcast_player_episode({ ...args })
7
+ return podcast_episode_article({ ...args })
8
8
  }
9
9
 
10
10
  export default {
@@ -0,0 +1 @@
1
+ {{> components/podcast/podcast_playlist_player-inline }}
@@ -0,0 +1,45 @@
1
+ <article class="grid grid-page">
2
+ <div class="grid grid-cols-12 col-full sm:col-main gap-x-6 gap-y-10 md:gap-y-14">
3
+ <div class="order-1 w-full col-span-12 my-6 md:col-span-9 bg-highlight-1 rounded-tl-hr rounded-br-hr" >
4
+ {{> components/podcast/podcast_playlist_player_all_episodes _isArticlePlayer=true}}
5
+ </div>
6
+ <aside class="grid order-2 col-span-3" aria-label='{{loca "appendix_title"}}'>
7
+ <div class="c-appendix">
8
+ {{#unless _webview}}
9
+ {{~#with this.backLinkUrl ~}}
10
+ {{~> base/link/backlink _addClass="appendix__backlink" ~}}
11
+ {{~/with~}}
12
+
13
+ {{~#with this.socialSharing ~}}
14
+ {{~> modules/socialmedia/shareit ~}}
15
+ {{~/with~}}
16
+ {{/unless}}
17
+ {{~#with this.programReference~}}
18
+ {{~#if this.hasReference~}}
19
+ <div class="appendix__entry">
20
+ {{> modules/program_reference/program_reference }}
21
+ </div>
22
+ {{~/if~}}
23
+ {{~/with~}}
24
+ {{~#with this.appendixLinks~}}
25
+
26
+ <div class="appendix__entry">
27
+ <div class="o-layout">
28
+ <h4 class="appendix__headline text__headline">{{../this.appendixLinksTitle}}</h4>
29
+ <ul class="list -appendix -vertical">
30
+ {{#each this}}
31
+ <li class="list__item -noIndent">
32
+ {{#decorator "base/link/link" _cssClasses="touchArea"}}
33
+ {{this.content.title}}{{~#if
34
+ this.hasIcon}}{{~> components/base/image/icon _icon=this.iconName _addClass="icon--primary icon--textRight" _iconmap="icons"~}}{{/if~}}
35
+ {{/decorator}}
36
+ </li>
37
+ {{/each}}
38
+ </ul>
39
+ </div>
40
+ </div>
41
+ {{~/with~}}
42
+ </div>
43
+ </aside>
44
+ </div>
45
+ </article>
@@ -0,0 +1,60 @@
1
+ <article class="grid grid-page">
2
+ <div class="grid grid-cols-12 col-full sm:col-main gap-x-6 gap-y-10 md:gap-y-14">
3
+ <div class="order-1 w-full col-span-12 my-6 md:col-span-9 bg-highlight-1 rounded-tl-hr rounded-br-hr" >
4
+ {{> components/podcast/podcast_playlist_player _isArticlePlayer=true}}
5
+
6
+ {{~#if this.remainingPlaylistItems}}
7
+ <div class="flex items-center justify-center pb-5 js-load"
8
+ data-hr-podcast-channel-remaining-episodes-loader='{"dynLoadTrigSelector":".js-load-remaining-items-button","dynLoadReplaceSelector":".js-placeholder-reload", "url":"{{this.reloadUrl}}"}'>
9
+ {{#> components/button/link_button _size="lg" _title="Weitere Episoden laden" _type="button" _css="js-load-remaining-items-button" _link=this.allEpisodeUrl }}
10
+ {{> components/button/components/button_label _label="Weitere Episoden laden"}}
11
+ {{> components/button/components/button_icon _icon="reload" _iconmap="icons"}}
12
+ {{/components/button/link_button}}
13
+ {{#*inline "htmlProperties"}}
14
+ data-hr-click-tracking='{"settings": [{"type": "uxAction", "clickLabel": "weitereEpisodenLaden:ButtonClick"}]}'
15
+ {{/inline}}
16
+ </div>
17
+ <div class="js-placeholder-reload"></div>
18
+ {{~/if~}}
19
+ </div>
20
+
21
+ <aside class="grid order-2 col-span-3 py-6" aria-label='{{loca "appendix_title"}}'>
22
+ <div class="c-appendix">
23
+ {{#unless _webview}}
24
+ {{~#with this.backLinkUrl ~}}
25
+ {{~> base/link/backlink _addClass="appendix__backlink" ~}}
26
+ {{~/with~}}
27
+
28
+ {{~#with this.socialSharing ~}}
29
+ {{~> modules/socialmedia/shareit ~}}
30
+ {{~/with~}}
31
+ {{/unless}}
32
+ {{~#with this.programReference~}}
33
+ {{~#if this.hasReference~}}
34
+ <div class="appendix__entry">
35
+ {{> modules/program_reference/program_reference }}
36
+ </div>
37
+ {{~/if~}}
38
+ {{~/with~}}
39
+ {{~#with this.appendixLinks~}}
40
+
41
+ <div class="appendix__entry">
42
+ <div class="o-layout">
43
+ <h4 class="appendix__headline text__headline">{{../this.appendixLinksTitle}}</h4>
44
+ <ul class="list -appendix -vertical">
45
+ {{#each this}}
46
+ <li class="list__item -noIndent">
47
+ {{#decorator "base/link/link" _cssClasses="touchArea"}}
48
+ {{this.content.title}}{{~#if
49
+ this.hasIcon}}{{~> components/base/image/icon _icon=this.iconName _addClass="icon--primary icon--textRight" _iconmap="icons"~}}{{/if~}}
50
+ {{/decorator}}
51
+ </li>
52
+ {{/each}}
53
+ </ul>
54
+ </div>
55
+ </div>
56
+ {{~/with~}}
57
+ </div>
58
+ </aside>
59
+ </div>
60
+ </article>
@@ -0,0 +1,21 @@
1
+ import { ArgsTable, Meta, Story, Canvas } from '@storybook/blocks'
2
+ import * as PodcastPlayerPlaylistStories from './podcast_playlist_article.stories'
3
+
4
+ <Meta of={PodcastPlayerPlaylistStories} />
5
+
6
+ # Podcast Player Playlist (Channel)
7
+
8
+ ## Beschreibung
9
+
10
+
11
+ ## Verwendung
12
+
13
+ Die Komponente wird in handlebars wie folgt eingebaut:
14
+
15
+ ```html
16
+ {{> components/article/components/podcast/podcast_playlist_article }}
17
+ ```
18
+
19
+ <Canvas withToolbar>
20
+ <Story of={PodcastPlayerPlaylistStories.Default} />
21
+ </Canvas>
@@ -0,0 +1,18 @@
1
+ import podcast_playlist_article from './podcast_playlist_article.hbs'
2
+ import podcastPlayerPlaylistJson from './fixtures/podcast_player_playlist.json'
3
+
4
+ const Template = ({ ...args }) => {
5
+ // You can either use a function to create DOM elements or use a plain html string!
6
+ // return `<span>${topline}</span>`;
7
+ return podcast_playlist_article({ ...args })
8
+ }
9
+
10
+ export default {
11
+ title: 'Komponenten/Artikel/Komponenten/Podcast-Player (Channel)',
12
+ }
13
+
14
+ export const Default = {
15
+ render: Template.bind({}),
16
+ name: 'default',
17
+ args: podcastPlayerPlaylistJson.teaserPodcastPlaylist.logicItem.includeModel,
18
+ }
@@ -1,7 +1,7 @@
1
1
  {{#unless _isSinglePage}}
2
2
  {{#unless this.hideShortText}}
3
3
  {{~#with this.shorttext}}
4
- <div class="col-span-12 px-5 text-sm md:text-base font-copy c-podcastEpisodePlayer__shortText">
4
+ <div class="col-span-12 text-sm md:text-base font-copy c-podcastEpisodePlayer__shortText">
5
5
  <span class="c-teaser__shorttext"> {{this}} </span>
6
6
  </div>
7
7
  {{/with~}}
@@ -0,0 +1,22 @@
1
+ {{~#with this.remainingPlaylistItems}}
2
+
3
+ <div class="flex flex-col col-span-12 gap-5 px-5"
4
+ x-data="playaudio()"
5
+ x-init="listenToGlobalStop()"
6
+ ax-load
7
+ x-ignore
8
+ ax-load-src={{resourceUrl "assets/js/vendor/podcast_player.alpine.js" }}>
9
+ {{#each this}}
10
+ <div class="flex pb-5 {{#if @first}}pt-5 border-t border-white {{/if}}{{#unless @last}}border-white border-b{{/unless}}">
11
+ {{> components/podcast/components/podcast_player_ui
12
+ _isPlaylistPlayer=true
13
+ _podcastDuration=this.duration
14
+ _title=this.title
15
+ _id=(nextRandom)
16
+ _first=@first
17
+ }}
18
+ </div>
19
+ {{/each}}
20
+ </div>
21
+
22
+ {{/with~}}
@@ -1,4 +1,4 @@
1
- <div class="flex col-span-12 pb-5 border-b border-white">
1
+ <div class="flex w-full py-5 border-b border-white">
2
2
  <div class="flex flex-col grow">
3
3
  {{!-- First Row --}}
4
4
  <div class="flex flex-row px-5 md:pl-5 {{#if ../_ordered}} pl-8 {{/if}} ">
@@ -18,25 +18,17 @@
18
18
  {{> components/podcast/components/podcast_title _title=this.title _teaserSize=this.realTeaserSize _addClass="" }}
19
19
  </div>
20
20
 
21
- {{!-- {{#switch this.realTeaserSize }}
22
- {{#case "100"}}
23
- {{> components/podcast/components/podcast_playlist_shorttext}}
24
- {{/case}}
25
- {{/switch}} --}}
26
-
27
21
  {{> components/podcast/components/podcast_playlist_shorttext}}
28
22
 
29
23
  {{!-- Abo-Dropdown --}}
30
24
  {{#if this.isSingleChannel}}
31
-
32
25
  {{> components/podcast/components/podcast_subscribe_button}}
33
-
34
26
  {{/if}}
35
27
  </div>
36
28
 
37
29
  {{!-- Podcast Image --}}
38
30
  <div class="flex flex-col pb-5">
39
- <div class="w-22 {{inline-switch this.realTeaserSize '["100","50"]' '["md:w-32 lg:w-42","md:w-22 lg:w-32", ""]'}}">
31
+ <div class="w-22 {{#if _isArticlePlayer}} md:w-32 lg:w-42{{else}}{{inline-switch this.realTeaserSize '["100","50"]' '["md:w-32 lg:w-42","md:w-22 lg:w-32", ""]'}}{{/if}} ">
40
32
  {{> components/base/image/responsive_image this.teaseritem
41
33
  _type="podcastEpisodePlayer"
42
34
  _variant="default"
@@ -47,21 +39,11 @@
47
39
  </div>
48
40
  </div>
49
41
  </div>
50
-
51
- {{!-- {{#switch this.realTeaserSize }}
52
- {{#case "50"}}
53
- <div class="flex flex-row w-full px-5 md:pl-5">
54
- {{> components/podcast/components/podcast_playlist_shorttext}}
55
- </div>
56
- {{/case}}
57
- {{/switch}} --}}
58
-
59
-
60
42
  </div>
61
43
  </div>
62
44
 
63
45
  {{!-- Player UI --}}
64
- <div class="flex flex-col col-span-12 gap-5 px-5"
46
+ <div class="flex flex-col col-span-12 gap-5 px-5 {{#if _isArticlePlayer }}pt-5 {{/if}} "
65
47
  x-data="playaudio()"
66
48
  x-init="listenToGlobalStop()"
67
49
  ax-load
@@ -0,0 +1,65 @@
1
+ <div class="flex w-full pb-5 border-b border-white">
2
+ <div class="flex flex-col grow">
3
+ {{!-- First Row --}}
4
+ <div class="flex flex-row px-5 md:pl-5 {{#if ../_ordered}} pl-8 {{/if}} ">
5
+ <div class="flex flex-col pr-5 grow">
6
+ <div class="flex max-h-6">
7
+ {{!-- Label / Airdate --}}
8
+ {{#with label}}
9
+ <span
10
+ class='sb-label mr-2 rounded px-1.5 pt-px inline-block tracking-wide text-white text-base leading-5.5 font-heading bg-labelMedia'>
11
+ {{ loca this.loca }}
12
+ </span>
13
+ {{/with}}
14
+ </div>
15
+
16
+ {{!-- Überschrift: --}}
17
+ <div class="flex pb-5 pr-2 md:pr-5">
18
+ {{> components/podcast/components/podcast_title _title=this.title _teaserSize=this.realTeaserSize _addClass="" }}
19
+ </div>
20
+
21
+ {{> components/podcast/components/podcast_playlist_shorttext}}
22
+
23
+ {{!-- Abo-Dropdown --}}
24
+ {{#if this.isSingleChannel}}
25
+ {{> components/podcast/components/podcast_subscribe_button}}
26
+ {{/if}}
27
+
28
+ </div>
29
+
30
+ {{!-- Podcast Image --}}
31
+ <div class="flex flex-col pb-5">
32
+ <div class="w-22 {{inline-switch this.realTeaserSize '["100","50"]' '["md:w-32 lg:w-42","md:w-22 lg:w-32", ""]'}}">
33
+ {{> components/base/image/responsive_image this.teaseritem
34
+ _type="podcastEpisodePlayer"
35
+ _variant="default"
36
+ _addClass="overflow-hidden"
37
+ _noDelay=this.dontLazyload
38
+ _addClassImg="w-full block"
39
+ }}
40
+ </div>
41
+ </div>
42
+ </div>
43
+
44
+ </div>
45
+ </div>
46
+
47
+ {{!-- Player UI --}}
48
+ <div class="flex flex-col col-span-12 gap-5 px-5"
49
+ x-data="playaudio()"
50
+ x-init="listenToGlobalStop()"
51
+ ax-load
52
+ x-ignore
53
+ ax-load-src={{resourceUrl "assets/js/vendor/podcast_player.alpine.js" }}>
54
+ {{#each this.allPlaylistItems}}
55
+ <div class="flex pb-5 {{#unless @last}}border-white border-b{{/unless}}">
56
+ {{> components/podcast/components/podcast_player_ui
57
+ _isPlaylistPlayer=true
58
+ _podcastDuration=this.duration
59
+ _title=this.title
60
+ _id=(nextRandom)
61
+ _first=@first
62
+ }}
63
+ </div>
64
+ {{/each}}
65
+ </div>
@@ -1,4 +1,4 @@
1
- <div class="grid gap-y-6 relative gap-x-4 flex-col pt-5 mx-5 sm:mx-0 md:pt-5 bg-highlight-1 rounded-tl-hr rounded-br-hr col-span-12{{inline-switch this.teaserSize '["50"]' '[" md:col-span-6",""]'}}" >
1
+ <div class="flex gap-y-6 relative gap-x-4 flex-col mx-5 sm:mx-0 bg-highlight-1 rounded-tl-hr rounded-br-hr col-span-12{{inline-switch this.teaserSize '["50"]' '[" md:col-span-6",""]'}}" >
2
2
  {{> components/podcast/podcast_playlist_player _linkTitle="true" _isSinglePage=false _type="podcastPlaylistPlayerTeaser" }}
3
3
  </div>
4
4
 
@@ -1,13 +0,0 @@
1
- <div class="w-full bg-highlight-1 rounded-tl-hr rounded-br-hr" >
2
- {{> components/podcast/podcast_player _linkTitle="true" _isSinglePage=false _type="podcastEpisodePlayer"}}
3
- </div>
4
- <div class="pt-5">
5
- {{> components/podcast/components/podcast_player_shorttext }}
6
- </div>
7
- {{> components/content/content_footer/content_footer
8
- _author=this.audioAuthor
9
- _showDate=this.hasDwellTime
10
- _date=this.airdateDate
11
- _copyright=this.copyright
12
- _isArchiveContent=this.isArchiveContent
13
- _posterCopyright="poster_copyright"}}
@@ -1,13 +0,0 @@
1
- <div class="w-full bg-highlight-1 rounded-tl-hr rounded-br-hr" >
2
- {{> components/podcast/podcast_player _linkTitle="true" _isSinglePage=false _type="podcastEpisodePlayer"}}
3
- </div>
4
- <div class="pt-5">
5
- {{> components/podcast/components/podcast_player_shorttext }}
6
- </div>
7
- {{> components/content/content_footer/content_footer
8
- _author=this.audioAuthor
9
- _showDate=this.hasDwellTime
10
- _date=this.airdateDate
11
- _copyright=this.copyright
12
- _isArchiveContent=this.isArchiveContent
13
- _posterCopyright="poster_copyright"}}
@@ -1,13 +0,0 @@
1
- <div class="w-full bg-highlight-1 rounded-tl-hr rounded-br-hr" >
2
- {{> components/podcast/podcast_player _linkTitle="true" _isSinglePage=false _type="podcastEpisodePlayer"}}
3
- </div>
4
- <div class="pt-5">
5
- {{> components/podcast/components/podcast_player_shorttext }}
6
- </div>
7
- {{> components/content/content_footer/content_footer
8
- _author=this.audioAuthor
9
- _showDate=this.hasDwellTime
10
- _date=this.airdateDate
11
- _copyright=this.copyright
12
- _isArchiveContent=this.isArchiveContent
13
- _posterCopyright="poster_copyright"}}