{"version":3,"sources":["webpack:///./src/views/BlogDetails.vue?7249","webpack:///./src/views/BlogDetails.vue","webpack:///./src/views/BlogDetails.vue?f82f","webpack:///./src/views/BlogDetails.vue?68d3","webpack:///./src/views/BlogDetails.vue?6b75","webpack:///./node_modules/client-website-ts-library/plugins/view/index.ts","webpack:///./src/views/BlogDetails.vue?361a"],"names":["render","_vm","this","_h","$createElement","_c","_self","attrs","blog","Title","Subtitle","staticClass","Images","length","Preview","Url","undefined","Paragraph1","Paragraph2","staticStyle","PDFUrl","_v","_s","PDFTitle","_e","staticRenderFns","BlogDetails","Mixins","AsyncView","constructor","mounted","blogId","$route","params","id","API","Blogs","Get","then","$emit","stripHtml","html","limit","tmp","document","createElement","innerHTML","text","innerText","substring","head","_this$blog","_this$blog2","_this$blog$Paragraph","_this$blog3","_this$blog4","_this$blog5","title","description","image","handleError","err","status","$router","push","path","query","next","__decorate","Component","components","component","ViewBase","Vue","prolistAnalyticsService","ServiceManager","ServiceType","Analytics","headService","Require","Head","updateAnalytics","evt","obj","getAnalyticsEvent","call","getAnalyticsData","AnalyticsPageView","name","triggerAnalyticsEvent","event","GetAll","forEach","adapter","Record","triggerCustomAnalyticsEvent","updateHead","result","bind","Promise","meta","Update","UpdateWithStatic","View","requestAnimationFrame","$on"],"mappings":"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","file":"js/chunk-639e1fd0.64bfc6b9.js","sourcesContent":["var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('Page',[(_vm.blog)?[_c('SiteMasthead',{attrs:{\"title\":_vm.blog.Title,\"subtitle\":_vm.blog.Subtitle,\"thin\":\"true\"}}),_c('ContentRow',[_c('ContentContainer',{staticClass:\"content-container--narrow\"},[_c('div',{staticClass:\"blog-details\"},[_c('LazyImage',{staticClass:\"blog__image\",attrs:{\"image\":_vm.blog.Images.length >= 1 ? _vm.blog.Images[0].Preview.Url : undefined}}),_c('RichText',{attrs:{\"content\":_vm.blog.Paragraph1}})],1)])],1),_c('ContentRow',[_c('ContentContainer',{staticClass:\"content-container--narrow\"},[_c('div',{staticClass:\"blog-details\"},[_c('LazyImage',{staticClass:\"blog__image\",attrs:{\"image\":_vm.blog.Images.length >= 2 ? _vm.blog.Images[1].Preview.Url : undefined}}),_c('RichText',{attrs:{\"content\":_vm.blog.Paragraph2}})],1)])],1),(_vm.blog.PDFUrl)?_c('ContentRow',[_c('ContentContainer',{staticClass:\"content-container--narrow\",staticStyle:{\"text-align\":\"center\"}},[_c('LinkButton',{attrs:{\"external\":true,\"href\":_vm.blog.PDFUrl}},[_vm._v(_vm._s(_vm.blog.PDFTitle ? _vm.blog.PDFTitle : 'Download'))])],1)],1):_vm._e()]:_vm._e()],2)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\r\nimport Button from '@/components/UI/Button.vue';\r\nimport { AsyncView, RouteMeta } from 'client-website-ts-library/plugins';\r\nimport { API } from 'client-website-ts-library/services';\r\nimport { Blog } from 'client-website-ts-library/types';\r\nimport { Component, Mixins } from 'vue-property-decorator';\r\n\r\n@Component({\r\n components: {\r\n },\r\n})\r\nexport default class BlogDetails extends Mixins(AsyncView) {\r\n private blog: Blog | null = null;\r\n\r\n mounted() {\r\n const blogId = this.$route.params.id;\r\n\r\n API.Blogs.Get(blogId).then((blog) => {\r\n this.blog = blog;\r\n this.$emit('updateView');\r\n });\r\n }\r\n\r\n stripHtml(html: string, limit: number): string {\r\n const tmp = document.createElement('div');\r\n\r\n tmp.innerHTML = html;\r\n\r\n const text = tmp.innerText;\r\n\r\n return text.length < (limit * 1.2) ? text : `${tmp.innerText.substring(0, limit)}...`;\r\n }\r\n\r\n public head(): RouteMeta {\r\n return {\r\n title: `${this.blog?.Title} - ${this.blog?.Subtitle}`,\r\n description: this.stripHtml(this.blog?.Paragraph1 ?? '', 100),\r\n image: this.blog?.Images.length ? this.blog?.Images[0].Preview.Url : undefined,\r\n };\r\n }\r\n\r\n handleError(err: Response) {\r\n if (err.status === 403) {\r\n this.$router.push({\r\n path: '/blogs',\r\n query: {\r\n next: `/blogs/${this.$route.params.id}`,\r\n },\r\n });\r\n }\r\n }\r\n}\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--14-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/ts-loader/index.js??ref--14-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./BlogDetails.vue?vue&type=script&lang=ts&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--14-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/ts-loader/index.js??ref--14-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./BlogDetails.vue?vue&type=script&lang=ts&\"","import { render, staticRenderFns } from \"./BlogDetails.vue?vue&type=template&id=66082af2&scoped=true&\"\nimport script from \"./BlogDetails.vue?vue&type=script&lang=ts&\"\nexport * from \"./BlogDetails.vue?vue&type=script&lang=ts&\"\nimport style0 from \"./BlogDetails.vue?vue&type=style&index=0&id=66082af2&scoped=true&lang=css&\"\nimport style1 from \"./BlogDetails.vue?vue&type=style&index=1&lang=css&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"66082af2\",\n null\n \n)\n\nexport default component.exports","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--6-oneOf-1-0!../../node_modules/css-loader/dist/cjs.js??ref--6-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--6-oneOf-1-2!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./BlogDetails.vue?vue&type=style&index=1&lang=css&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--6-oneOf-1-0!../../node_modules/css-loader/dist/cjs.js??ref--6-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--6-oneOf-1-2!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./BlogDetails.vue?vue&type=style&index=1&lang=css&\"","import Vue from \"vue\";\r\nimport { Component } from \"vue-property-decorator\";\r\nimport { AnalyticsEvent, AnalyticsEventObject, AnalyticsPageView, IAnalyticsAdapter, PROListAnalyticsAdapter } from \"../../services/Analytics\";\r\nimport { HeadService } from \"../../services/HeadService\";\r\nimport { ServiceManager, ServiceType } from \"../../services/ServiceManager\";\r\nimport { RouteMeta } from \"../meta\";\r\n\r\ninterface ViewBase {\r\n getAnalyticsEvent?(): AnalyticsEvent | null;\r\n getAnalyticsData?(): AnalyticsEventObject | null;\r\n head?(): RouteMeta | Promise | null;\r\n}\r\n\r\n@Component\r\nclass ViewBase extends Vue {\r\n protected prolistAnalyticsService = ServiceManager.Get(ServiceType.Analytics, 'PROListAnalyticsAdapter');\r\n protected headService = ServiceManager.Require(ServiceType.Head)!;\r\n\r\n public updateAnalytics() {\r\n let evt: AnalyticsEvent | null = null;\r\n let obj: AnalyticsEventObject | null = null;\r\n\r\n if (typeof this.getAnalyticsEvent !== 'undefined') {\r\n evt = this.getAnalyticsEvent.call(this);\r\n } else if(typeof this.getAnalyticsData !== 'undefined') {\r\n obj = this.getAnalyticsData.call(this);\r\n }\r\n\r\n if (evt === null) evt = new AnalyticsPageView(this.$route.path, this.$route.name || '', obj || undefined);\r\n\r\n this.triggerAnalyticsEvent(evt);\r\n }\r\n\r\n public triggerAnalyticsEvent(event: AnalyticsEvent) {\r\n ServiceManager.GetAll(ServiceType.Analytics).forEach((adapter) => {\r\n adapter.Record(event);\r\n });\r\n }\r\n\r\n public triggerCustomAnalyticsEvent(event: AnalyticsEvent) {\r\n if (this.prolistAnalyticsService !== null) this.prolistAnalyticsService.Record(event);\r\n }\r\n\r\n protected updateHead() {\r\n if ('head' in this) {\r\n const result = this.head!.bind(this)();\r\n\r\n if(result instanceof Promise) {\r\n result.then((meta: RouteMeta | null) => {\r\n this.headService.Update(meta);\r\n });\r\n } else {\r\n this.headService.Update(result as RouteMeta | null);\r\n }\r\n } else {\r\n this.headService.UpdateWithStatic(this.$route.path);\r\n }\r\n }\r\n}\r\n\r\n@Component\r\nclass View extends ViewBase {\r\n public mounted() {\r\n requestAnimationFrame(() => {\r\n this.updateHead();\r\n this.updateAnalytics();\r\n });\r\n }\r\n}\r\n\r\n@Component\r\nclass AsyncView extends ViewBase {\r\n public mounted() {\r\n this.$on('updateView', () => {\r\n requestAnimationFrame(() => {\r\n this.updateHead();\r\n this.updateAnalytics();\r\n });\r\n });\r\n }\r\n}\r\n\r\nexport {\r\n View,\r\n AsyncView\r\n}\r\n","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--6-oneOf-1-0!../../node_modules/css-loader/dist/cjs.js??ref--6-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--6-oneOf-1-2!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./BlogDetails.vue?vue&type=style&index=0&id=66082af2&scoped=true&lang=css&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--6-oneOf-1-0!../../node_modules/css-loader/dist/cjs.js??ref--6-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--6-oneOf-1-2!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./BlogDetails.vue?vue&type=style&index=0&id=66082af2&scoped=true&lang=css&\""],"sourceRoot":""}