{"version":3,"sources":["webpack:///../WCC.UI/App/components/attachments/box/box.html?10f0","webpack:///../WCC.UI/App/components/attachments/box/box.scss?9a3b","webpack:///../WCC.UI/App/components/attachments/box/box.ts","webpack:///../WCC.UI/App/webpack/runtime/htmlExposer.js","webpack:///../WCC.UI/App/components/attachments/box/box.scss","webpack:///../WCC.UI/App/components/attachments/box/box.html"],"names":["content","expose","__esModule","default","api","module","i","options","exports","locals","components","preload","AttachmentsBoxVM","constructor","config","info","id","_","uniqueId","getTemplate","attachment","isImage","isLink","isFile","isYouTube","isVimeo","getFileConfig","file","layout","theme","this","getLinkConfig","link","itemWidth","ko","flattenComputed","offset","outerOffset","attachments","images","filter","a","fileType","enums","AttachmentTypes","Image","value","videos","isVideoplayer","photoset","source","rowsCount","columnWidth","AttachmentsHelpers","isVideo","files","links","hasFilesOrLinks","pureComputed","length","applyBindingsToNode","element","__decorate","injectable","__param","inject","wccModules","componentConfig","componentInfo","system","SystemHelpers","html","getTemplatesAndResources","forEach","node","document","head","appendChild","___CSS_LOADER_API_IMPORT___","push"],"mappings":"uIAAA,UAAO,CACC,uGACA,wDAIC,KAJ4C,EAAF,SAAYA,EAASC,GAG5D,OADAA,EADAD,EAAUA,EAAQE,WAAaF,EAAQG,QAAUH,GAE1CA,GACV,4B,oECNT,IAAII,EAAM,EAAQ,gFACFJ,EAAU,EAAQ,kJAIC,iBAFvBA,EAAUA,EAAQE,WAAaF,EAAQG,QAAUH,KAG/CA,EAAU,CAAC,CAACK,EAAOC,EAAIN,EAAS,MAG9C,IAAIO,EAAU,CAEd,OAAiB,OACjB,WAAoB,GAEPH,EAAIJ,EAASO,GAI1BF,EAAOG,QAAUR,EAAQS,QAAU,I,2yBCAnCC,EAAWC,QAAQ,eAAgB,YAAa,WAAY,WAAY,qBAAsB,sBAW9F,IAAqBC,EAArB,MAWIC,YACgDC,EACVC,GADU,KAAAD,SAXhD,KAAAE,GAAKC,EAAEC,SAAS,mBA2ChB,KAAAC,YAAeC,GACPA,EAAWC,UACJ,wCACFD,EAAWE,SACT,uCACFF,EAAWG,SACT,uCACFH,EAAWI,YACT,0CACFJ,EAAWK,UACT,6CADN,EAIT,KAAAC,cAAiBC,IACN,CACHA,OACAC,OAAQ,MACRC,MAAOC,KAAKhB,OAAOe,QAI3B,KAAAE,cAAiBC,IACN,CACHA,OACAJ,OAAQ,MACRC,MAAOC,KAAKhB,OAAOe,QAtDvB,MAAMI,EAAYC,EAAGC,gBAAgBrB,EAAOmB,WACtCG,EAASF,EAAGC,gBAAgBrB,EAAOsB,QACnCC,EAAcH,EAAGC,gBAAgBrB,EAAOuB,aAExCC,EAAcJ,EAAGC,gBAAgBrB,EAAOwB,YAAa,IACrDC,EAASD,EAAYE,OAAiBC,GAAKA,EAAEC,aAAeC,EAAMC,gBAAgBC,MAAMC,OAC9FhB,KAAKiB,OAAST,EAAYE,OAAOC,GAAKA,EAAEO,iBAExClB,KAAKmB,SAAW,CACZC,OAAQX,EACRH,SACAC,cACAc,UAAW,EACXC,YAAanB,GAGjBH,KAAKiB,OAAST,EAAYE,OAAmDC,GAAKY,qBAAmB7B,UAAUiB,EAAEC,aAAeW,qBAAmB5B,QAAQgB,EAAEC,aAAeW,qBAAmBC,QAAQb,EAAEC,aACzMZ,KAAKyB,MAAQjB,EAAYE,OAAgBC,GAAKA,EAAElB,UAChDO,KAAK0B,MAAQlB,EAAYE,OAAgBC,GAAKA,EAAEnB,UAEhDQ,KAAK2B,gBAAkBvB,EAAGwB,aAAa,IAAM5B,KAAKyB,QAAQI,OAAS,GAAK7B,KAAK0B,QAAQG,OAAS,GAE9FzB,EAAG0B,oBAAoB7C,EAAK8C,QAAS,CACjC,IAAO,CACH,mBAAmB,OAvCdjD,EAAgBkD,EAAA,CADpCC,cAaQC,EAAA,EAAAC,YAAOC,IAAWC,kBAClBH,EAAA,EAAAC,YAAOC,IAAWE,iBAbNxD,gB,2RC7BrB,WAOC,KAPD,aACI,MAAMyD,EAAS,EAAQ,mCAAkBC,cAEzC,OAAO,SAAUC,GACbF,EAAOG,yBAAyBD,GAC3BE,SAAQ,SAAUC,GAAQC,SAASC,KAAKC,YAAYH,QAEhE,+B,kKCLDlE,EADkC,EAAQ,wDAChCsE,EAA4B,IAE9BC,KAAK,CAAC1E,EAAOC,EAAI,+DAAgE,KAEzFD,EAAOG,QAAUA,G,kHCHjBH,EAAOG,QAFI","file":"263.26ad06603748a01ab13e.js","sourcesContent":["define([\n \"!!../../../../node_modules/html-loader/dist/cjs.js??ref--26-1!./box.html\", \n \"!../../../webpack/runtime/htmlExposer.js\"], function (content, expose) {\n content = content.__esModule ? content.default : content;\n expose(content);\n return content;\n });","var api = require(\"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\");\n var content = require(\"!!../../../../node_modules/css-loader/dist/cjs.js!../../../../node_modules/sass-loader/dist/cjs.js!./box.scss\");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === 'string') {\n content = [[module.id, content, '']];\n }\n\nvar options = {};\n\noptions.insert = \"head\";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};","import { PhotosetConfig } from 'components/photoset/photoset.interfaces';\r\nimport { wccModules } from 'enums/wccModules';\r\nimport { AttachmentsHelpers } from 'helpers/attachments';\r\nimport { inject, injectable } from 'inversify';\r\nimport { Subscribable, SubscribableOrNullableValue } from 'knockout';\r\nimport WCCAttachment from 'models/attachments/attachment';\r\nimport WCCFile from 'models/attachments/file';\r\nimport WCCImage from 'models/attachments/image';\r\nimport WCCLink from 'models/attachments/link';\r\nimport WCCVideo from 'models/attachments/video';\r\nimport WCCVimeoVideo from 'models/attachments/vimeo';\r\nimport WCCYoutubeVideo from 'models/attachments/youtube';\r\nimport { WCCFileVMConfig } from '../file/file';\r\nimport { WCCAttachmentLayoutVMTheme } from '../layouts/base/base.interfaces';\r\nimport { WCCLinkVMConfig } from '../link/link';\r\nimport './box.html';\r\nimport './box.scss';\r\n\r\ncomponents.preload('photoset-new', 'wcc-image', 'wcc-link', 'wcc-file', 'attachment-caption', 'fancybox-image-new');\r\n\r\nexport interface AttachmentsBoxVMConfig {\r\n attachments?: SubscribableOrNullableValue>\r\n itemWidth?: SubscribableOrNullableValue\r\n offset?: SubscribableOrNullableValue\r\n outerOffset?: SubscribableOrNullableValue\r\n theme?: SubscribableOrNullableValue\r\n}\r\n\r\n@injectable()\r\nexport default class AttachmentsBoxVM {\r\n id = _.uniqueId('attachments-box');\r\n\r\n photoset: PhotosetConfig\r\n\r\n videos: Subscribable>\r\n files: Subscribable>\r\n links: Subscribable>\r\n\r\n hasFilesOrLinks: Subscribable\r\n\r\n constructor(\r\n @inject(wccModules.componentConfig) private config: AttachmentsBoxVMConfig,\r\n @inject(wccModules.componentInfo) info: ko.components.ComponentInfo\r\n ) {\r\n const itemWidth = ko.flattenComputed(config.itemWidth);\r\n const offset = ko.flattenComputed(config.offset);\r\n const outerOffset = ko.flattenComputed(config.outerOffset);\r\n\r\n const attachments = ko.flattenComputed(config.attachments, []);\r\n const images = attachments.filter(a => a.fileType() === enums.AttachmentTypes.Image.value);\r\n this.videos = attachments.filter(a => a.isVideoplayer());\r\n\r\n this.photoset = {\r\n source: images,\r\n offset,\r\n outerOffset,\r\n rowsCount: 0,\r\n columnWidth: itemWidth\r\n }\r\n\r\n this.videos = attachments.filter(a => AttachmentsHelpers.isYouTube(a.fileType()) || AttachmentsHelpers.isVimeo(a.fileType()) || AttachmentsHelpers.isVideo(a.fileType()));\r\n this.files = attachments.filter(a => a.isFile());\r\n this.links = attachments.filter(a => a.isLink());\r\n\r\n this.hasFilesOrLinks = ko.pureComputed(() => this.files().length > 0 || this.links().length > 0);\r\n\r\n ko.applyBindingsToNode(info.element, {\r\n 'css': {\r\n 'attachments-box': true\r\n }\r\n });\r\n }\r\n\r\n getTemplate = (attachment: WCCAttachment) => {\r\n if (attachment.isImage())\r\n return 'wcc-components-attachments-grid-image';\r\n else if (attachment.isLink())\r\n return 'wcc-components-attachments-grid-link';\r\n else if (attachment.isFile())\r\n return 'wcc-components-attachments-grid-file';\r\n else if (attachment.isYouTube())\r\n return 'wcc-components-attachments-grid-youtube';\r\n else if (attachment.isVimeo())\r\n return 'wcc-components-attachments-grid-vimeo';\r\n }\r\n\r\n getFileConfig = (file: WCCFile): WCCFileVMConfig => {\r\n return {\r\n file,\r\n layout: 'row',\r\n theme: this.config.theme\r\n }\r\n }\r\n\r\n getLinkConfig = (link: WCCLink): WCCLinkVMConfig => {\r\n return {\r\n link,\r\n layout: 'row',\r\n theme: this.config.theme\r\n }\r\n }\r\n}","define(function () {\r\n const system = require('helpers/system').SystemHelpers;\r\n\r\n return function (html) {\r\n system.getTemplatesAndResources(html)\r\n .forEach(function (node) { document.head.appendChild(node) });\r\n }\r\n});","// Imports\nvar ___CSS_LOADER_API_IMPORT___ = require(\"../../../../node_modules/css-loader/dist/runtime/api.js\");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.id, \".attachments-box{display:flex;flex-direction:column;gap:4px}\", \"\"]);\n// Exports\nmodule.exports = exports;\n","// Module\nvar code = \"\";\n// Exports\nmodule.exports = code;"],"sourceRoot":""}