diff --git a/pype/aport/static/build.js b/pype/aport/static/build.js
new file mode 100644
index 0000000000..180c65d29c
--- /dev/null
+++ b/pype/aport/static/build.js
@@ -0,0 +1,4862 @@
+var app = angular.module("Plugin", ["ui-rangeSlider", "ui.bootstrap"]);
+app.run(["$rootScope", "MainHelper", function($rootScope, MainHelper) {
+ MainHelper.init(BM_VIDEO, 15)
+}]), app.controller("ModalIntroController", function($scope, $uibModal, CreateOnFileSystemService, DestinationsService) {
+ $scope.items = [], $scope.obj = {
+ state: 1
+ }, $scope.$root.$on("intro requested", function(event) {
+ console.log("ModalIntroController event handler"), $scope.open("sm")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_INTRO_HTML,
+ backdrop: "static",
+ controller: ModalIntroInstanceCtrl,
+ windowClass: "modal-intro"
+ }).result.then(function() {
+ console.log("ModalIntroController OK"), CreateOnFileSystemService.createDestinationBaseFolder(), DestinationsService.saveItem()
+ }, function() {
+ console.log("ModalIntroController CANCELED")
+ })
+ }
+});
+
+var ModalIntroInstanceCtrl = function($scope, $uibModalInstance, BrowseDestinationService, AppModel) {
+ $scope.obj = {
+ state: 1,
+ title: "",
+ message: "",
+ labelLeft: [!1, "PREVIOUS"],
+ labelCenter: [!1, ""],
+ labelRight: [!0, "NEXT"],
+ stateImage: [!0, ""],
+ selectedFolder: AppModel.currentBaseFolder
+ }, $scope.onChange = function() {
+ switch (1 < $scope.obj.state && ($scope.obj.stateImage = [!0, STATE_IMG + $scope.obj.state + ".png"]), $scope.obj.state) {
+ case 1:
+ $scope.obj.stateName = "", $scope.obj.stateImage = [!1, ""], $scope.obj.labelLeft = [!1, "PREVIOUS"], $scope.obj.title = "Welcome!", $scope.obj.message = "Thanks for downloading the Pond5 Adobe Add-On. Click through this short tutorial to learn some of the basics.";
+ break;
+ case 2:
+ $scope.obj.labelLeft = [!0, "PREVIOUS"], $scope.obj.stateName = "search", $scope.obj.title = "", $scope.obj.message = "Start by searching our massive library of royalty-free video clips and easily add them to your working projects.";
+ break;
+ case 3:
+ $scope.obj.stateName = "filters", $scope.obj.labelLeft = [!0, "PREVIOUS"], $scope.obj.message = "Use the toolbar on the left to filter your search results, view your previews, and update your directory folder.";
+ break;
+ case 4:
+ $scope.obj.stateName = "collections", $scope.obj.message = "View and create new collections below. We've even added 50 free clips to get you started!";
+ break;
+ case 5:
+ $scope.obj.stateName = "login", $scope.obj.labelCenter = [!1, "SELECT"], $scope.obj.labelRight = [!0, "NEXT"], $scope.obj.message = "Log in to your Pond5 account here for easy checkout once you've found the perfect clips for your project.";
+ break;
+ case 6:
+ $scope.obj.stateName = "", $scope.obj.labelLeft = [!0, "PREVIOUS"], $scope.obj.labelCenter = [!0, "SELECT"], $scope.obj.labelRight = [!0, "FINISH"], $scope.obj.message = "Select your destination folder to get started. Pond5 media will be saved in this folder.", 0 < AppModel.currentBaseFolder.length && ($scope.obj.message = "Select your destination folder to get started. The default folder is " + AppModel.currentBaseFolder)
+ }
+ }, $scope.buttonLeftClicked = function() {
+ $scope.obj.state--, $scope.onChange(), getStateObject($scope.obj.stateName)
+ }, $scope.buttonCenterClicked = function() {
+ $scope.obj.selectedFolder = BrowseDestinationService.browse(), $scope.obj.message = "Your current destination folder is: " + $scope.obj.selectedFolder
+ }, $scope.buttonRightClicked = function() {
+ console.log("ModalIntroController buttonRightClicked"), $scope.obj.state < 6 ? ($scope.obj.state++, $scope.onChange(), getStateObject($scope.obj.stateName)) : (console.log("ModalIntroController buttonRightClicked", $scope.obj.selectedFolder), BrowseDestinationService.save($scope.obj.selectedFolder), $uibModalInstance.close())
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }, getStateObject = function(stateName) {
+ console.log("modalIntroController look for: ", stateName), INTRO_DATA.forEach(function(entry) {
+ var obj = {};
+ entry.stateName === stateName ? (console.log("modalIntroController found stateName: ", entry), obj.stateName = entry.stateName, obj.arrowClass = entry.arrowClass, obj.posX = entry.posX, obj.posY = entry.posY, console.log("modalIntroController found obj: ", obj)) : (obj.stateName = stateName, obj.arrowClass = ""), $scope.$root.$emit("intro asset requested", obj)
+ })
+ }, $scope.onChange()
+};
+PLUGIN_VERSION = "", HOST_NAME = "PPRO", THIRD_PARTY = "", MEDIA_TYPES = ["Footage", "Music", "SFX"], BUTTON_REPLACE_LABEL = "REPLACE WITH HI-RES CLIPS", BUTTON_REPLACE_TOOLTIP = "Replace lo-res with paid items", MODAL_REPLACE_HEADER = "Replace With Hi-Res Clips", MODAL_REPLACE_CONTENT = "The selected items below will be replaced by full resolution versions after you complete checkout. Items already in your account history will also be downloaded.", MODAL_REPLACE_RES_TITLE = "RESOLUTION", MODAL_INTRO_SEARCH = "Start by searching our massive library of royalty-free video clips and easily add them to your working projects.", MODAL_INTRO_COLLECTIONS = "View and create new collections below. We've even added 50 free clips to get you started!", MODAL_INTRO_LOGIN = "Log in to your Pond5 account here for easy checkout once you've found the perfect clips for your project.", INTRO_DATA = [{
+ state: 7,
+ stateName: "downloads",
+ arrowClass: ".intro-asset-arrow-left",
+ posY: ["top", "96px"],
+ posX: ["left", "60px"]
+}, {
+ state: 3,
+ stateName: "filters",
+ arrowClass: ".intro-asset-arrow-left",
+ posY: ["top", "60px"],
+ posX: ["left", "55px"]
+}, {
+ state: 9,
+ stateName: "destination",
+ arrowClass: ".intro-asset-arrow-left",
+ posY: ["bottom", "55px"],
+ posX: ["left", "60px"]
+}, {
+ state: 4,
+ stateName: "collections",
+ arrowClass: ".intro-asset-arrow-down",
+ posY: ["bottom", "140px"],
+ posX: ["left", "260px"]
+}, {
+ state: 2,
+ stateName: "search",
+ arrowClass: ".intro-asset-arrow-up",
+ posY: ["top", "60px"],
+ posX: ["left", "165px"]
+}, {
+ state: 5,
+ stateName: "login",
+ arrowClass: ".intro-asset-arrow-up",
+ posY: ["top", "60px"],
+ posX: ["right", "75px"]
+}], app.service("ReplaceService", ["$rootScope", "ReplaceModel", "Service", "ReplaceServiceShared", function($rootScope, ReplaceModel, Service, ReplaceServiceShared) {
+ var call = {
+ onClipFSCollected: function() {
+ call.getSequences()
+ },
+ getSequences: function() {
+ csInterface.evalScript("getSequences()", function(result) {
+ var sequences = JSON.parse(result).sequences;
+ console.log("\nReplaceService sequences NEW", sequences.length, sequences), ReplaceModel.setSequences(sequences)
+ })
+ },
+ getMedia: function() {
+ var obj = ReplaceModel.sequences;
+ csInterface.evalScript("getSequenceItems(" + JSON.stringify(obj) + ")", function(result) {
+ var clipsInSequences = JSON.parse(result).data;
+ ReplaceModel.clipsInSequences = clipsInSequences, console.log("\nReplaceService clipsInSequences", ReplaceModel.clipsInSequences), csInterface.evalScript("getProjectItems()", function(result) {
+ call.getMissingItemIDs()
+ })
+ })
+ },
+ getClipsInSelectedSequences: function() {
+ for (var clipsInSequences = ReplaceModel.clipsInSequences, clipsInSelectedSequences = [], s = 0; s < ReplaceModel.sequences.length; s++)
+ for (var j = 0; j < clipsInSequences.length; j++)
+ if (ReplaceModel.sequences[s].sequenceID === clipsInSequences[j].sequenceID && ReplaceModel.sequences[s].checked)
+ for (var k = 0; k < clipsInSequences[j].clipNames.length; k++) clipsInSelectedSequences.push(clipsInSequences[j].clipNames[k]);
+ return clipsInSelectedSequences
+ },
+ getMissingItemIDs: function() {
+ var clipsInSelectedSequences = call.getClipsInSelectedSequences();
+ clipsInSelectedSequences = ReplaceServiceShared.removeDuplicates(clipsInSelectedSequences), console.log("\nReplaceService clipsInSelectedSequences after removing duplicates: ", clipsInSelectedSequences);
+ var previewNamesonFS = ReplaceServiceShared.getPreviewsOnFSNames();
+ clipsInSelectedSequences = ReplaceServiceShared.filterNonP5Clips(clipsInSelectedSequences, previewNamesonFS), console.log("\nReplaceService after filterNonP5Clips", clipsInSelectedSequences);
+ var previewIDs = ReplaceServiceShared.getPreviewsIDs(clipsInSelectedSequences);
+ console.log("\nReplaceService previewIDs: " + previewIDs), ReplaceServiceShared.setReplaceProp(previewIDs), console.log("\nReplaceService after set replace: " + ReplaceModel.hiresOnFS);
+ var hiresIDs = ReplaceServiceShared.getHiresIDsonFS();
+ console.log("\nReplaceService hiresIDs: " + hiresIDs);
+ var missingItemIDs = _(previewIDs).difference(hiresIDs),
+ missingIDsToString = missingItemIDs.join(",");
+ 0 < missingItemIDs.length ? Service.getMissingItems(missingIDsToString) : 0 < hiresIDs.length ? call.onPurchasedAndDownloaded() : 0 === clipsInSelectedSequences.length && (ReplaceModel.setState(DEFAULT), $rootScope.$emit("modal simple requested", ["", "There are are currently no Pond5 previews in the sequence(s) you've selected."]))
+ },
+ onPurchasedAndDownloaded: function() {
+ var hasReplaceCandidates = !1;
+ if (ReplaceModel.hiresOnFS.forEach(function(entry) {
+ entry.replace && (hasReplaceCandidates = !0)
+ }), !hasReplaceCandidates) return $rootScope.$emit("modal simple requested", ["", "Replacing previews by hi-res clips has been canceled"]), void ReplaceModel.setState(DEFAULT);
+ var obj = {
+ hiresOnFS: ReplaceModel.hiresOnFS
+ };
+ csInterface.evalScript("replaceClips(" + JSON.stringify(obj) + ")", function(result) {
+ $rootScope.$emit("modal simple requested", ["", "Your previews have been successfully replaced by your purchased clips. Right-click the clips and choose Scale to Frame Size to scale them correctly."]), ReplaceModel.setState(DEFAULT)
+ })
+ }
+ };
+ return call
+}]), app.controller("ModalAddDestinationController", function($scope, $uibModal, UserModel, AppModel, CreateOnFileSystemService, DestinationsService) {
+ $scope.obj = {}, $scope.$root.$on("modal add destination requested", function() {
+ console.log("ModalAddDestinationController event handler", UserModel.getFirstTimeUser()), $scope.obj.title = "Add a destination folder", $scope.obj.content = "Please select a new folder to store your previews and purchased items.", $scope.obj.okButtonLabel = "APPLY", $scope.obj.selectedFolderPrefix = "Current folder: ", $scope.obj.selectedFolder = AppModel.currentBaseFolder, $scope.open("lg")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_ADD_DESTINATION_HTML,
+ controller: ModalAddDestinatonInstanceCtrl,
+ size: size,
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ }
+ }).result.then(function() {
+ console.log("ModalAddDestinationController OK", AppModel.currentBaseFolder), $scope.onClicked()
+ }, function() {
+ console.log("ModalAddDestinationController CANCEL", AppModel.currentBaseFolder), $scope.onClicked()
+ })
+ }, $scope.onClicked = function() {
+ console.log("ModalAddDestinationController onClicked"), UserModel.getFirstTimeUser() && $scope.$root.$emit("modal freebies"), CreateOnFileSystemService.createDestinationBaseFolder(), DestinationsService.saveItem()
+ }
+});
+var ModalAddDestinatonInstanceCtrl = function($scope, $uibModalInstance, obj, BrowseDestinationService) {
+ $scope.obj = {}, $scope.obj.showTitle = obj.showTitle, $scope.obj.title = obj.title, $scope.obj.content = obj.content, $scope.obj.selectedFolder = obj.selectedFolder, $scope.obj.selectedFolderPrefix = obj.selectedFolderPrefix, $scope.obj.okButtonLabel = obj.okButtonLabel, $scope.browse = function() {
+ console.log("ModalAddDestinatonInstanceCtrl browse"), $scope.obj.selectedFolder = BrowseDestinationService.browse()
+ }, $scope.ok = function() {
+ BrowseDestinationService.save($scope.obj.selectedFolder), $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalSelectSequencesController", function($scope, $uibModal, ReplaceModel, ReplaceService) {
+ $scope.items = [], $scope.$root.$on("modal select sequences", function(event, data) {
+ $scope.items = data, $scope.open("lg")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_SELECT_SEQUENCES_HTML,
+ controller: ModalSelectSequencesInstanceCtrl,
+ size: size,
+ resolve: {
+ items: function() {
+ return $scope.items
+ }
+ }
+ }).result.then(function() {
+ console.log("ModalSelectSequencesController OK: ", $scope.items);
+ for (var i = 0; i < $scope.items.length; i++) $scope.items[i].selected && (ReplaceModel.sequences[i].checked = !0);
+ ReplaceService.getMedia()
+ }, function() {
+ ReplaceModel.setState(DEFAULT)
+ })
+ }
+});
+var ModalSelectSequencesInstanceCtrl = function($scope, $uibModalInstance, items) {
+ $scope.items = items, $scope.obj = {
+ showWarning: !1
+ }, $scope.ok = function() {
+ for (var checked = !1, i = 0; i < $scope.items.length; i++) $scope.items[i].selected && (checked = !0);
+ checked ? $uibModalInstance.close() : $scope.obj.showWarning = !0
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.factory("MainHelper", ["$rootScope", "AppModel", "StartUpService", "SearchModel", function($rootScope, AppModel, StartUpService, SearchModel) {
+ var result = {
+ init: function(mediaType, sumOfBitmasks) {
+ csInterface = new CSInterface, csInterface.addEventListener("LogEvent", function(evt) {
+ console.log("JSX : " + evt.data)
+ });
+ var rootFolderPath = csInterface.getSystemPath(SystemPath.EXTENSION);
+ AppModel.rootFolderPath = rootFolderPath, fs = require("fs"), os = require("os"), path = require("path"), url = require("url"), https = require("https"), xml2js = require(rootFolderPath + "/node_modules/xml2js/lib/xml2js.js"), walk = require(rootFolderPath + "/node_modules/walk/lib/walk.js"), junk = require(rootFolderPath + "/node_modules/junk/index.js"), rimraf = require(rootFolderPath + "/node_modules/rimraf/rimraf.js"), opn = require(rootFolderPath + "/node_modules/opn/index.js"), DecompressZip = require(rootFolderPath + "/node_modules/decompress-zip/lib/decompress-zip.js"), $("#logo").click(function() {
+ location.reload()
+ }), result.readManifestXML(), SearchModel.sumOfBitmasks = sumOfBitmasks, $rootScope.$emit("media filter change", mediaType), setTimeout(function() {
+ AppModel.setEnv()
+ }, 2e3)
+ },
+ readManifestXML: function() {
+ var file = AppModel.rootFolderPath + "/CSXS/manifest.xml";
+ fs.readFile(file, "utf8", function(err, data) {
+ if (err) throw err;
+ result.parseXML(data)
+ })
+ },
+ parseXML: function(xml) {
+ var parser = new xml2js.Parser;
+ parser.addListener("end", function(res) {
+ PLUGIN_VERSION = res.ExtensionManifest.$.ExtensionBundleVersion, console.log("mainHelper parsed manifest xml, version:", PLUGIN_VERSION), result.loadJSX()
+ }), parser.parseString(xml)
+ },
+ loadJSX: function(fileName) {
+ var jsxPath = AppModel.rootFolderPath + "/jsx/json2.js";
+ console.log("mainHelper loadJSX:", jsxPath), csInterface.evalScript('$.evalFile("' + jsxPath + '")', function(result) {})
+ }
+ };
+ return result
+}]), app.service("BrowseDestinationService", ["AppModel", function(AppModel) {
+ this.browse = function() {
+ var result = window.cep.fs.showOpenDialog(!1, !0, "Select a folder for your previews and hi-res downloads.", ""),
+ selectedFolder = AppModel.currentBaseFolder;
+ return console.log("BrowseDestinationService folder chosen, result.err: ", result.err), 0 == result.err ? (console.log("BrowseDestinationService folder chosen: ", result.data[0]), result.data[0] && (selectedFolder = result.data[0])) : selectedFolder = "This folder cannot be selected. Please choose another folder.", console.log("BrowseDestinationService return folder: ", selectedFolder), selectedFolder
+ }, this.save = function(selectedFolder) {
+ console.log("BrowseDestinationService save", AppModel.getOS(), "win" === AppModel.getOS()), "win" === AppModel.getOS() ? AppModel.currentBaseFolder = selectedFolder.replace(/\//g, "\\") : AppModel.currentBaseFolder = selectedFolder
+ }
+}]), app.service("CreateFileCompleteService", ["ImportedPreviewsService", "DestinationsService", "UserService", function(ImportedPreviewsService, DestinationsService, UserService) {
+ return {
+ onFileReady: function(file) {
+ -1 != file.indexOf("imported_previews.xml") && ImportedPreviewsService.readXML(), -1 != file.indexOf("destinations.xml") && DestinationsService.readXML(), -1 != file.indexOf("user.xml") && UserService.readXML()
+ }
+ }
+}]), app.factory("DestinationsService", ["$rootScope", "AppModel", "UserModel", function($rootScope, AppModel, UserModel) {
+ var result = {
+ xmlVersion: "",
+ readXML: function() {
+ result.file = AppModel.getDestinationsXML(), console.log("DestinationsService file: ", result.file), fs.readFile(result.file, "utf8", function(err, data) {
+ if (err) throw err;
+ result.xml = data, console.log("DestinationsService, xml:", result.xml), result.parseXML()
+ })
+ },
+ saveItem: function() {
+ var node = ' ';
+ result.xml = result.xml.insert(result.xml.indexOf("destinations") + 13, node), result.writeToDisk()
+ },
+ deleteItem: function() {},
+ parseXML: function() {
+ var parser = new xml2js.Parser;
+ parser.addListener("end", function(res) {
+ var i;
+ result.parsedXML = res, AppModel.baseFolders = [], UserModel.setFirstTimeUser(!1), res.root.$[HOST_NAME] ? result.xmlVersion = res.root.$[HOST_NAME] : res.root.$.version ? result.xmlVersion = res.root.$.version : res.root.$.PPRO && (result.xmlVersion = res.root.$.PPRO), UserModel.setUID(res.root.$.id), PLUGIN_VERSION != result.xmlVersion && (console.log("DestinationsService other or no version number in xml, first time user: ", result.xmlVersion), UserModel.setFirstTimeUser(!0));
+ var destinations = res.root.destinations[0].destination;
+ if (console.log("DestinationsService destinations: ", destinations), destinations) {
+ for (i = 0; i < destinations.length; i++) - 1 == AppModel.baseFolders.indexOf(destinations[i].$.destination) && fs.existsSync(destinations[i].$.destination + path.sep + "pond5") && AppModel.baseFolders.push(destinations[i].$.destination);
+ fs.stat(AppModel.baseFolders[0] + path.sep + "pond5", function(err, stats) {
+ err ? setTimeout(function() {
+ $rootScope.$emit("modal add destination requested")
+ }, 3e3) : AppModel.currentBaseFolder = AppModel.baseFolders[0]
+ }), console.log("DestinationsService AppModel.baseFolders : ", AppModel.baseFolders), console.log("DestinationsService currentBaseFolder : ", AppModel.currentBaseFolder)
+ }
+ if (UserModel.getFirstTimeUser()) {
+ var newVersion = HOST_NAME + '="' + PLUGIN_VERSION + '"';
+ result.parsedXML.root.$[HOST_NAME] ? result.xml = result.xml.replace(HOST_NAME + '="' + result.xmlVersion + '"', newVersion) : result.parsedXML.root.$.version && "PPRO" === HOST_NAME ? result.xml = result.xml.replace('version="' + result.xmlVersion + '"', newVersion) : result.parsedXML.root.$.version && "PPRO" != HOST_NAME ? result.xml = result.xml.replace('version="' + result.xmlVersion + '"', 'version="' + result.xmlVersion + '" ' + newVersion) : result.parsedXML.root.$.PPRO && !result.parsedXML.root.$[HOST_NAME] && (result.xml = result.xml.replace('PPRO="' + result.xmlVersion + '"', 'PPRO="' + result.xmlVersion + '" ' + newVersion)), console.log("DestinationsService result.xml replaced: ", result.xml), console.log("DestinationsService getFirstTimeUser is true, show intro"), setTimeout(function() {
+ $rootScope.$emit("intro requested")
+ }, 3e3)
+ }
+ }), parser.parseString(result.xml)
+ },
+ writeToDisk: function() {
+ fs.writeFile(result.file, result.xml, function(err) {
+ if (err) throw err;
+ result.readXML()
+ })
+ }
+ };
+ return result
+}]), app.service("ImportService", ["$rootScope", function($rootScope) {
+ this.importClips = function(items) {
+ var i, importPaths = [];
+ for (i = 0; i < items.length; i++) console.log("ImportService item.canceled:", items[i].canceled), items[i].canceled || items[i].imported || (items[i].imported = !0, importPaths.push(items[i].downloadDestination + items[i].fileName));
+ console.log("ImportService importPath:", importPaths);
+ var obj = {
+ paths: importPaths
+ };
+ csInterface.evalScript("importClips(" + JSON.stringify(obj) + ")", function(result) {
+ console.log("ImportService result: ", result), $rootScope.$emit("on importing bin complete")
+ })
+ }
+}]), app.service("OpenURLService", [function() {
+ this.openURL = function(url) {
+ csInterface.openURLInDefaultBrowser(url)
+ }
+}]), app.controller("AdvancedSearchController", function($scope, ViewStateModel, SearchModel, ViewStateService) {
+ $scope.obj = {
+ show: !1,
+ fpsItems: [{
+ fps: "23.98"
+ }, {
+ fps: "24"
+ }, {
+ fps: "25"
+ }, {
+ fps: "29.97"
+ }, {
+ fps: "30"
+ }, {
+ fps: "60"
+ }, {
+ fps: "60+"
+ }],
+ resItems: [{
+ res: "4K+",
+ param: "8K"
+ }, {
+ res: "4K",
+ param: "4K"
+ }, {
+ res: "2K",
+ param: "2K"
+ }, {
+ res: "HD (1080)",
+ param: "HD1080"
+ }, {
+ res: "HD (720)",
+ param: "HD720"
+ }, {
+ res: "SD",
+ param: "SD"
+ }, {
+ res: "Web",
+ param: "WEB"
+ }],
+ showCbFilters: !0,
+ _minPrice: 0,
+ _maxPrice: 500,
+ minPrice: function(newValue) {
+ return arguments.length ? $scope.obj._minPrice = newValue : $scope.obj._minPrice
+ },
+ maxPrice: function(newValue) {
+ return 500 == $scope.obj._maxPrice ? $scope.obj.maxPriceValue = "$500+" : $scope.obj.maxPriceValue = "$" + $scope.obj._maxPrice, arguments.length ? $scope.obj._maxPrice = newValue : $scope.obj._maxPrice
+ },
+ _minTime: 0,
+ _maxTime: 120,
+ minTime: function(newValue) {
+ return arguments.length ? $scope.obj._minTime = newValue : $scope.obj._minTime
+ },
+ maxTime: function(newValue) {
+ return 120 == $scope.obj._maxTime ? $scope.obj.showTimePlusSign = !0 : $scope.obj.showTimePlusSign = !1, arguments.length ? $scope.obj._maxTime = newValue : $scope.obj._maxTime
+ }
+ }, $scope.oneAtATime = !0, $scope.reset = function() {
+ for ($scope.obj._minPrice = 0, $scope.obj._maxPrice = 500, $scope.obj._minTime = 0, $scope.obj._maxTime = 120, SearchModel.fps = "", SearchModel.fpsgt = "", SearchModel.res = "", SearchModel.pricegt = "", SearchModel.pricelt = "", SearchModel.durationgt = "", SearchModel.durationlt = "", i = 0; i < $scope.obj.fpsItems.length; i++) $scope.obj.fpsItems[i].checked = !1;
+ for (i = 0; i < $scope.obj.resItems.length; i++) $scope.obj.resItems[i].checked = !1
+ }, $scope.reset(), $scope.$root.$on("filters button clicked", function(event, state) {
+ $scope.obj.show = state
+ }), $scope.$root.$on("media filter change", function(event, data) {
+ data == BM_VIDEO || data == BM_PUBLIC_DOMAIN ? $scope.obj.showCbFilters = !0 : ($scope.obj.showCbFilters = !1, $scope.reset()), data == BM_AFTER_EFFECTS ? $scope.obj.showDuration = !1 : $scope.obj.showDuration = !0
+ }), $scope.change = function() {
+ var fpsgt, fps = " fps",
+ res = " resolutions";
+ for (i = 0; i < $scope.obj.fpsItems.length - 1; i++) $scope.obj.fpsItems[i].checked && (fps += ":" + $scope.obj.fpsItems[i].fps);
+ for (fpsgt = $scope.obj.fpsItems[6].checked ? " fpsgt:60" : "", i = 0; i < $scope.obj.resItems.length; i++) $scope.obj.resItems[i].checked && (res += ":" + $scope.obj.resItems[i].param);
+ fps.length <= 5 ? fps = "" : fpsgt = "", res.length <= 13 && (res = ""), SearchModel.fps = fps, SearchModel.fpsgt = fpsgt, SearchModel.res = res, SearchModel.resultType = "replace", SearchModel.page = 0, ViewStateService.viewRequested("search")
+ }, $scope.onHideFiltersClicked = function() {
+ $scope.obj.show = !1, $scope.$root.$emit("filters button clicked", !1)
+ }, $scope.onResetFiltersClicked = function() {
+ $scope.reset(), $scope.change()
+ }, $scope.viewState = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewState, function() {
+ "cart" !== ViewStateModel.getState() && "downloads" !== ViewStateModel.getState() || ($scope.obj.show = !1)
+ }, !0), window.addEventListener("rangeSliderOff", function(e) {
+ "" == $scope.obj._minPrice ? SearchModel.pricegt = "" : SearchModel.pricegt = " pricegt:" + $scope.obj._minPrice, "500" == $scope.obj._maxPrice ? SearchModel.pricelt = "" : SearchModel.pricelt = " pricelt:" + $scope.obj._maxPrice, "" == $scope.obj._minTime ? SearchModel.durationgt = "" : SearchModel.durationgt = " durationgt:" + $scope.obj._minTime, "120" == $scope.obj._maxTime ? SearchModel.durationlt = "" : SearchModel.durationlt = " durationlt:" + $scope.obj._maxTime, $scope.change()
+ }, !1)
+}), app.controller("AlertController", function($scope) {
+ $scope.alerts = [], $scope.addAlert = function() {
+ console.log("AlertController add"), $scope.alerts.push({
+ msg: "Another alert!"
+ })
+ }, $scope.closeAlert = function(index) {
+ $scope.alerts.splice(index, 1)
+ }
+}), app.controller("BinsController", function($scope, BinsModel, Service, LoginModel, ViewStateModel, ViewStateService) {
+ $scope.obj = {}, $scope.obj.showImportAll = !1, $scope.obj.showSelect = !1, $scope.obj.direction = "dropup", $scope.loginModel = function() {
+ return LoginModel.loggedIn
+ }, $scope.viewStateModel = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.loginModel, function() {
+ LoginModel.loggedIn ? $scope.obj.showSelect = !0 : $scope.obj.showSelect = !1
+ }), $scope.$watch($scope.viewStateModel, function() {
+ "bins" != ViewStateModel.getState() && ($scope.obj.selectedNameFormatted = "Collection")
+ }), $scope.$root.$on("onBins", function(event) {
+ $scope.bins = BinsModel.bins
+ }), $scope.onClick = function() {
+ console.log("BinsController onClick"), $scope.$root.$emit("select clicked")
+ }, $scope.onChange = function(bin) {
+ console.log("onChange, bin: ", bin), 14 < bin.name.length ? $scope.obj.selectedNameFormatted = bin.name.substr(0, 14) + "..." : $scope.obj.selectedNameFormatted = bin.name, $scope.obj.open = !1, $scope.selected = bin, $scope.selected && (BinsModel.selectedBin = bin, $scope.$root.$emit("bin selected", bin.name), ViewStateService.viewRequested("bins"))
+ }, $scope.onDelete = function(bin) {
+ console.log("onDelete, bin: ", bin)
+ }, $scope.toggled = function(open) {
+ $scope.obj.direction = open ? "down" : "dropup"
+ }, $scope.onAddClicked = function() {
+ console.log("onAddClicked"), $scope.$root.$emit("modal add collection requested")
+ }, $scope.onRemoveClicked = function() {
+ console.log("onRemoveClicked"), $scope.$root.$emit("modal remove collection requested")
+ }
+}), app.controller("CartController", function($scope, Service, ViewStateService, CartModel, LoginModel, AnalyticsService) {
+ $scope.obj = {
+ numberOfItem: 0,
+ clearCartIcon: CLEAR_CART_TRASH_IMG,
+ imageUrl: CART_BUTTON_IMG,
+ cartButtonStyle: "button-cart-logged-out"
+ }, $scope.cartModel = function() {
+ return CartModel.cartVO
+ }, $scope.$watch($scope.cartModel, function() {
+ CartModel.cartVO.items && ($scope.obj.numberOfItems = CartModel.cartVO.items.length)
+ }), $scope.loginModel = function() {
+ return LoginModel
+ }, $scope.$watch($scope.loginModel, function() {
+ LoginModel.getLoggedIn() ? $scope.obj.cartButtonStyle = "button-cart-logged-in" : ($scope.obj.cartButtonStyle = "button-cart-logged-out", $scope.obj.numberOfItems = "")
+ }, !0), $scope.onCartButtonClicked = function() {
+ ViewStateService.viewRequested("cart");
+ var ga = {
+ ec: "cart"
+ };
+ AnalyticsService.sendData(ga)
+ }
+}), app.controller("CheckOutController", function($scope, Service, ViewStateModel, CheckOutService, CartModel) {
+ $scope.obj = {
+ show: !1,
+ disabled: !0,
+ info: "",
+ showInfo: !1,
+ subTotalText: "",
+ showVAT: !1,
+ lineStyle: "",
+ totalStyle: "",
+ remainingStyle: "",
+ cartInfoStyle: ""
+ }, $scope.CartModel = function() {
+ return CartModel.cartVO
+ }, $scope.$watch($scope.CartModel, function() {
+ CartModel.cartVO.items && 0 < CartModel.cartVO.items.length ? $scope.obj.disabled = !1 : $scope.obj.disabled = !0
+ }, !0), $scope.$root.$on("checkout complete", function() {
+ $scope.obj.disabled = !1
+ }), $scope.$root.$on("billing info canceled", function() {
+ $scope.obj.disabled = !1
+ }), $scope.viewState = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewState, function() {
+ "cart" === ViewStateModel.getState() ? $scope.obj.show = !0 : $scope.obj.show = !1
+ }, !0), $scope.onClick = function() {
+ $scope.obj.disabled = !0, $scope.$root.$emit("on modal choose billing info requested"), $scope.onOut()
+ }, $scope.onOver = function() {
+ $scope.obj.showInfo = !0, $scope.showData()
+ }, $scope.onOut = function() {
+ $scope.obj.showInfo = !1
+ }, $scope.showData = function() {
+ var data = CartModel.getCartTotal();
+ data && ($scope.obj.subTotalText = data.subtotals.beforeDiscounts, data.vatData.display ? $scope.obj.showVAT = !0 : $scope.obj.showVAT = !1, $scope.obj.showVAT ? ($scope.obj.cartInfoStyle = "cart-info-vat", $scope.obj.lineStyle = "cart-info-line-vat", $scope.obj.totalStyle = "cart-info-total-vat", $scope.obj.remainingStyle = "cart-info-remaining-vat", $scope.obj.vatPerc = data.vatData.percentage, $scope.obj.vat = data.vatData.amount) : ($scope.obj.cartInfoStyle = "cart-info-no-vat", $scope.obj.lineStyle = "cart-info-line-no-vat", $scope.obj.totalStyle = "cart-info-total-no-vat", $scope.obj.remainingStyle = "cart-info-remaining-no-vat"), $scope.obj.credits = data.creditsData.usedSum, $scope.obj.total = data.subtotals.final, $scope.obj.remaining = data.creditsData.remainingSum)
+ }, $scope.$root.$on("alreadyBought", function(event, data) {
+ CheckOutService.onCheckOutRequested(data)
+ }), $scope.$root.$on("ownClips", function(event, data) {
+ CheckOutService.onCheckOutRequested(data)
+ })
+}), app.controller("CollectionsController", function($scope, BinsModel, Service, LoginModel, ViewStateService) {
+ $scope.obj = {}, $scope.obj.showImportAll = !1, $scope.obj.showFooter = !1, $scope.obj.showList = !1, $scope.obj.showBin, $scope.obj.addToBin, $scope.obj.addToBinName = "Collections", $scope.obj.collectionsList = COLLECTIONS_LIST_HTML, $scope.loginModel = function() {
+ return LoginModel.loggedIn
+ }, $scope.$watch($scope.loginModel, function() {
+ LoginModel.loggedIn ? $scope.obj.showFooter = !0 : $scope.obj.showFooter = !1
+ }), $scope.$root.$on("onBins", function(event) {
+ $scope.bins = BinsModel.bins, 0 == BinsModel.bins.length && ($scope.obj.addToBinName = "Collections")
+ }), $scope.$root.$on("active bin changed", function(event) {
+ $scope.obj.addToBin = BinsModel.addToBin, BinsModel.addToBin && ($scope.obj.addToBinName = getAbbrName(BinsModel.addToBin.name, 10))
+ }), $scope.toggleList = function() {
+ $scope.obj.showList = !$scope.obj.showList
+ }, $scope.openList = function() {
+ $scope.obj.showList = !0
+ }, $scope.closeList = function() {
+ $scope.obj.showList = !1
+ }, $scope.deleteIconClicked = function(bin) {
+ $scope.$root.$emit("collection delete requested", [bin])
+ }, $scope.showCollectionIconClicked = function(bin) {
+ BinsModel.showBin = bin, $scope.$root.$emit("bin selected", bin.name), ViewStateService.viewRequested("bins"), $scope.closeList()
+ }, $scope.collectionNameClicked = function(bin) {
+ BinsModel.addToBin = bin, $scope.obj.addToBinName = getAbbrName(bin.name, 10), $scope.closeList(), Service.setActiveBin(BinsModel.addToBin.id)
+ }, $scope.freeItemsClicked = function() {
+ ViewStateService.viewRequested("freebies"), $scope.closeList()
+ }, $scope.onClick = function() {
+ $scope.$root.$emit("select clicked")
+ }, $scope.onAddClicked = function() {
+ $scope.$root.$emit("modal add collection requested")
+ }
+}), app.controller("DownloadAllController", function($scope, ViewStateModel, DownloadBatchService, PurchasesModel, AnalyticsService) {
+ function onStateChange() {
+ "downloads" === ViewStateModel.getState() && PurchasesModel.purchasesVO && PurchasesModel.purchasesVO.items ? $scope.obj.show = !0 : $scope.obj.show = !1
+ }
+ $scope.obj = {
+ show: !1,
+ isDownloading: !1
+ }, $scope.$root.$on("on downloading all purchases complete", function(event) {
+ $scope.$apply(function() {
+ $scope.obj.isDownloading = !1
+ })
+ }), $scope.$root.$on("cancel all requested", function(event) {
+ console.log("DownloadAllController cancel all requested"), $scope.obj.isDownloading = !1
+ }), $scope.$root.$on("on purchases vo", function() {
+ onStateChange()
+ }), $scope.viewState = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewState, onStateChange, !0), $scope.onDownloadAllClicked = function() {
+ console.log("DownloadAllController onDownloadAllClicked"), $scope.obj.isDownloading = !0, DownloadBatchService.onBatchRequested();
+ var ga = {
+ ec: "download%20all"
+ };
+ console.log("DownloadAllController ga", ga), AnalyticsService.sendData(ga)
+ }
+}), app.controller("DownloadProgressController", function($scope, $timeout, ProgressService, DownloadRequestService, DownloadCancelService, ViewStateModel, DownloadModel) {
+ $scope.obj = {
+ items: [],
+ isOpen: !1,
+ progressCloseIcon: PROGRESS_CLOSE_IMG
+ }, $scope.viewStateModel = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewStateModel, function() {
+ $scope.obj.view = ViewStateModel.getState()
+ }), $scope.$root.$on("select clicked", function(event) {
+ $scope.obj.isOpen = !1
+ }), $scope.$root.$on("import all clicked", function(event) {
+ $scope.obj.isOpen = !0
+ }), $scope.$root.$on("open progress", function(event) {
+ $scope.obj.isOpen || ($scope.obj.isOpen = !0)
+ }), $scope.$root.$on("clear progress", function(event) {
+ $scope.obj.items = DownloadModel.itemsDownloadList
+ }), $scope.$root.$on("added to progress", function(event, data) {
+ $scope.obj.items = DownloadModel.itemsDownloadList
+ }), $scope.onProgressIconClicked = function() {
+ $scope.$root.$emit("progress button clicked")
+ }, $scope.$root.$on("progress button clicked", function(event) {
+ $scope.obj.isOpen = !$scope.obj.isOpen
+ }), $scope.clearListClicked = function() {
+ $scope.$root.$emit("progress button clicked"), ProgressService.clearCompleteItems(), 0 < $scope.obj.items.length ? $scope.obj.isOpen = !0 : $scope.obj.isOpen = !1
+ }, $scope.showClear = function() {
+ var show = !1;
+ return $scope.obj.items.forEach(function(item) {
+ item.completed && (show = !0)
+ }), !ProgressService.getDownloadingStatus() && 0 < DownloadModel.itemsDownloadList.length && (show = !0), show
+ }, $scope.isDownloading = function() {
+ var isDownloading = !1;
+ return $scope.obj.items.forEach(function(item) {
+ item.downloading && (isDownloading = !0)
+ }), ProgressService.getDownloadingStatus() && (show = !0), isDownloading
+ }, $scope.showMenu = function() {
+ return 0 < $scope.obj.items.length
+ }, $scope.cancelAllClicked = function() {
+ DownloadCancelService.onCancelAll(), $scope.$root.$emit("cancel all requested")
+ }, $scope.closeClicked = function() {
+ $scope.$root.$emit("progress button clicked"), console.log("DownloadProgressController closeClicked", $scope.obj.isOpen), $scope.obj.isOpen = !1, console.log("DownloadProgressController closeClicked", $scope.obj.isOpen)
+ }, $scope.cancelSingleClicked = function(item) {
+ DownloadCancelService.onCancelSingle(item)
+ }, $scope.hideTooltip = function() {
+ $timeout(function() {
+ $("#clearListButton").trigger("hide")
+ }, 0)
+ }
+}), app.controller("FilterController", function($scope, Service, SearchModel, ViewStateModel, AnalyticsService) {
+ $scope.obj = {
+ filters: ["Best Match", "Popular", "Newest", "Price", "Duration"]
+ }, $scope.caret = {
+ direction: "down"
+ }, $scope.obj.selected = $scope.obj.filters[0], $scope.onChange = function(val) {
+ var sortID;
+ switch (console.log("FilterController changed: ", $scope.obj.selected), $scope.obj.selected = val || $scope.obj.selected, $scope.obj.open = !1, $scope.obj.selected) {
+ case "Best Match":
+ sortID = 1;
+ break;
+ case "ARTIST":
+ sortID = 2;
+ break;
+ case "Newest":
+ sortID = 6;
+ break;
+ case "Duration":
+ sortID = 5;
+ break;
+ case "Popular":
+ sortID = 8;
+ break;
+ case "PAGE VIEWS":
+ sortID = 10;
+ break;
+ case "Price":
+ sortID = 4
+ }
+ console.log("FilterController sortID: ", sortID), SearchModel.filter = sortID, SearchModel.resultType = "replace", SearchModel.page = "0", Service.search(), window.scrollTo(0, 0);
+ var ga = {};
+ ga.ec = "search%20filter%20" + $scope.obj.selected.replace(/ /g, "%20"), ga.label = SearchModel.query, AnalyticsService.sendData(ga)
+ }, $scope.setCurrent = function(val) {
+ $scope.obj.selected = val
+ }, $scope.toggled = function(open) {
+ $scope.obj.direction = open ? "dropup" : "down"
+ }
+}), app.controller("FooterLinksController", function($scope, ViewStateModel, CartModel) {
+ $scope.obj = {
+ show: !1
+ }, $scope.viewState = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewState, function() {
+ "cart" === ViewStateModel.getState() ? $scope.obj.show = !0 : $scope.obj.show = !1
+ }, !0), $scope.onPromoCodeClicked = function() {
+ $scope.$root.$emit("modal promo requested")
+ }
+});
+var FreebiesController = function($scope, ViewStateService, FreebiesModel, ViewStateModel, LoginModel, AnalyticsService) {
+ function onViewStateChange() {
+ console.log("FreebiesController onViewStateChange:", ViewStateModel.getState()), "freebies" === ViewStateModel.getState() && LoginModel.getLoggedIn() ? $scope.obj.show = !0 : $scope.obj.show = !1
+ }
+ $scope.obj = {
+ show: !1
+ }, $scope.viewState = function() {
+ return ViewStateModel.getState()
+ }, $scope.loggedIn = function() {
+ return LoginModel.getLoggedIn()
+ }, $scope.$watch($scope.viewState, onViewStateChange, !0), $scope.$watch($scope.loggedIn, onViewStateChange), $scope.onFreebiesButtonClicked = function() {
+ ViewStateService.viewRequested("freebies"), console.log("FreebiesController onFreebiesButtonClicked");
+ var ga = {
+ ec: "freebies"
+ };
+ console.log("FreebiesController ga", ga), AnalyticsService.sendData(ga)
+ }, $scope.onAddAllFreebiesToCartClicked = function() {
+ var ids = [];
+ FreebiesModel.freebiesVO.items.forEach(function(item) {
+ ids.push(item.id)
+ });
+ var apiObj = {
+ fn: "modifyCart",
+ args: [convertArrayToCommaSeperatedString(ids), ""]
+ };
+ $scope.$root.$emit("api call", apiObj), $scope.$root.$emit("modal add to cart")
+ }
+};
+FreebiesController.$inject = ["$scope", "ViewStateService", "FreebiesModel", "ViewStateModel", "LoginModel", "AnalyticsService"], app.controller("ImportCollectionsController", function($scope, DownloadModel, ViewStateModel, BinsModel) {
+ $scope.obj = {
+ show: !1,
+ isImporting: !1
+ }, $scope.$root.$on("on importing bin complete", function(event) {
+ console.log("ImportCollectionsController on importing bin complete"), $scope.$apply(function() {
+ $scope.obj.isImporting = !1
+ })
+ }), $scope.viewState = function() {
+ return ViewStateModel.getState()
+ }, $scope.binsModel = function() {
+ return BinsModel.binVO
+ }, $scope.$watch($scope.viewState, function() {
+ "bins" === ViewStateModel.getState() ? $scope.obj.show = !0 : $scope.obj.show = !1
+ }, !0), $scope.$watch($scope.binsModel, function() {
+ "bins" === ViewStateModel.getState() && ($scope.obj.show = !0, 0 < BinsModel.binVO.items.length ? $scope.obj.isImporting = !1 : $scope.obj.isImporting = !0)
+ }, !0), $scope.onImportAllClicked = function() {
+ $scope.obj.isImporting = !0, $scope.$root.$emit("download requested", BinsModel.binVO.items), $scope.$root.$emit("import all clicked")
+ }
+}), app.controller("IntroAssetsController", function($scope) {
+ $scope.obj = {
+ state: 0,
+ stateName: ""
+ }, $scope.$root.$on("intro asset requested", function(event, stateObj) {
+ $scope.obj.stateName = stateObj.stateName, console.log("IntroAssetsController stateName", $scope.obj.stateName);
+ var fromX, toX, fromY, toY, currArrow = stateObj.arrowClass;
+ switch (currArrow) {
+ case ".intro-asset-arrow-up":
+ fromY = 20, toY = 0;
+ break;
+ case ".intro-asset-arrow-left":
+ fromX = 20, toX = 0;
+ break;
+ case ".intro-asset-arrow-down":
+ fromY = 0, toY = 20
+ }
+ "" != currArrow && ($(currArrow).css("top", "").css("left", "").css("bottom", ""), $(currArrow).css(stateObj.posX[0], stateObj.posX[1]), $(currArrow).css(stateObj.posY[0], stateObj.posY[1]), $(".intro-asset-arrow").velocity("stop"), $scope.loop(currArrow, fromX, toX, fromY, toY))
+ }), $scope.loop = function(target, fromX, toX, fromY, toY) {
+ $(target).velocity({
+ translateX: [fromX, toX],
+ translateY: [fromY, toY]
+ }, {
+ duration: 1e3,
+ loop: !0
+ })
+ }
+}), app.controller("ListItemController", function($scope, VersionsModel, ViewStateModel) {
+ $scope.obj = {}, $scope.deleteIconClicked = function() {
+ var apiObj = {
+ fn: "modifyCart",
+ args: ["", $scope.item.id]
+ };
+ $scope.$root.$emit("api call", apiObj)
+ }, $scope.versionButtonClicked = function() {
+ VersionsModel.setVersions($scope.item.versions)
+ }, $scope.imageHovered = function(e) {
+ var item;
+ "cart" == ViewStateModel.getState() ? item = $scope.item : "downloads" == ViewStateModel.getState() && (item = $scope.item.versions[0]), $scope.$root.$emit("start preview", item)
+ }, $scope.imageLeft = function(item) {
+ $scope.$root.$emit("stop preview", item)
+ }
+}), app.controller("ListCartController", function($scope, CartModel) {
+ $scope.obj = {}, $scope.cartItems = function() {
+ return CartModel
+ }, $scope.$watchCollection($scope.cartItems, function() {
+ CartModel.cartVO && ($scope.obj.items = CartModel.cartVO.items)
+ })
+}), app.controller("ListDownloadsController", function($scope, PurchasesModel) {
+ $scope.obj = {}, $scope.purchasedItems = function() {
+ return PurchasesModel
+ }, $scope.$watchCollection($scope.purchasedItems, function() {
+ PurchasesModel.purchasesVO && (console.log("ListController onPurchasesModelChange: ", PurchasesModel.purchasesVO.items), $scope.obj.items = PurchasesModel.purchasesVO.items)
+ })
+}), app.controller("LoginController", function($scope, LoginModel, UserModel) {
+ $scope.obj = {
+ loggedIn: !1,
+ logo: LOGO_IMG,
+ logoStyle: "logo-reg"
+ }, $scope.loginModel = function() {
+ return LoginModel
+ }, $scope.userModel = function() {
+ return UserModel
+ }, $scope.$watch($scope.loginModel, function() {
+ void 0 === LoginModel.getLoggedIn() ? $scope.obj.loggedIn = $scope.obj.loggedIn : $scope.obj.loggedIn = LoginModel.getLoggedIn();
+ $scope.obj.loggedIn && ($scope.obj.avatarURL = UserModel.getAvatarURL());
+ !1 === LoginModel.getLoggedIn() || void 0 === LoginModel.getLoggedIn() ? $scope.obj.row_top_style = "row-top-loggedout" : $scope.obj.row_top_style = "row-top-loggedin"
+ }, !0), $scope.$watch($scope.userModel, function() {
+ $scope.obj.avatarURL = UserModel.getAvatarURL(), 0 < THIRD_PARTY.length && ($scope.obj.logo = BASE_URL + "pond5_shared/images/" + THIRD_PARTY + ".png", $scope.obj.logoStyle = "logo-tp")
+ }, !0), $scope.loginRequested = function() {
+ $scope.$root.$emit("modal login requested")
+ }, $scope.logoutClicked = function() {
+ $scope.$root.$emit("modal logout requested")
+ }
+}), app.controller("MainViewController", function($scope, ViewStateModel, SearchModel) {
+ $scope.obj = {
+ tilesClass: "main-content"
+ }, $scope.$root.$on("filters button clicked", function(event, state) {
+ $scope.obj.tilesClass = state ? (ViewStateModel.setState("search"), "main-content-advanced-search") : "main-content"
+ }), $scope.$root.$on("advanced search close requested", function(event) {
+ $scope.obj.tilesClass = "main-content"
+ }), $scope.viewState = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewState, function() {
+ "search" === ViewStateModel.getState() && "add" === SearchModel.resultType ? console.log("MainViewController, do not scroll to top") : window.scrollTo(0, 0);
+ "cart" !== ViewStateModel.getState() && "downloads" !== ViewStateModel.getState() || ($scope.obj.tilesClass = "main-content");
+ $scope.obj.state = ViewStateModel.getState()
+ }, !0)
+});
+var MenuController = function($scope, ViewStateService, AnalyticsService) {
+ $scope.states = ["default", "hover", "selected"], $scope.btn0 = {
+ state: $scope.states[2],
+ selected: !0
+ }, $scope.btn1 = {
+ state: $scope.states[0],
+ selected: !1
+ }, $scope.btn2 = {
+ state: $scope.states[0],
+ selected: !1
+ }, $scope.btn3 = {
+ state: $scope.states[0],
+ selected: !1
+ }, $scope.buttons = [$scope.btn0, $scope.btn1, $scope.btn2, $scope.btn3], $scope.click = function(button) {
+ console.log("MenuController clicked ", button), $scope.selected = button;
+ for (var i = 0; i < $scope.buttons.length - 1; i++) button === $scope.buttons[i] ? ($scope.buttons[i].selected = !0, $scope.buttons[i].state = $scope.states[2]) : button != $scope.buttons[3] && ($scope.buttons[i].selected = !1, $scope.buttons[i].state = $scope.states[0]);
+ var view;
+ switch (button) {
+ case $scope.buttons[0]:
+ view = "search";
+ break;
+ case $scope.buttons[1]:
+ view = "downloads";
+ break;
+ case $scope.buttons[2]:
+ view = "previews";
+ break;
+ case $scope.buttons[3]:
+ view = "settings"
+ }
+ console.log("MenuController clicked view ", view), $scope.requestView(view)
+ }, $scope.requestView = function(view) {
+ "settings" === view ? $scope.$root.$emit("modal add destination requested") : ViewStateService.viewRequested(view);
+ var ga = {};
+ ga.ec = view, console.log("MenuController ga", ga), AnalyticsService.sendData(ga)
+ }, $scope.over = function(button) {
+ console.log("MenuController over ", button), button.selected || (button.state = $scope.states[1])
+ }, $scope.out = function(button) {
+ console.log("MenuController over ", button), button.selected || (button.state = $scope.states[0])
+ }
+};
+MenuController.$inject = ["$scope", "ViewStateService", "AnalyticsService"], app.controller("MessageController", function($scope, ViewStateModel) {
+ $scope.obj = {
+ show: !1
+ }, $scope.$root.$on("message view requested", function(event, show, data, list, imgUrl) {
+ $scope.obj.title = null, $scope.obj.messageList = null, $scope.obj.message = null, $scope.obj.imgUrl = null, $scope.obj.showImg = !1, ($scope.obj.show = show) && ($scope.obj.title = data[0], list ? $scope.obj.messageList = data[1] : $scope.obj.message = data[1], 2 === data.length ? $scope.obj.label = "OK" : $scope.obj.label = data[2], imgUrl && ($scope.obj.imgUrl = imgUrl, $scope.obj.showImg = !0))
+ }), $scope.viewStateModel = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewStateModel, function() {
+ "search" !== ViewStateModel.getState() && ($scope.obj.show = !1)
+ })
+}), app.controller("ModalAddCollectionConfirmationController", function($scope, $uibModal, BinsModel) {
+ $scope.items = [], $scope.$root.$on("collection created", function(event, data) {
+ console.log("ModalAddCollectionConfirmationController event handler", data), $scope.open("sm")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_ADD_COLLECTION_CONFIRMATION_HTML,
+ controller: ModalAddCollectionConfirmationInstanceCtrl,
+ size: size,
+ resolve: {
+ items: function() {
+ return $scope
+ }
+ }
+ }).result.then(function() {
+ console.log("ModalAddCollectionConfirmationController OK")
+ }, function() {
+ console.log("ModalAddCollectionConfirmationController CANCELED")
+ })
+ }
+});
+var ModalAddCollectionConfirmationInstanceCtrl = function($scope, $uibModalInstance, items, BinsModel) {
+ $scope.obj = {
+ title: "Complete!",
+ messagePre: "Your collection '",
+ messagePost: "' was succesfully created",
+ newBinName: BinsModel.newBinName
+ }, $scope.ok = function() {
+ $uibModalInstance.dismiss("cancel")
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalAddCollectionController", function($scope, $uibModal, Service, UserModel, BinsModel) {
+ $scope.items = [], $scope.$root.$on("modal add collection requested", function(event) {
+ console.log("ModalAddCollectionController event handler"), $scope.open("sm")
+ }), $scope.open = function(size) {
+ var modalInstance = $uibModal.open({
+ templateUrl: MODAL_ADD_COLLECTION_HTML,
+ controller: ModalAddCollectionInstanceCtrl,
+ size: size,
+ windowClass: "modal-small",
+ resolve: {
+ items: function() {
+ return $scope
+ }
+ }
+ });
+ modalInstance.result.then(function() {
+ console.log("ModalAddCollectionController OK")
+ }, function() {
+ console.log("ModalAddCollectionController CANCELED")
+ }), modalInstance.result.then(function(result) {}, function(result) {})
+ }
+});
+var ModalAddCollectionInstanceCtrl = function($scope, $uibModalInstance, items, Service, BinsModel) {
+ $scope.obj = {
+ showMessage: !1
+ }, $scope.create = function() {
+ console.log("ModalAddCollectionInstanceCtrl bin name: ", document.getElementById("addCollectionInput").value);
+ var binName = document.getElementById("addCollectionInput").value;
+ 1 < binName.length && ($uibModalInstance.close(), BinsModel.newBinName = binName, Service.createBin(binName))
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalAddToCartController", function($scope, $uibModal, Service, ViewStateService) {
+ $scope.$root.$on("modal add to cart", function(event) {
+ console.log("ModalAddToCartController event handler"), $scope.open("sm")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_ADD_TO_CART_HTML,
+ controller: ModalAddToCartInstanceCtrl,
+ size: size
+ }).result.then(function() {
+ console.log("ModalAddToCartController proceed"), ViewStateService.viewRequested("cart")
+ }, function() {
+ console.log("ModalAddToCartController later")
+ })
+ }
+});
+var ModalAddToCartInstanceCtrl = function($scope, $uibModalInstance) {
+ $scope.onProceed = function() {
+ console.log("ModalAddToCartInstanceCtrl onProceed"), $uibModalInstance.close()
+ }, $scope.onCancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalBillingAddressController", function($scope, $uibModal) {
+ $scope.obj = {}, $scope.$root.$on("modal billing address requested", function(event) {
+ console.log("ModalBillingAddressController event handler"), $scope.open("lg")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_BILLING_ADDRESS_HTML,
+ controller: ModalBillingAddressInstanceCtrl,
+ size: size,
+ windowClass: "modal-billing-address",
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ }
+ }).result.then(function() {
+ console.log("ModalBillingAddressController OK")
+ }, function() {
+ console.log("ModalBillingAddressController CANCELED"), $scope.$root.$emit("billing info canceled")
+ })
+ }
+});
+var ModalBillingAddressInstanceCtrl = function($scope, $uibModalInstance, obj, Service) {
+ $scope.firstName = "", $scope.lastName = "", $scope.street1 = "", $scope.street2 = "", $scope.province = "", $scope.zipCode = "", $scope.city = "", $scope.state = "", $scope.country = "", $scope.error = !1, $scope.countries = COUNTRIES, $scope.states = STATES, $scope.submit = function(myForm) {
+ if (console.log("ModalBillingAddressInstanceCtrl ok: ", myForm.firstName.$modelValue, myForm.lastName.$modelValue), console.log("ModalBillingAddressInstanceCtrl form valid: ", myForm.$valid), myForm.$valid) {
+ var stateCode;
+ stateCode = "" == myForm.state.$modelValue ? "" : myForm.state.$modelValue.code;
+ var data = {
+ country: myForm.country.$modelValue.code,
+ firstName: myForm.firstName.$modelValue,
+ lastName: myForm.lastName.$modelValue,
+ organization: myForm.organization.$modelValue,
+ department: myForm.department.$modelValue,
+ companyID: myForm.companyID.$modelValue,
+ vatID: myForm.vatID.$modelValue,
+ street1: myForm.street1.$modelValue,
+ street2: myForm.street2.$modelValue,
+ province: myForm.province.$modelValue,
+ zipCode: myForm.zipCode.$modelValue,
+ city: myForm.city.$modelValue,
+ state: stateCode
+ };
+ console.log("ModalBillingAddressInstanceCtrl DATA", data);
+ var apiObj = {
+ fn: "setBillingAddress",
+ args: [data]
+ };
+ $scope.$root.$emit("api call", apiObj), $uibModalInstance.dismiss()
+ } else console.log("ModalBillingAddressInstanceCtrl form is not valid"), $scope.error = !0
+ }, $scope.close = function() {
+ $uibModalInstance.dismiss()
+ }, $scope.back = function() {
+ $uibModalInstance.dismiss(), $scope.$root.$emit("on modal choose billing info requested")
+ }
+};
+app.controller("ModalBuyCreditsController", function($scope, $uibModal, ViewStateModel) {
+ $scope.obj = {}, $scope.$root.$on("modal buy credits requested", function() {
+ console.log("ModalBuyCreditsController event handler"), $scope.obj.title = "", $scope.obj.message = "As a reminder, only credits purchased in $USD can be used in this Add-on.";
+ $scope.open("sm")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_BUY_CREDITS_HTML,
+ controller: ModalBuyCreditsInstanceCtrl,
+ size: size,
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ },
+ windowClass: "modal-small"
+ }).result.then(function() {
+ console.log("ModalBuyCreditsController OK"), ViewStateModel.allowPreviews = !0, opn("https://www.pond5.com/credit-packages")
+ }, function() {
+ console.log("ModalBuyCreditsController CANCELED")
+ })
+ }
+});
+var ModalBuyCreditsInstanceCtrl = function($scope, $uibModalInstance, obj) {
+ $scope.obj = {}, $scope.obj.message = obj.message, $scope.obj.title = obj.title, $scope.ok = function() {
+ console.log("ModalBuyCreditsInstanceCtrl OK"), $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel"), console.log("ModalBuyCreditsInstanceCtrl cancel")
+ }
+};
+app.controller("ModalChooseBillingInfoController", function($scope, $uibModal, BillingInfoModel, CheckOutService, Service) {
+ $scope.items = [], $scope.obj = {}, $scope.$root.$on("on modal choose billing info requested", function(event) {
+ console.log("ModalChooseBillingInfoController event handler: ", BillingInfoModel.getBillingInfo()), $scope.items = BillingInfoModel.getBillingInfo(), $scope.open("lg")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_CHOOSE_BILLING_INFO_HTML,
+ controller: ModalChooseBillingInfoInstanceCtrl,
+ windowClass: "modal-choose-billing",
+ size: size,
+ resolve: {
+ items: function() {
+ return $scope.items
+ }
+ }
+ }).result.then(function(item) {
+ console.log("ModalChooseBillingInfoController ok, selected: ", item.addressid), CheckOutService.onCheckOutRequested()
+ }, function() {
+ console.log("ModalChooseBillingInfoController dismissed"), $scope.$root.$emit("billing info canceled")
+ })
+ }
+});
+var ModalChooseBillingInfoInstanceCtrl = function($scope, $uibModalInstance, items, BillingInfoModel, Service) {
+ console.log("ModalChooseBillingInfoInstanceCtrl items", items), console.log("ModalChooseBillingInfoInstanceCtrl default", BillingInfoModel.getDefaultInfo()), $scope.items = items, $scope.selected = BillingInfoModel.getDefaultInfo(), $scope.adyenEncryption = "https://plugin.pond5.com/pond5_shared/images/adyen-encryption.png", $scope.onRbClicked = function(item) {
+ $scope.selected = item, console.log("ModalChooseBillingInfoInstanceCtrl rb > default", item), BillingInfoModel.setDefaultInfo(item), Service.getCartTotal()
+ }, $scope.onOKClicked = function() {
+ $uibModalInstance.close($scope.selected)
+ }, $scope.close = function() {
+ $uibModalInstance.dismiss()
+ }, $scope.addNewClicked = function() {
+ $uibModalInstance.dismiss(), $scope.$root.$emit("modal billing address requested")
+ }, $scope.readAgreement = function() {
+ console.log("ModalChooseBillingInfoInstanceCtrl readAgreement"), opn("https://www.pond5.com/legal/license")
+ }, $scope.helpCenter = function() {
+ opn("https://help.pond5.com/hc/en-us/")
+ }, $scope.callUs = function() {
+ opn("https://help.pond5.com/hc/en-us/requests/new")
+ }
+};
+app.controller("ModalChooseFormatController", function($scope, $uibModal) {
+ $scope.items = [], $scope.$root.$on("on add to cart clicked", function(event, formats) {
+ console.log("ModalChooseFormatController handler, formats: ", formats), $scope.items = [], $scope.items = formats, $scope.open("sm")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_CHOOSE_FORMAT_HTML,
+ controller: ModalChooseFormatInstanceCtrl,
+ size: size,
+ windowClass: "modal-small",
+ resolve: {
+ items: function() {
+ return $scope.items
+ }
+ }
+ }).result.then(function() {}, function() {
+ console.log("ModalChooseFormatController dismissed")
+ })
+ }
+});
+var ModalChooseFormatInstanceCtrl = function($scope, $uibModalInstance, items, Service) {
+ $scope.items = items, $scope.items[0].selected = !0, $scope.onRbClicked = function(item, index) {
+ console.log("ModalChooseFormatInstanceCtrl onRbClicked: " + item + "-" + index);
+ for (var i = 0; i < $scope.items.length; i++) $scope.items[i].selected = index === i
+ }, $scope.onAddToCartClicked = function() {
+ for (var i = 0; i < $scope.items.length; i++)
+ if ($scope.items[i].selected) {
+ var item = $scope.items[i],
+ apiObj = {
+ fn: "modifyCart",
+ args: [item.id + ":" + item.offset]
+ };
+ $scope.$root.$emit("api call", apiObj)
+ } $uibModalInstance.dismiss()
+ }
+};
+app.controller("ModalChooseVersionController", function($scope, $uibModal, Service, DownloadModel) {
+ $scope.items = [], $scope.$root.$on("on versions selected", function(event, versions) {
+ console.log("ModalChooseVersionController event handler: ", $scope.items, versions), $scope.items = [], $scope.items = versions, $scope.open("sm")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_CHOOSE_VERSION_HTML,
+ controller: ModalChooseVersionInstanceCtrl,
+ size: size,
+ resolve: {
+ items: function() {
+ return $scope.items
+ }
+ },
+ windowClass: "modal-small"
+ }).result.then(function(selectedIndex) {
+ var selectedItem = $scope.items[selectedIndex];
+ DownloadModel.selectedVersion = selectedIndex, Service.getPurchaseURL(selectedItem.id, selectedItem.transactionID, selectedItem.versionID, selectedItem.version)
+ }, function() {
+ console.log("ModalChooseVersionController dismissed")
+ })
+ }
+});
+var ModalChooseVersionInstanceCtrl = function($scope, $uibModalInstance, items) {
+ $scope.items = items, $scope.selected = $scope.items[0], $scope.selectedIndex = 0, $scope.onRbClicked = function(index) {
+ $scope.selected = $scope.items[index], $scope.selectedIndex = index
+ }, $scope.ok = function() {
+ $uibModalInstance.close($scope.selectedIndex)
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalClearCartConfirmationController", function($scope, $uibModal) {
+ $scope.obj = [], $scope.$root.$on("clear cart requested", function(event, data, size) {
+ console.log("ModalClearCartConfirmationController event handler", data), $scope.obj.title = "Clear My Cart", $scope.obj.message = "Are you sure you want to clear your cart?", $scope.obj.itemsToDelete = data[0], $scope.obj.label = "CLEAR", $scope.obj.showButtonLeft = !0, $scope.obj.labelLeft = "CANCEL", size = size || "sm", $scope.open(size)
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_SIMPLE_HTML,
+ controller: ModalClearCartConfirmationInstanceCtrl,
+ size: size,
+ windowClass: "modal-small",
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ }
+ }).result.then(function() {
+ console.log("ModalClearCartConfirmationController OK");
+ var apiObj = {
+ fn: "modifyCart",
+ args: ["", $scope.obj.itemsToDelete]
+ };
+ $scope.$root.$emit("api call", apiObj)
+ }, function() {
+ console.log("ModalClearCartConfirmationController CANCELED")
+ })
+ }
+});
+var ModalClearCartConfirmationInstanceCtrl = function($scope, $uibModalInstance, obj) {
+ $scope.obj = {}, $scope.obj.message = obj.message, $scope.obj.title = obj.title, $scope.obj.label = obj.label, $scope.obj.showButtonLeft = !0, $scope.obj.labelLeft = "CANCEL", $scope.ok = function() {
+ $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalDeleteCollectionConfirmationController", function($scope, $uibModal, Service, ViewStateModel, BinsModel, ViewStateService) {
+ $scope.obj = {}, $scope.$root.$on("collection delete requested", function(event, data, size) {
+ console.log("ModalDeleteCollectionConfirmationController event handler", data, data.length, size), $scope.obj.title = "Delete Collection", $scope.obj.message = "Are you sure you want to delete the collection " + data[0].name + " ?", $scope.obj.bin = data[0], $scope.obj.label = "DELETE", $scope.obj.showButtonLeft = !0, $scope.obj.labelLeft = "CANCEL", size = size || "sm", $scope.open(size)
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_SIMPLE_HTML,
+ controller: ModalDeleteCollectionConfirmationInstanceCtrl,
+ size: size,
+ windowClass: "modal-small",
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ }
+ }).result.then(function() {
+ BinsModel.selectedBin == $scope.obj.bin && ViewStateService.viewRequested("search"), Service.removeBin($scope.obj.bin.id), ViewStateModel.allowPreviews = !0
+ }, function() {})
+ }
+});
+var ModalDeleteCollectionConfirmationInstanceCtrl = function($scope, $uibModalInstance, obj) {
+ $scope.obj = {}, $scope.obj.message = obj.message, $scope.obj.title = obj.title, $scope.obj.label = obj.label, $scope.obj.showButtonLeft = !0, $scope.obj.labelLeft = "CANCEL", $scope.ok = function() {
+ $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalFreebiesController", function($scope, $uibModal, ViewStateService) {
+ $scope.$root.$on("modal freebies", function(event) {
+ console.log("ModalFreebiesController event handler"), $scope.open("lg")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_FREEBIES_HTML,
+ controller: ModalFreebiesInstanceCtrl,
+ size: size
+ }).result.then(function() {
+ console.log("ModalFreebiesController OK"), ViewStateService.viewRequested("freebies")
+ }, function() {
+ console.log("ModalFreebiesController dismissed")
+ })
+ }
+});
+var ModalFreebiesInstanceCtrl = function($scope, $uibModalInstance) {
+ $scope.ok = function() {
+ $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalLoginController", function($scope, $uibModal) {
+ $scope.obj = {}, $scope.$root.$on("modal login requested", function(event) {
+ console.log("ModalLoginController event handler"), $scope.open("lg")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_LOGIN_HTML,
+ controller: ModalLoginInstanceCtrl,
+ size: size,
+ windowClass: "modal-small",
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ }
+ }).result.then(function() {
+ console.log("ModalLoginController OK")
+ }, function() {
+ console.log("ModalLoginController CANCELED")
+ })
+ }
+});
+var ModalLoginInstanceCtrl = function($scope, $uibModalInstance, obj) {
+ $scope.obj = {}, $scope.obj.userName = obj.userName, $scope.obj.password = obj.password, $scope.obj.showTitle = !0, $scope.obj.showClose = !0, $scope.loginRequested = function() {
+ $uibModalInstance.close();
+ var apiObj = {
+ fn: "login",
+ args: [$scope.obj.userName, $scope.obj.password]
+ };
+ $scope.$root.$emit("api call", apiObj)
+ }, $scope.close = function() {
+ $uibModalInstance.dismiss("cancel")
+ }, $scope.signUp = function() {
+ opn("https://www.pond5.com/login")
+ }
+};
+app.controller("ModalLogoutConfirmationController", function($scope, $uibModal, Service, ViewStateModel) {
+ $scope.obj = {}, $scope.$root.$on("modal logout requested", function(event, data, size) {
+ console.log("ModalLogoutConfirmationController event handler"), $scope.obj.title = "Log out", $scope.obj.message = "Are you sure you want to log out?", $scope.obj.label = "YES", $scope.obj.showButtonLeft = !0, $scope.obj.labelLeft = "CANCEL", size = size || "sm", $scope.open(size)
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_SIMPLE_HTML,
+ controller: ModalLogoutConfirmationInstanceCtrl,
+ size: size,
+ windowClass: "modal-small",
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ }
+ }).result.then(function() {
+ Service.logout(), ViewStateModel.allowPreviews = !0
+ }, function() {})
+ }
+});
+var ModalLogoutConfirmationInstanceCtrl = function($scope, $uibModalInstance, obj) {
+ $scope.obj = {}, $scope.obj.message = obj.message, $scope.obj.title = obj.title, $scope.obj.label = obj.label, $scope.obj.showButtonLeft = !0, $scope.obj.labelLeft = "CANCEL", $scope.ok = function() {
+ $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalNotLoggedInController", function($scope, $uibModal) {
+ $scope.obj = {}, $scope.$root.$on("modal not logged in", function(event, data) {
+ $scope.obj.title = data[0], $scope.obj.message = "You're not logged in", $scope.open("lg")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_NOT_LOGGED_IN_HTML,
+ controller: ModalNotLoggedInInstanceCtrl,
+ size: size,
+ windowClass: "modal-small",
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ }
+ }).result.then(function() {
+ console.log("ModalNotLoggedInController OK")
+ }, function() {
+ console.log("ModalNotLoggedInController CANCELED")
+ })
+ }
+});
+var ModalNotLoggedInInstanceCtrl = function($scope, $uibModalInstance, obj) {
+ $scope.obj = {}, $scope.obj.message = obj.message, $scope.obj.title = obj.title, $scope.loginRequested = function() {
+ $uibModalInstance.dismiss("cancel"), $scope.$root.$emit("modal login requested")
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }, $scope.signUp = function() {
+ opn("https://www.pond5.com/login")
+ }
+};
+app.controller("ModalPromoCodeController", function($scope, $uibModal, Service, UserModel) {
+ $scope.items = [], $scope.obj = {
+ label: "APPLY",
+ onlyNumbers: /^\d+$/
+ }, $scope.$root.$on("modal promo requested", function(event) {
+ console.log("ModalPromoCodeController event handler"), $scope.open("sm")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_PROMO_CODE_HTML,
+ controller: ModalPromoCodeInstanceCtrl,
+ size: size,
+ windowClass: "modal-small",
+ resolve: {
+ items: function() {
+ return $scope
+ }
+ }
+ }).result.then(function() {
+ console.log("ModalPromoCodeController OK")
+ }, function() {
+ console.log("ModalPromoCodeController CANCELED")
+ })
+ }
+});
+var ModalPromoCodeInstanceCtrl = function($scope, $uibModalInstance, items, Service, $filter) {
+ $scope.obj = {
+ showMessage: !1,
+ label: "APPLY",
+ onlyNumbers: /^\d+$/
+ }, $scope.$root.$on("promo code added", function(event, data) {
+ var message;
+ console.log("ModalPromoCodeController event handler", data), message = data.commands[0].sum ? $filter("currency")(data.commands[0].sum) + " were succesfully added to your account!" : "Invalid code. Please try again or contact Pond5.", $scope.obj.credits = data, $scope.obj.showMessage = !0, $scope.obj.message = message, $scope.obj.label = "OK"
+ }), $scope.codeApplied = function() {
+ if (console.log("ModalPromoCodeInstanceCtrl codeApplied: ", document.getElementById("promoInput").value), "OK" == $scope.obj.label) $uibModalInstance.close();
+ else {
+ var code = document.getElementById("promoInput").value;
+ 1 < code.length && Service.promoRedeem(code)
+ }
+ }, $scope.ok = function() {
+ console.log("ModalPromoCodeInstanceCtrl OK"), $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalRemoveCollectionController", function($scope, $uibModal, Service, BinsModel, ViewStateModel) {
+ $scope.items = [], $scope.showModal = function() {
+ return BinsModel.showModal
+ }, $scope.$root.$on("modal remove collection requested", function(event) {
+ console.log("ModalRemoveCollectionController remove collection requested event handler", BinsModel.showModal, BinsModel.clipClicked), $scope.items = BinsModel.bins, 0 < $scope.items.length && $scope.open()
+ }), $scope.$root.$on("collection removed", function(event) {
+ console.log("ModalAddCollectionController collection removed event handler")
+ }), $scope.open = function(size) {
+ var modalInstance = $uibModal.open({
+ templateUrl: MODAL_REMOVE_COLLECTION_HTML,
+ controller: ModalRemoveCollectionInstanceCtrl,
+ windowClass: "modal-fit",
+ resolve: {
+ items: function() {
+ return $scope.items
+ }
+ }
+ });
+ $scope.resetBins = function() {
+ BinsModel.showModal = !1;
+ for (var i = 0; i < $scope.items.length; i++) $scope.items[i].selected = !1
+ }, modalInstance.result.then(function() {
+ console.log("OK: ", BinsModel.clipClicked, $scope.items);
+ for (var i = 0; i < $scope.items.length; i++) $scope.items[i].selected && (console.log("ModalRemoveCollectionController selected bin:", $scope.items[i].id), Service.removeBin($scope.items[i].id));
+ $scope.resetBins(), ViewStateModel.allowPreviews = !0
+ }, function() {
+ $scope.resetBins()
+ })
+ }
+});
+var ModalRemoveCollectionInstanceCtrl = function($scope, $uibModalInstance, items) {
+ $scope.items = items, $scope.ok = function() {
+ $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalReplaceController", function($scope, $uibModal, ReplaceModel, ReplaceServiceShared) {
+ $scope.items = [], $scope.$root.$on("modal replace", function(event, items) {
+ console.log("ModalReplaceController event handler: ", items), $scope.items = items, $scope.open("lg")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_REPLACE_HTML,
+ controller: ModalReplaceInstanceCtrl,
+ size: size,
+ resolve: {
+ items: function() {
+ return $scope.items
+ }
+ },
+ windowClass: "modal-replace"
+ }).result.then(function() {
+ ReplaceServiceShared.onModalReplaceOK()
+ }, function() {
+ ReplaceModel.setState(DEFAULT)
+ })
+ }
+});
+var ModalReplaceInstanceCtrl = function($scope, $uibModalInstance, items) {
+ $scope.obj = {
+ checkIcon: "https://plugin.pond5.com/pond5_shared/images/check-icon.png",
+ modalHeader: MODAL_REPLACE_HEADER,
+ modalContent: MODAL_REPLACE_CONTENT,
+ resTitle: MODAL_REPLACE_RES_TITLE
+ }, $scope.items = items;
+ for (var i = 0; i < $scope.items.length; i++) {
+ $scope.items[i].selected = !0;
+ for (var j = 0; j < $scope.items[i].formats.length; j++) console.log("ModalReplaceInstanceCtrl incart: ", $scope.items[i].formats[j].inDownloads), $scope.items[i].formats[j].inDownloads && ($scope.items[i].formats.length = 0), 0 < $scope.items[i].formats.length && $scope.items[i].formats[j].inCart && ($scope.items[i].formats[j].selected = !0, $scope.items[i].oneFormatInCart = !0);
+ !$scope.items[i].oneFormatInCart && 0 < $scope.items[i].formats.length && ($scope.items[i].formats[0].selected = !0)
+ }
+ $scope.selectAllClicked = function() {
+ var item;
+ console.log("ModalReplaceInstanceCtrl selectAllClicked: ", $scope.obj.selectAll);
+ for (var i = 0; i < $scope.items.length; i++) item = $scope.items[i], !$scope.obj.selectAll || item.inCart || item.inDownloads ? item.selected = !0 : item.selected = !1
+ }, $scope.onRbClicked = function(item, index) {
+ console.log("ModalReplaceInstanceCtrl onRbClicked: " + item.name + "-" + item.selected);
+ for (var i = 0; i < item.formats.length; i++) item.formats[i].selected = index === i
+ }, $scope.onCbClicked = function(item, index) {
+ console.log("ModalReplaceInstanceCtrl onCbClicked: " + item.name + "-" + item.selected), item.selected = !item.selected;
+ for (var i = 0; i < item.formats.length; i++) item.formats[i].selected = index === i;
+ console.log("ModalReplaceInstanceCtrl onCbClicked after toggle: " + item.name + "-" + item.selected)
+ }, $scope.ok = function() {
+ $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalReplaceWarningController", function($scope, $uibModal, Service, DownloadModel, ViewStateService, ReplaceModel) {
+ $scope.obj = {}, $scope.obj.requestedState = "", $scope.$root.$on("modal replace warning", function(event, viewState) {
+ console.log("ModalReplaceWarningController event handler, event: ", event), console.log("ModalReplaceWarningController event handler, viewState: ", viewState), $scope.obj.requestedState = viewState, $scope.obj.message = "Visiting the " + viewState + " view will cancel the process of replacing your lo-res previews with hi-res clips. Are you sure you want to visit the " + viewState + " view?", $scope.open("sm")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_REPLACE_WARNING_HTML,
+ controller: ModalReplaceWarningInstanceCtrl,
+ size: size,
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ },
+ windowClass: "modal-small"
+ }).result.then(function() {
+ ViewStateService.onViewApproved(!0)
+ }, function() {
+ console.log("ModalReplaceWarningController CANCELED"), ViewStateService.onViewApproved(!1)
+ })
+ }
+});
+var ModalReplaceWarningInstanceCtrl = function($scope, $uibModalInstance, obj) {
+ $scope.obj = {}, $scope.obj.message = obj.message, $scope.ok = function() {
+ $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalSimpleController", function($scope, $uibModal, Service, DownloadModel, ViewStateModel) {
+ $scope.obj = {
+ imgUrl: "",
+ showImg: !1
+ }, $scope.$root.$on("modal simple requested", function(event, data, size, list, imgUrl) {
+ var windowClass;
+ $scope.obj.title = null, $scope.obj.messageList = null, $scope.obj.message = null, $scope.obj.imgUrl = null, $scope.obj.showImg = !1, list ? $scope.obj.messageList = data[1] : $scope.obj.message = data[1], 2 === data.length ? $scope.obj.label = "OK" : $scope.obj.label = data[2], imgUrl && ($scope.obj.imgUrl = imgUrl, $scope.obj.showImg = !0), "sm" === size ? windowClass = "modal-small" : "lg" === size && (windowClass = "modal-large"), $scope.open(windowClass)
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_SIMPLE_HTML,
+ controller: ModalSimpleInstanceCtrl,
+ windowClass: size,
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ }
+ }).result.then(function() {
+ ViewStateModel.allowPreviews = !0
+ }, function() {})
+ }
+});
+var ModalSimpleInstanceCtrl = function($scope, $uibModalInstance, obj) {
+ $scope.obj = {}, $scope.obj.message = obj.message, $scope.obj.messageList = obj.messageList, $scope.obj.title = obj.title, $scope.obj.label = obj.label, $scope.obj.imgUrl = obj.imgUrl, $scope.ok = function() {
+ $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("PreviewAudioController", function($scope, ViewStateModel) {
+ $scope.obj = {
+ show: !1
+ }, $scope.$root.$on("start preview", function(event, item, xpos) {
+ if (("Music" == item.type || "Sound effect" == item.type) && ViewStateModel.allowPreviews) {
+ var num = Number(item.dur),
+ seconds = Math.floor(num / 1e3),
+ minutes = Math.floor(seconds / 60);
+ 1 === (seconds = seconds - 60 * minutes).toString().length && (seconds = "0" + seconds);
+ var format = minutes + ":" + seconds;
+ $scope.obj.dur = format, item.dur || ($scope.obj.dur = ""), $scope.obj.timer = setTimeout(function() {
+ document.getElementById("tracktime").style.left = "0px", $scope.playAudio(item.m4aURL, xpos), $scope.obj.name = item.abbrName, item.artistName ? $scope.obj.artist = "BY " + item.artistName.toUpperCase() : "n/a" === item.fps ? $scope.obj.artist = "" : $scope.obj.artist = item.fps, $scope.obj.iconLargeURL = item.iconLargeURL, item.priceRange && item.priceRange[0] != item.priceRange[1] ? ($scope.obj.price = "$" + item.priceRange[0] + "-$" + item.priceRange[1], $scope.obj.priceStyle = "preview-price-double") : ($scope.obj.price = "$" + item.price, $scope.obj.priceStyle = "preview-price-single"), $scope.$apply(function() {
+ $scope.obj.show = !0
+ })
+ }, 400)
+ }
+ }), $scope.$root.$on("stop preview", function(event, data) {
+ data && (clearTimeout($scope.obj.timer), setTimeout(function() {
+ $scope.playAudio("")
+ }, 200), $scope.obj.name = "", $scope.obj.price = "", $scope.obj.type = "", $scope.obj.dur = "", $scope.obj.show = !1)
+ }), $scope.playAudio = function(url, xpos) {
+ var audio = document.getElementById("audio");
+ document.getElementById("source-audio").setAttribute("src", url), audio.load()
+ }
+}), app.controller("PreviewPhotoController", function($scope, ViewStateModel) {
+ $scope.obj = {
+ show: !1,
+ showInfo: !0
+ }, $scope.$root.$on("start preview", function(event, item, xpos) {
+ "Photo" != item.type && "Illustration" != item.type || ViewStateModel.allowPreviews && ($scope.obj.timer = setTimeout(function() {
+ $scope.obj.name = item.abbrName, item.artistName ? $scope.obj.artist = "BY " + item.artistName.toUpperCase() : "n/a" === item.fps ? $scope.obj.artist = "" : $scope.obj.artist = item.fps, $scope.obj.vs = item.vs, $scope.obj.ar = item.ar, $scope.obj.audioCodec = item.audioCodec, $scope.obj.videoCodec = item.videoCodec, item.priceRange && item.priceRange[0] != item.priceRange[1] ? ($scope.obj.price = "$" + item.priceRange[0] + "-$" + item.priceRange[1], $scope.obj.priceStyle = "preview-price-double") : ($scope.obj.price = "$" + item.price, $scope.obj.priceStyle = "preview-price-single"), item.ox ? $scope.obj.res = item.ox + " x " + item.oy : $scope.obj.res = "", $scope.obj.type = item.type, $scope.obj.iconLargeURL = item.iconLargeURL;
+ var size = convertAspectRatio(370, 208, item.aq);
+ actualRatio = item.aq, targetRatio = size.x / size.y, adjustmentRatio = targetRatio / actualRatio;
+ var photo = document.getElementById("photo");
+ photo.width = size.x, photo.height = size.y, document.getElementById("preview-loading").style.visibility = "hidden", photo.style.position = "absolute";
+ var x_pos = 185 - photo.width / 2;
+ photo.style.left = x_pos + "px", $scope.obj.name = item.abbrName, item.artistName ? $scope.obj.artist = "BY " + item.artistName.toUpperCase() : "n/a" === item.fps ? $scope.obj.artist = "" : $scope.obj.artist = item.fps, $scope.obj.fps = item.fps, $scope.obj.vs = item.vs, $scope.obj.ar = item.ar, $scope.obj.audioCodec = item.audioCodec, $scope.obj.videoCodec = item.videoCodec, item.videoCodec && -1 != item.videoCodec.indexOf("Apple ProRes") && ($scope.obj.videoCodec = "Apple ProRes"), item.priceRange && item.priceRange[0] != item.priceRange[1] ? ($scope.obj.price = "$" + item.priceRange[0] + "-$" + item.priceRange[1], $scope.obj.priceStyle = "preview-price-double") : ($scope.obj.price = "$" + item.price, $scope.obj.priceStyle = "preview-price-single"), item.ox ? $scope.obj.res = item.ox + " x " + item.oy : $scope.obj.res = "", $scope.$apply(function() {
+ $scope.obj.show = !0
+ })
+ }, 400))
+ }), $scope.$root.$on("stop preview", function(event, item) {
+ item && (clearTimeout($scope.obj.timer), $scope.obj.name = "", $scope.obj.price = "", $scope.obj.type = "", $scope.obj.show = !1)
+ })
+}), app.controller("PreviewVideoController", function($scope, ViewStateModel) {
+ $scope.obj = {
+ show: !1,
+ timer: null,
+ item: null,
+ showInfo: !0
+ }, $scope.$root.$on("start preview", function(event, item) {
+ "Video" != item.type && "AE" != item.type || ViewStateModel.allowPreviews && ($scope.obj.timer = setTimeout(function() {
+ $scope.obj.name = item.abbrName, item.artistName ? $scope.obj.artist = "BY " + item.artistName.toUpperCase() : "n/a" === item.fps && ($scope.obj.artist = ""), $scope.obj.fps = item.fps, $scope.obj.vs = item.vs, $scope.obj.ar = item.ar, $scope.obj.audioCodec = item.audioCodec, $scope.obj.videoCodec = item.videoCodec, item.videoCodec && -1 != item.videoCodec.indexOf("Apple ProRes") && ($scope.obj.videoCodec = "Apple ProRes"), item.priceRange && item.priceRange[0] != item.priceRange[1] ? ($scope.obj.price = "$" + item.priceRange[0] + "-$" + item.priceRange[1], $scope.obj.priceStyle = "preview-price-double") : ($scope.obj.price = "$" + item.price, $scope.obj.priceStyle = "preview-price-single"), item.ox ? $scope.obj.res = item.ox + " x " + item.oy : $scope.obj.res = "", $scope.$apply(function() {
+ $scope.obj.show = !0
+ }), $scope.playVideo(item)
+ }, 400))
+ }), $scope.$root.$on("stop preview", function(event, data) {
+ clearTimeout($scope.obj.timer), $("#video-frame").children().filter("video").each(function() {
+ this.pause(), $(this).remove()
+ }), $("#video-frame").empty(), $scope.obj.name = "", $scope.obj.price = "", $scope.obj.fps = "", $scope.obj.vs = "", $scope.obj.show = !1, document.getElementById("preview-loading").style.visibility = "visible"
+ }), $scope.playVideo = function(item) {
+ $("#video-frame").append($(" "));
+ var video = document.getElementsByTagName("video")[0],
+ source = document.getElementById("source-video");
+ video.style.visibility = "hidden";
+ var size = convertAspectRatio(370, 208, item.aq);
+ video.addEventListener("loadedmetadata", function(event) {
+ video.width = size.x, video.height = size.y, document.getElementById("preview-loading").style.visibility = "hidden", video.style.visibility = "visible"
+ }), item.h264URL ? (video.pause(), source.setAttribute("src", ""), source.setAttribute("src", item.h264URL), video.load()) : (source.setAttribute("src", ""), video.pause())
+ }, $scope.$root.$on("preview info icon over", function() {
+ $scope.obj.showInfo = !0
+ }), $scope.$root.$on("preview info icon out", function() {
+ $scope.obj.showInfo = !1
+ })
+}), app.controller("ReplaceController", function($scope, $timeout, ViewStateModel, ReplaceService, LoginModel, AnalyticsService, ReadClipsOnFSService) {
+ $scope.obj = {
+ show: !1,
+ disabled: !1,
+ buttonLabel: BUTTON_REPLACE_LABEL,
+ buttonTooltip: BUTTON_REPLACE_TOOLTIP
+ }, $scope.$root.$on("replacing complete", function() {
+ $scope.obj.disabled = !1
+ }), $scope.viewState = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewState, function() {
+ "cart" != ViewStateModel.getState() ? $scope.obj.show = !0 : $scope.obj.show = !1
+ }, !0), $scope.onReplaceButtonClicked = function() {
+ if (LoginModel.getLoggedIn()) {
+ $scope.hideTooltip(), $scope.obj.disabled = !0, ReadClipsOnFSService.listPurchasesOnFS(function() {
+ console.log("DragAndDropController fs items listed, call onClipsFSCollected"), ReplaceService.onClipFSCollected()
+ });
+ var ga = {
+ ec: "replace%20with%20hires"
+ };
+ AnalyticsService.sendData(ga)
+ } else $scope.$root.$emit("modal not logged in", [ERROR])
+ }, $scope.onReplaceButtonOver = function() {
+ $timeout(function() {
+ $("#replaceButton").trigger("show")
+ }, 0)
+ }, $scope.onReplaceButtonOut = function() {
+ $scope.hideTooltip()
+ }, $scope.hideTooltip = function() {
+ $timeout(function() {
+ $("#replaceButton").trigger("hide")
+ }, 0)
+ }
+}), app.controller("SearchController", function($scope, ViewStateService, SearchModel, ViewStateModel, AnalyticsService) {
+ $scope.obj = {
+ filters: MEDIA_TYPES,
+ direction: "down",
+ showFilters: !1,
+ view: "search",
+ styleInput: "search-input-reg"
+ }, $scope.viewStateModel = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewStateModel, function() {
+ $scope.obj.view = ViewStateModel.getState(), 0 < THIRD_PARTY.length && ($scope.obj.styleInput = "search-input-tp")
+ }, !0), resizePanel = function() {
+ var numOfTotalResults = SearchModel.searchResultItems.length,
+ numOfResults = SearchModel.numOfResults,
+ rect = window.innerWidth * window.innerHeight;
+ 0 < numOfResults && numOfResults != numOfTotalResults && numOfTotalResults < rect / 25e3 && "search" == ViewStateModel.getState() && (SearchModel.isSearching || (console.log("SearchController resize, new search"), SearchModel.isSearching = !0, SearchModel.resultType = "add", SearchModel.page = SearchModel.page + 1, ViewStateService.viewRequested("search")))
+ }, $scope.obj.selected = $scope.obj.filters[0], $scope.$root.$on("filters button clicked", function(event, state) {
+ $scope.obj.showFilters = state
+ }), $scope.filtersRequested = function() {
+ $scope.obj.showFilters = !$scope.obj.showFilters, $scope.$root.$emit("filters button clicked", $scope.obj.showFilters)
+ }, $scope.onChange = function(val) {
+ var sortID;
+ switch (console.log("SearchController onChange: ", val), $scope.obj.selected = val, $scope.obj.open = !1, $scope.obj.selected) {
+ case "Footage":
+ sortID = BM_VIDEO;
+ break;
+ case "After Effects":
+ sortID = BM_AFTER_EFFECTS;
+ break;
+ case "Music":
+ sortID = BM_MUSIC;
+ break;
+ case "SFX":
+ sortID = BM_SFX;
+ break;
+ case "Public Domain":
+ sortID = BM_PUBLIC_DOMAIN;
+ break;
+ case "Photos":
+ sortID = BM_PHOTO;
+ break;
+ case "Illustrations":
+ sortID = BM_ILLUSTRATIONS
+ }
+ SearchModel.sumOfBitmasks = sortID, console.log("SearchController changed, selected, bm: ", SearchModel.sumOfBitmasks), $scope.$root.$emit("media filter change", sortID), $scope.search()
+ }, $scope.setCurrent = function(val) {
+ $scope.obj.selected = val
+ }, $scope.toggled = function(open) {
+ $scope.obj.direction = open ? "dropup" : "down"
+ }, $scope.search = function() {
+ var query = document.getElementById("search").value;
+ "Search Pond5..." === query && (query = "");
+ var ga = {
+ ec: "search"
+ };
+ ga.ea = $scope.obj.selected.replace(/ /g, "%20"), ga.el = query.replace(/ /g, "%20"), AnalyticsService.sendData(ga), SearchModel.query = query, SearchModel.resultType = "replace", SearchModel.page = 0, SearchModel.sumOfBitmasks === BM_PUBLIC_DOMAIN && (SearchModel.query = SearchModel.query + " editorial:1"), console.log("SearchController search: ", query, SearchModel.sumOfBitmasks, SearchModel.resultType, SearchModel.page), ViewStateService.viewRequested("search")
+ }, $scope.searchButtonClicked = function() {
+ $scope.search()
+ }, $scope.enterThis = function() {
+ 13 === event.keyCode && $scope.search()
+ }, $scope.onSearchIconClicked = function() {
+ ViewStateService.viewRequested("search")
+ }
+});
+var SellController = function($scope, AnalyticsService) {
+ $scope.sellClicked = function() {
+ var ga = {
+ ec: "sell%20media"
+ };
+ console.log("SellController ga", ga), AnalyticsService.sendData(ga), opn("https://www.pond5.com/index.php?page=my_uploads")
+ }
+};
+SellController.$inject = ["$scope", "AnalyticsService"], app.controller("SidebarController", function($scope, ViewStateModel, ViewStateService, AnalyticsService) {
+ $scope.obj = {
+ view: "search"
+ }, $scope.viewStateModel = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewStateModel, function() {
+ $scope.obj.view = ViewStateModel.getState()
+ }), $scope.onDownloadsIconClicked = function() {
+ $scope.$root.$emit("views requested", "downloads"), ViewStateService.viewRequested("downloads");
+ var ga = {
+ ec: "downloads"
+ };
+ AnalyticsService.sendData(ga)
+ }, $scope.onPreviewsIconClicked = function() {
+ ViewStateService.viewRequested("previews");
+ var ga = {
+ ec: "imported%20previews"
+ };
+ AnalyticsService.sendData(ga)
+ }, $scope.onDestinationIconClicked = function() {
+ $scope.$root.$emit("modal add destination requested");
+ var ga = {
+ ec: "add%20destination"
+ };
+ AnalyticsService.sendData(ga)
+ }
+}), app.controller("SubTopRowController", function($scope, ViewStateModel, BinsModel, SearchModel, CartModel, PurchasesModel, UserModel, AnalyticsService) {
+ function onViewStateChange() {
+ var title;
+ switch (ViewStateModel.getState()) {
+ case "downloads":
+ title = "MY DOWNLOADS";
+ break;
+ case "previews":
+ title = "MY IMPORTED PREVIEWS";
+ break;
+ case "cart":
+ title = "MY CART";
+ break;
+ case "freebies":
+ title = "50 FREE MEDIA CLIPS";
+ break;
+ case "bins":
+ console.log("SubTopRowController selected bin name:", BinsModel.showBin.name), title = "COLLECTION: " + BinsModel.showBin.name;
+ break;
+ case "search":
+ title = 0 < SearchModel.query.length ? SearchModel.query.toUpperCase() : "";
+ break;
+ default:
+ title = ""
+ }
+ $scope.obj.title = title, "search" == ViewStateModel.getState() ? $scope.obj.showDropdown = !0 : $scope.obj.showDropdown = !1, "cart" == ViewStateModel.getState() ? $scope.obj.showCreditsWrapper = !0 : $scope.obj.showCreditsWrapper = !1, $scope.showClearAll()
+ }
+ $scope.obj = {
+ showFilters: !1,
+ titleClass: "sub-top-row-title-no-filters",
+ showClearAll: !1,
+ showDropdown: !0,
+ showCreditsWrapper: !1,
+ credits: 0
+ }, $scope.$root.$on("on cart total", function(event) {
+ $scope.obj.credits = CartModel.getCartTotal().creditsData.availableSum
+ }), $scope.cartModel = function() {
+ return CartModel.cartVO
+ }, $scope.$watch($scope.cartModel, function() {
+ $scope.showClearAll()
+ }), $scope.$root.$on("bin selected", function(event) {
+ onViewStateChange()
+ }), $scope.viewStateModelQuery = function() {
+ return SearchModel.query
+ }, $scope.$watch($scope.viewStateModelQuery, onViewStateChange), $scope.viewStateModel = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewStateModel, onViewStateChange), $scope.showClearAll = function() {
+ "cart" == ViewStateModel.getState() && 0 < CartModel.cartVO.items.length ? $scope.obj.showClearAll = !0 : $scope.obj.showClearAll = !1
+ }, $scope.$root.$on("filters button clicked", function(event, state) {
+ $scope.obj.titleClass = state ? "sub-top-row-title-filters" : "sub-top-row-title-no-filters"
+ }), $scope.onClearCartClicked = function() {
+ if (0 != CartModel.cartVO.items.length) {
+ for (var ids = "", i = 0; i < CartModel.cartVO.items.length; i++) i < CartModel.cartVO.items.length ? ids += CartModel.cartVO.items[i].id + "," : ids += CartModel.cartVO.items[i].id;
+ $scope.$root.$emit("clear cart requested", [ids])
+ }
+ }, $scope.buyCreditsClicked = function() {
+ var ga = {
+ ec: "buy%20credits"
+ };
+ console.log("CreditsController ga", ga), AnalyticsService.sendData(ga), $scope.$root.$emit("modal buy credits requested"), console.log("SubTopRowController button clicked")
+ }
+}), app.controller("TileListItemController", function($scope, Service, BinsModel, ImportedPreviewsService, ViewStateModel, LoginModel, ReplaceModel, DownloadModel) {
+ $scope.childObj = {}, $scope.childObj.addedToCart = !1, $scope.childObj.addedToBin = !1, $scope.allowDownload = !0, $scope.childObj.cartClicked = !1, $scope.childObj.binClicked = !1, $scope.childObj.showEditorial = !0, $scope.childObj.viewState = "search", $scope.childObj.notification = "", "FCPX" === HOST_NAME ? $scope.childObj.importTooltip = "CLICK TO DOWNLOAD" : $scope.childObj.importTooltip = "CLICK TO IMPORT", $scope.viewState = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewState, function() {
+ $scope.childObj.viewState = ViewStateModel.getState()
+ }, !0), $scope.$root.$on("added to cart", function(event) {
+ $scope.childObj.cartClicked && ($scope.childObj.addedToCart = !0), setTimeout(function() {
+ $scope.childObj.cartClicked = !1, $scope.childObj.addedToCart = !1
+ }, 1e3)
+ }), $scope.$root.$on("added to bin", function(event) {
+ $scope.childObj.binClicked && ($scope.childObj.addedToBin = !0), setTimeout(function() {
+ $scope.childObj.binClicked = !1, $scope.childObj.addedToBin = !1
+ }, 1e3)
+ }), $scope.itemHovered = function(e) {
+ $scope.childObj.showMenu = !0, $scope.$root.$emit("start preview", $scope.item, e.clientX)
+ }, $scope.itemLeft = function() {
+ $scope.childObj.showMenu = !1, $scope.$root.$emit("stop preview", $scope.item)
+ }, $scope.opaqueClicked = function() {
+ console.log("TileListItemController opaqueClicked", $scope.allowDownload), $scope.allowDownload && ($scope.allowDownload = !1, $scope.$root.$emit("download requested", [$scope.item]), ImportedPreviewsService.saveItem($scope.item.id), $scope.$root.$emit("stop preview", $scope.item)), setTimeout(function() {
+ $scope.allowDownload = !0
+ }, 2e3)
+ }, $scope.overInfoIcon = function() {
+ $scope.$root.$emit("preview info icon over")
+ }, $scope.outInfoIcon = function() {
+ $scope.$root.$emit("preview info icon out")
+ }, $scope.binIconClicked = function() {
+ console.log("TileListItemController binIconClicked"), LoginModel.loggedIn ? 0 < BinsModel.bins.length ? (console.log("TileListItemController binIconClicked show notification"), Service.modifyBin(BinsModel.addToBin.id, $scope.item.id), $scope.childObj.notification = "Added to the collection!", $scope.childObj.binClicked = !0, setTimeout(function() {
+ $scope.childObj.binClicked = !1, $scope.childObj.addedToBin = !1
+ }, 4e3), $scope.childObj.binClicked = !0) : $scope.$root.$emit("modal simple requested", ["You don't have Collections", "In order to add clips to a Collection you first need to create a Collection"]) : $scope.$root.$emit("modal not logged in", [ERROR])
+ }, $scope.cartIconClicked = function() {
+ $scope.childObj.notification = "Added to the cart successfully!", $scope.childObj.cartClicked = !0, setTimeout(function() {
+ $scope.childObj.cartClicked = !1, $scope.childObj.addedToCart = !1
+ }, 4e3), Service.getFormats($scope.item)
+ }, $scope.trashIconClicked = function() {
+ $scope.$root.$emit("stop preview", $scope.item), "bins" === ViewStateModel.getState() ? Service.modifyBin(BinsModel.binVO.id, "", $scope.item.id) : "previews" === ViewStateModel.getState() && ImportedPreviewsService.deleteItem($scope.item.id)
+ }, $scope.linkClicked = function() {
+ opn("https://www.pond5.com/item/" + $scope.item.id)
+ }
+}), app.controller("TileListSearchController", function($scope, SearchModel, Service) {
+ $scope.obj = {
+ showDeleteIcon: !1
+ }, $scope.searchItems = function() {
+ if (SearchModel.searchResultVO) return SearchModel.searchResultVO.items
+ }, $scope.$watch($scope.searchItems, function() {
+ SearchModel.searchResultVO && ($scope.obj.items = SearchModel.searchResultItems)
+ })
+}), app.controller("TileListPreviewsController", function($scope, PreviewsModel) {
+ $scope.obj = {
+ showDeleteIcon: !0
+ }, $scope.previewItems = function() {
+ if (PreviewsModel.previewsVO) return PreviewsModel.previewsVO.items
+ }, $scope.$watch($scope.previewItems, function() {
+ if (PreviewsModel.previewsVO) {
+ console.log("TileListPreviewsController: ", PreviewsModel.previewsVO), PreviewsModel.previewsVO.items.reverse();
+ for (var previews = PreviewsModel.previewsVO.items, nonAEpreviews = [], i = 0; i < previews.length; i++) "AE" != previews[i].type && nonAEpreviews.push(previews[i]);
+ $scope.obj.items = nonAEpreviews
+ }
+ })
+}), app.controller("TileListBinsController", function($scope, BinsModel) {
+ $scope.obj = {
+ showDeleteIcon: !0
+ }, $scope.binItems = function() {
+ if (BinsModel.binVO) return BinsModel.getBinVO()
+ }, $scope.$watch($scope.binItems, function() {
+ BinsModel.binVO && ($scope.obj.items = BinsModel.binVO.items)
+ }, !0)
+}), app.controller("TileListFreebiesController", function($scope, FreebiesModel) {
+ $scope.obj = {
+ showDeleteIcon: !1
+ }, $scope.freeItems = function() {
+ if (FreebiesModel.freebiesVO) return FreebiesModel.freebiesVO.items
+ }, $scope.$watch($scope.freeItems, function() {
+ FreebiesModel.freebiesVO && ($scope.obj.items = FreebiesModel.freebiesVO.items)
+ })
+}), app.controller("TransactionController", function($scope, ViewStateModel, ViewStateService, Service, AnalyticsService, CheckOutModel, ReplaceModel) {
+ $scope.obj = {
+ url: "",
+ show: !1
+ }, $scope.CheckOutModel = function() {
+ return CheckOutModel
+ }, $scope.$watch($scope.CheckOutModel, function() {
+ if (CheckOutModel.checkOutURL) {
+ (new Date).getTime();
+ $scope.obj.url = CheckOutModel.checkOutURL, $scope.obj.show = !0, CheckOutModel.checkOutURL = "", $("body,html").css("overflow", "hidden")
+ }
+ }, !0), window.parent.addEventListener("message", function() {
+ switch (ViewStateModel.allowPreviews = !0, console.log("TransactionController postMessage: ", event.data), event.data) {
+ case "PAID":
+ ReplaceModel.getState() === NOT_PURCHASED ? Service.getPurchases() : ($scope.$root.$emit("modal simple requested", PURCHASE_SUCCESSFULL), ViewStateService.viewRequested("downloads")), $scope.$root.$emit("purchase complete"), Service.getUserInfo(), console.log("TransactionController CC payment success");
+ break;
+ case "CANCELED":
+ $scope.$root.$emit("modal simple requested", PURCHASE_CANCELED);
+ break;
+ default:
+ $scope.$root.$emit("modal simple requested", [ERROR, "UNKNOWN"])
+ }
+ $scope.obj.show = !1, console.log("TransactionController onDone, show:", $scope.obj.show), $scope.$root.$emit("checkout complete"), $("body,html").css("overflow", "visible")
+ }, !1)
+}), app.directive("enter", function() {
+ return function(scope, element, attrs) {
+ element.bind("keydown", function() {
+ 13 === event.which && scope.$apply(attrs.enter)
+ })
+ }
+}), app.directive("enterFooter", function() {
+ return function(scope, element, attrs) {
+ element.bind("mouseenter", function() {
+ element.children()[0].style.color = "#ccc"
+ })
+ }
+}), app.directive("leaveFooter", function() {
+ return function(scope, element, attrs) {
+ element.bind("mouseleave", function() {
+ element.children()[0].style.color = "#969493"
+ })
+ }
+}), app.directive("repositionImage", function() {
+ return {
+ restrict: "A",
+ link: function(scope, elem, attrs) {
+ elem.on("load", function() {
+ 108 < $(this).height() && elem.addClass("high")
+ })
+ }
+ }
+}), app.directive("rotate", function() {
+ return {
+ restrict: "A",
+ link: function(scope, element, attrs) {
+ scope.$watch(attrs.rotate, function(dir) {
+ var r = "rotate(" + ("up" === dir ? 180 : 0) + "deg)";
+ element.css({
+ "-webkit-transform": r
+ })
+ })
+ }
+ }
+}), app.directive("whenScrolled", ["$window", "ScrollService", function($window, ScrollService) {
+ return function(scope, elm, attr) {
+ elm[0];
+ angular.element($window).bind("scroll", function() {
+ ScrollService.onScroll()
+ })
+ }
+}]), app.directive("scrollTop", [function() {
+ return {
+ restrict: "A",
+ link: function(scope, $elm, attr) {
+ scope.$root.$on("scroll progress to top", function() {
+ $elm.animate({
+ scrollTop: 0
+ }, "slow")
+ })
+ }
+ }
+}]), app.directive("dragMe", function() {
+ return {
+ restrict: "A",
+ link: function(scope, elem, attr, ctrl) {
+ elem.draggable()
+ }
+ }
+}), app.directive("onHoverInfoCart", function() {
+ return {
+ link: function(scope, element, attrs) {
+ element.bind("mouseenter", function($event) {
+ initialMouseX = $event.clientX, initialMouseY = $event.clientY, scope.$root.$emit("cart icon over", initialMouseX, initialMouseY)
+ }), element.bind("mouseleave", function() {
+ scope.$root.$emit("cart icon out")
+ })
+ }
+ }
+}), app.directive("onHoverPreview", function() {
+ return {
+ link: function(scope, element, attrs) {
+ element.bind("mouseenter", function($event) {
+ var previewX, previewY, tileX = element[0].getBoundingClientRect().left;
+ previewX = tileX < 310 ? tileX + 220 : tileX - 400, (previewY = element[0].getBoundingClientRect().top - 200) < 20 && (previewY = 20), 340 < previewY && (previewY = 340);
+ var cols = document.getElementsByClassName("preview");
+ for (i = 0; i < cols.length; i++) cols[i].style.left = previewX.toString() + "px", cols[i].style.top = previewY.toString() + "px"
+ })
+ }
+ }
+}), app.filter("to_trusted", ["$sce", function($sce) {
+ return function(text) {
+ return $sce.trustAsHtml(text)
+ }
+}]), app.filter("trusted", ["$sce", function($sce) {
+ return function(url) {
+ return $sce.trustAsResourceUrl(url)
+ }
+}]), app.filter("secondsToDateTime", [function() {
+ return function(seconds) {
+ return new Date(1970, 0, 1).setSeconds(seconds)
+ }
+}]), app.directive("closeCollectionsList", function($document) {
+ return {
+ restrict: "A",
+ link: function(scope, elem, attr, ctrl) {
+ elem.bind("click", function(e) {
+ e.stopPropagation()
+ }), $document.bind("click", function() {
+ scope.$apply(attr.closeCollectionsList)
+ })
+ }
+ }
+}), app.directive("fieldValidation", function() {
+ return {
+ require: "ngModel",
+ link: function(scope, element, attr, mCtrl) {
+ mCtrl.$parsers.push(function(value) {
+ return /^\w+$/.test(value) && 1 < value.toString().length || 0 == value.toString().length ? (mCtrl.$setValidity("charE", !0), console.log("directive valid true")) : (mCtrl.$setValidity("charE", !1), console.log("directive valid false")), value
+ })
+ }
+ }
+}), app.directive("vatValidation", function() {
+ return {
+ require: "ngModel",
+ link: function(scope, element, attr, mCtrl) {
+ mCtrl.$parsers.push(function(value) {
+ return /^\w+$/.test(value) && 2 < value.toString().length || 0 == value.toString().length ? (mCtrl.$setValidity("charE", !0), console.log("directive valid true")) : (mCtrl.$setValidity("charE", !1), console.log("directive valid false")), value
+ })
+ }
+ }
+}), app.directive("restrictInput", [function() {
+ return {
+ restrict: "A",
+ link: function(scope, element, attrs) {
+ var ele = element[0],
+ regex = RegExp(attrs.restrictInput),
+ value = ele.value;
+ ele.addEventListener("keyup", function(e) {
+ regex.test(ele.value) ? value = ele.value : ele.value = value
+ })
+ }
+ }
+}]), app.filter("searchFilter", function() {
+ return function(input, param1) {
+ if (console.log("------------------------------------------------- begin dump of custom parameters"), console.log("searchFilter input: ", input), input && input.length) {
+ console.log("searchFilter param1: ", param1);
+ var filteredItems = [];
+ for (i = 0; i < input.length; i++) input[i].fps == param1 && filteredItems.push(input[i]);
+ return filteredItems
+ }
+ }
+}), PURCHASE_SUCCESSFULL = ["Your purchase has been successfull!", "Your items are now ready to download."], PURCHASE_CANCELED = ["Canceled.", "Purchase was canceled."], ERROR = "Oops, something went wrong...", NO_RESULTS = ["Your search returned no results", "
Try adjusting your filters Check your search term for misspelling or try a few synonyms "], BM_VIDEO = 15, BM_MUSIC = 16, BM_SFX = 32, BM_PHOTO = 128, BM_ILLUSTRATIONS = 1024, BM_AFTER_EFFECTS = 64, BM_PUBLIC_DOMAIN = 16384, MODE = "live", THIRD_PARTY = "", TARGET_APP = "", GA_TRACKING_CODE = "UA-60083218-9", DEFAULT = "not replacing", MISSING_ITEMS = "missing items", NOT_PURCHASED = "not purchased", NOT_DOWNLOADED = "not downloaded", PURCHASED_AND_DOWNLOADED = "purchased and downloaded";
+var BASE_URL = "https://plugin.pond5.com/",
+ NO_RESULTS_ICON = BASE_URL + "pond5_shared/images/no_results_icon.png",
+ DRAGNDROP_IMG = BASE_URL + "pond5_shared/images/intro-icons/dragndrop.png",
+ STATE_IMG = BASE_URL + "pond5_shared/images/intro-states/step",
+ STATE_FCP_IMG = BASE_URL + "pond5_shared/images/intro-states-fcp/step",
+ DOWNLOAD_IMG = BASE_URL + "pond5_shared/images/intro-icons/download.png",
+ CART_IMG = BASE_URL + "pond5_shared/images/intro-icons/cart.png",
+ PREVIEWS_IMG = BASE_URL + "pond5_shared/images/intro-icons/previews.png",
+ DUMMY_IMG = BASE_URL + "pond5_shared/images/intro-icons/dummy.png",
+ CLEAR_CART_TRASH_IMG = BASE_URL + "pond5_shared/images/clear-cart-trash-icon.png",
+ CART_BUTTON_IMG = BASE_URL + "pond5_shared/images/cartButtonIcon.png",
+ PROGRESS_CLOSE_IMG = BASE_URL + "pond5_shared/images/progress-close-icon.png",
+ LOGO_IMG = BASE_URL + "pond5_shared/images/logo-white.png",
+ MODAL_SIMPLE_HTML = BASE_URL + "pond5_shared/views/modals/modalSimple.html",
+ MODAL_ADD_DESTINATION_HTML = BASE_URL + "pond5_shared/views/modals/modalAddDestination.html",
+ MODAL_ADD_COLLECTION_HTML = BASE_URL + "pond5_shared/views/modals/modalAddCollection.html",
+ MODAL_ADD_COLLECTION_CONFIRMATION_HTML = BASE_URL + "pond5_shared/views/modals/modalAddCollectionConfirmation.html",
+ MODAL_SELECT_SEQUENCES_HTML = BASE_URL + "pond5_shared/views/modals/modalSelectSequences.html",
+ MODAL_INTRO_HTML = BASE_URL + "pond5_shared/views/modals/modalIntro.html",
+ MODAL_ADD_TO_CART_HTML = BASE_URL + "pond5_shared/views/modals/modalAddToCart.html",
+ MODAL_BILLING_ADDRESS_HTML = BASE_URL + "pond5_shared/views/modals/modalBillingAddress.html",
+ MODAL_CHOOSE_BILLING_INFO_HTML = BASE_URL + "pond5_shared/views/modals/modalChooseBillingInfo.html",
+ MODAL_CHOOSE_FORMAT_HTML = BASE_URL + "pond5_shared/views/modals/modalChooseFormat.html",
+ MODAL_CHOOSE_VERSION_HTML = BASE_URL + "pond5_shared/views/modals/modalChooseVersion.html",
+ MODAL_FREEBIES_HTML = BASE_URL + "pond5_shared/views/modals/modalFreebies.html",
+ MODAL_LOGIN_HTML = BASE_URL + "pond5_shared/views/modals/modalLogin.html",
+ MODAL_NOT_LOGGED_IN_HTML = BASE_URL + "pond5_shared/views/modals/modalNotLoggedIn.html",
+ MODAL_PROMO_CODE_HTML = BASE_URL + "pond5_shared/views/modals/modalPromoCode.html",
+ MODAL_REMOVE_COLLECTION_HTML = BASE_URL + "pond5_shared/views/modals/modalRemoveCollection.html",
+ MODAL_REPLACE_HTML = BASE_URL + "pond5_shared/views/modals/modalReplace.html",
+ MODAL_REPLACE_WARNING_HTML = BASE_URL + "pond5_shared/views/modals/modalReplaceWarning.html",
+ MODAL_BUY_CREDITS_HTML = BASE_URL + "pond5_shared/views/modals/modalBuyCredits.html",
+ COLLECTIONS_LIST_HTML = BASE_URL + "pond5_shared/views/collectionsList.html";
+$(function() {
+ Offline.options = {
+ checkOnLoad: !0,
+ checks: {
+ image: {
+ url: function() {
+ return "https://plugin.pond5.com/pond5_shared/images/logo-white.png?_=" + Math.floor(1e9 * Math.random())
+ }
+ },
+ active: "image"
+ }
+ }
+}), app.service("AppModel", ["$rootScope", function($rootScope) {
+ var path = require("path"),
+ dirHomePond5 = getUserHome() + path.sep + "pond5",
+ dirImports = dirHomePond5 + path.sep + "imports",
+ dirPrefs = dirHomePond5 + path.sep + "prefs",
+ dirDestinations = dirHomePond5 + path.sep + "destinations",
+ dirDefaultLib = path.sep,
+ dirUser = dirHomePond5 + path.sep + "user",
+ result = (dirDefaultLib = dirHomePond5 + path.sep + "defaultLib", {
+ OS: "",
+ baseFolders: [],
+ currentBaseFolder: "",
+ previewsDir: "",
+ purchasedDir: "",
+ defaultLib: "",
+ defaultLibName: "",
+ defaultLibPath: "",
+ targetApp: "",
+ setEnv: function() {
+ result.setOS(os.platform()), $rootScope.$emit("environment set")
+ },
+ getOS: function() {
+ return result.OS
+ },
+ setOS: function(s) {
+ result.OS = s
+ },
+ getDocumentsPath: function() {
+ return os.homedir() + path.sep + "Documents"
+ },
+ getDirHomePond5: function() {
+ return dirHomePond5
+ },
+ getDirImports: function() {
+ return dirImports
+ },
+ getDirDestinations: function() {
+ return dirDestinations
+ },
+ getDirPrefs: function() {
+ return dirPrefs
+ },
+ getDirUser: function() {
+ return dirUser
+ },
+ getDestinationsXML: function() {
+ return result.getDirDestinations() + path.sep + "destinations.xml"
+ },
+ getUserXML: function() {
+ return result.getDirUser() + path.sep + "user.xml"
+ },
+ getPreferencesXML: function() {
+ return result.getDirPrefs() + path.sep + "preferences.xml"
+ },
+ getDirDefaultLib: function() {
+ return dirDefaultLib
+ },
+ getDefaultLib: function() {
+ return result.defaultLib
+ },
+ setDefaultLib: function(path) {
+ "/" == path.substr(path.length - 1) && (path = path.slice(0, -1)), result.setDefaultLibName(path), result.setDefaultLibPath(path), result.defaultLib = path
+ },
+ getDefaultLibName: function() {
+ return result.defaultLibName
+ },
+ setDefaultLibName: function(path) {
+ var n = path.lastIndexOf("/");
+ result.defaultLibName = path.substring(n + 1).replace(".fcpbundle", "")
+ },
+ getDefaultLibPath: function() {
+ return result.defaultLibPath
+ },
+ setDefaultLibPath: function(path) {
+ result.defaultLibPath = path.substring(0, path.lastIndexOf("/"))
+ },
+ getDefaultLibXML: function() {
+ return result.getDirDefaultLib() + path.sep + "defaultLib.xml"
+ },
+ getTargetApp: function() {
+ return result.targetApp
+ },
+ setTargetApp: function(app) {
+ result.targetApp = app
+ }
+ });
+ return result
+}]), app.factory("BillingInfoModel", ["$rootScope", function($rootScope) {
+ var info = {
+ onBillingInfo: function(data) {
+ info.setBillingInfo(data.commands[0]), info.getBillingInfo().forEach(function(item) {
+ item.isdefault && info.setDefaultInfo(item)
+ })
+ },
+ setBillingInfo: function(data) {
+ info.billingInfo = data
+ },
+ getBillingInfo: function() {
+ return info.billingInfo
+ },
+ setDefaultInfo: function(data) {
+ info.defaultInfo = data
+ },
+ getDefaultInfo: function() {
+ return info.defaultInfo
+ }
+ };
+ return info
+}]), app.service("BinsModel", ["$rootScope", function($rootScope) {
+ var result = {
+ binsVO: null,
+ bins: [],
+ binVO: null,
+ showBin: null,
+ addToBin: null,
+ onBins: function(data) {
+ result.binsVO = new BinsVO(data.commands[0]), result.bins = result.binsVO.bins, $rootScope.$emit("onBins")
+ },
+ onBin: function(data) {
+ result.setBinVO(new BinVO(data.commands[0]))
+ },
+ onActiveBin: function(data) {
+ result.bins.forEach(function(bin) {
+ bin.id == data.commands[0].binid && (result.addToBin = bin)
+ }), $rootScope.$emit("active bin changed", result.addToBin)
+ },
+ setBinVO: function(data) {
+ result.binVO = data
+ },
+ getBinVO: function() {
+ return result.binVO
+ }
+ };
+ return result
+}]);
+var BinsVO = function BinsVO(data) {
+ var i;
+ for (this.bins = [], i = 0; i < data.bins.length; i += 1) {
+ var bin = {};
+ bin.name = data.bins[i].name, bin.abbrBinName = getAbbrName(bin.name, 17), bin.id = data.bins[i].id, bin.total = data.bins[i].tot, bin.selected = !1, this.bins[i] = bin
+ }
+ this.bins.sort(compare), BinsVO.prototype = {
+ toString: function() {
+ console.log("bins: " + this.bins)
+ }
+ }
+ },
+ BinVO = function BinVO(data) {
+ var itemVO, i;
+ this.items = [], this.id = data.binid, this.name = data.name, this.jpegBase = "http://ec.pond5.com/s3/", console.log("BinVO id: ", data.binid, data.name);
+ var filterVS = 0;
+ for (filterVS = "AEFT" == HOST_NAME ? 200 : 102, i = 0; i < data.items.length; i += 1) parseInt(data.items[i].vs) <= filterVS && (itemVO = new ItemVO(data.items[i], data.icon_base, data.flv_base, "", this.jpegBase), this.items.push(itemVO));
+ BinVO.prototype = {
+ toString: function() {
+ console.log("name & id: ", this.id, this.name)
+ }
+ }
+ };
+app.factory("CartModel", ["$rootScope", "ReplaceModel", function($rootScope, ReplaceModel) {
+ $rootScope.$on("on cart", function(event, data) {
+ result.onCart(data)
+ }), $rootScope.$on("on cart total", function(event, data) {
+ result.onCartTotal(data)
+ }), $rootScope.$on("formats complete", function(event, item, formats) {
+ console.log("CartModel onCart ReplaceModel.getState(): ", ReplaceModel.getState()), result.onFormats(item, formats)
+ });
+ var result = {
+ cartVO: [],
+ cartTotal: null,
+ onCart: function(data) {
+ result.cartVO = new ItemsVO(data.commands[0])
+ },
+ onCartTotal: function(data) {
+ result.setCartTotal(data.commands[0])
+ },
+ onFormats: function(item, formats) {
+ if (console.log("CartModel onFormats, num of formats for id: ", item, formats.length), 1 < formats.length) {
+ var uniqueResFormats = _.uniq(formats, function(p) {
+ return p.ti
+ });
+ $rootScope.$emit("on add to cart clicked", uniqueResFormats)
+ } else {
+ var apiObj = {
+ fn: "modifyCart",
+ args: [item.id, ""]
+ };
+ $rootScope.$emit("api call", apiObj)
+ }
+ },
+ setCartTotal: function(data) {
+ result.cartTotal = data
+ },
+ getCartTotal: function() {
+ return result.cartTotal
+ }
+ };
+ return result
+}]), app.factory("CheckOutModel", ["$sce", function($sce) {
+ var result = {
+ onPurchase: function(data) {
+ console.log("CheckOutModel onPurchase, url: ", data.commands[0].url);
+ (new Date).getTime();
+ result.checkOutURL = $sce.trustAsResourceUrl(data.commands[0].url), console.log("CheckOutModel onPurchase, url: ", result.checkOutURL)
+ }
+ };
+ return result
+}]), app.factory("DownloadModel", ["$rootScope", "PurchasesModel", "ReplaceModel", function($rootScope, PurchasesModel, ReplaceModel) {
+ var result = {
+ binBatch: null,
+ itemsDownloadList: [],
+ selectedVersion: 0,
+ downloadingBatchURLs: !1,
+ urlCounter: 0,
+ downloadCounter: -1,
+ stayAwake: !1,
+ onGetPurchaseURL: function(data) {
+ var item = result.getVersionByID(data.commands[0].bid);
+ item && (item.hiresURL = data.commands[0].url, item.downloadType = "purchase", "AE" == item.vs && (item.type = item.vs), $rootScope.$emit("download requested", [item]))
+ },
+ onGetAllPurchaseURLs: function(data) {
+ var i, purchase, purchases = [];
+ for (ReplaceModel.getState() === DEFAULT ? purchases = PurchasesModel.purchasesVO.items : ReplaceModel.getState() === NOT_DOWNLOADED && (purchases = ReplaceModel.missingDownloads), result.urlCounter++, i = 0; i < purchases.length; i += 1) {
+ purchase = purchases[i];
+ var dataItem = data.commands[0];
+ for (k = 0; k < purchase.formats.length; k += 1) purchase.formats[k].id == dataItem.bid && (purchase.hiresURL = dataItem.url, purchase.downloadType = "purchase");
+ purchase.id == dataItem.bid && (purchase.hiresURL = dataItem.url, purchase.downloadType = "purchase", purchase.versions && 0 < purchase.versions.length && (purchase.vs = purchase.versions[0].vs))
+ }
+ purchases = purchases.filter(function(v, i, a) {
+ return a.indexOf(v) == i
+ }), result.urlCounter === purchases.length && ($rootScope.$emit("download requested", purchases), result.urlCounter = 0, result.downloadingBatchURLs = !1)
+ },
+ getVersionByID: function(id) {
+ var foundItem;
+ if (PurchasesModel.purchasesVO.items.forEach(function(item) {
+ item.id === id && (item.parentFormatID && (item.versions[result.selectedVersion].parentFormatID = item.parentFormatID), foundItem = item.versions[result.selectedVersion])
+ }), foundItem) return foundItem
+ }
+ };
+ return result
+}]), app.factory("FreebiesModel", [function() {
+ var result = {
+ onFreebies: function(data) {
+ result.freebiesVO = new ItemsVO(data.commands[0])
+ }
+ };
+ return result
+}]);
+var HiresVO = function HiresVO(dest, name) {
+ this.dest = dest, this.name = name, this.path = dest + name, this.id = name.split(" ")[1], this.replace = !1, this.type = "", this.nameFCP = this.name.replaceAll(" ", "%20"), this.nameFCP = this.nameFCP.replaceAll("-", "%2D"), this.nameFCP = this.nameFCP.replaceAll("&", "and"), this.pathFCP = "file://" + this.path.replaceAll(" ", "%20"), this.pathFCP = this.pathFCP.replaceAll("-", "%2D"), this.pathFCP = this.pathFCP.replaceAll("&", "and"), HiresVO.prototype = {
+ toString: function() {
+ return "\nHiresVO path: " + this.path + "\nname: " + this.name + "\nid: " + this.id + "\nreplace: " + this.replace
+ }
+ }
+ },
+ ItemsVO = function ItemsVO(data) {
+ var itemVO, i;
+ for (this.tot_nbr_rows = data.tot_nbr_rows, this.max_per_page = data.max_per_page, this.nbr_footage = data.nbr_footage, this.nbr_music = data.nbr_music, this.nbr_sfx = data.nbr_sfx, this.nbr_total = data.nbr_total, this.items = [], i = 0; i < data.items.length; i += 1) itemVO = new ItemVO(data.items[i], data.icon_base, data.flv_base, ""), this.items[i] = itemVO;
+ ItemsVO.prototype = {
+ toString: function() {
+ console.log("vs: " + this.vs)
+ }
+ }
+ },
+ ItemVO = function ItemVO(data, iconBase, flvBase, parentID) {
+ var getURL;
+ this.selectedVersion = 0, this.name = data.n, this.abbrName = getAbbrName(this.name, 25), this.abbrTileName = getAbbrName(this.name, 22), this.abbrListName = getAbbrName(this.name, 40), this.artistName = getAbbrName(data.artistname, 40), this.id = data.id, this.title = data.ti, this.vr360 = data.vr360, data.pr < .001 ? this.price = "0" : this.price = data.pr, this.priceRange = data.pricerange, this.vs = getConvertedVideoStandard(data.vs), this.downloadType = "preview", this.downloadURL, this.downloadDestination = "", this.downloading = !1, this.progressPerc = "", this.progressMB = "", this.progressName = "", this.parentFormatID = "", this.canceled = !1, this.completed = !1, this.imported = !1, this.inCart = !1, this.inDownloads = !1, this.selected = !1, this.formats = [], this.versions = [], this.ox = data.ox, this.oy = data.oy, this.ar = getAspectRatio(data.ar), this.ar || (this.ar = "n/a"), this.aq = data.aq, this.dur = data.dur, data.fps ? this.fps = data.fps : this.fps = "n/a", data.ti && (this.title = data.ti), data.tb && (this.subTitle = data.tb), data.i && (this.additionalInfo = data.i), data.id ? this.id = data.id : this.id = parentID, 0 === this.id.length && (this.id = parentID), this.offset = data.so, this.transactionID = data.tr, this.expirationDate = data.exp, this.versionID = data.v, this.videoCodec = data.codg, this.audioCodec = data.coda, this.extension = data.ext, this.version = data.bitoffset, this.type = getMediaType(this.vs), this.baseURL = flvBase || "https://api-cdn.pond5.com/", getURL = function(id, type, baseURL) {
+ var url;
+ switch (type) {
+ case "icon":
+ url = iconBase + ExtendedID.extend(id) + "_iconv.jpeg";
+ break;
+ case "H264":
+ url = baseURL + ExtendedID.extend(id) + "_main_xl.mp4";
+ break;
+ case "vr360":
+ url = baseURL + ExtendedID.extend(id) + "_main360.mp4";
+ break;
+ case "mov":
+ url = baseURL + ExtendedID.extend(id) + "_prev_264.mov";
+ break;
+ case "flv":
+ url = baseURL + ExtendedID.extend(id) + "_prev_xl.flv";
+ break;
+ case "mp3":
+ url = baseURL + ExtendedID.extend(id) + "_prev.mp3";
+ break;
+ case "m4a":
+ url = baseURL + ExtendedID.extend(id) + "_prev.m4a";
+ break;
+ case "icon large":
+ url = iconBase + ExtendedID.extend(id) + "_iconl.jpeg"
+ }
+ return url
+ }, this.iconURL = getURL(this.id, "icon", this.baseURL), this.iconLargeURL = getURL(this.id, "icon large", this.baseURL), this.vr360 ? this.h264URL = getURL(this.id, "vr360", this.baseURL) : this.h264URL = getURL(this.id, "H264", this.baseURL), this.mp3URL = getURL(this.id, "mp3", this.baseURL), this.m4aURL = getURL(this.id, "m4a", this.baseURL), ItemVO.prototype = {}
+ };
+app.factory("LoginModel", [function() {
+ var data = {
+ getLoggedIn: function() {
+ return data.loggedIn
+ },
+ setLoggedIn: function(state) {
+ data.loggedIn = state
+ },
+ getCX: function() {
+ return data.cx
+ },
+ setCX: function(cx) {
+ data.cx = cx
+ },
+ getCM: function() {
+ return data.cm
+ },
+ setCM: function(cm) {
+ data.cm = cm
+ }
+ };
+ return data
+}]), app.service("MissingItemsModel", [function() {
+ return {
+ missingItemsVO: null
+ }
+}]);
+var MissingItemsVO = function MissingItemsVO(data) {
+ var i;
+ for (this.items = [], i = 0; i < data.items.length; i += 1) this.itemVO = new ItemVO(data.items[i], data.icon_base, data.flv_base), this.items[i] = this.itemVO;
+ MissingItemsVO.prototype = {}
+};
+app.factory("PreviewsModel", [function() {
+ var result = {
+ onPreviews: function(data) {
+ console.log("PreviewsModel onPreviews: ", data), result.previewsVO = new ItemsVO(data.commands[0])
+ }
+ };
+ return result
+}]);
+var PreviewVO = function PreviewVO(dest, path) {
+ var parts = (this.path = path).split("/");
+ this.name = parts[parts.length - 1], this.id = this.name.split(" ")[0], PreviewVO.prototype = {
+ toString: function() {
+ return "\nPreviewVO path: " + this.path + "\nname: " + this.name + "\nid: " + this.id
+ }
+ }
+};
+app.service("PurchasesModel", ["$rootScope", "AnalyticsService", function($rootScope, AnalyticsService) {
+ $rootScope.$on("on purchases", function(event, data) {
+ result.onGetPurchases(data)
+ }), $rootScope.$on("purchase complete", function(event) {
+ console.log("PurchasesModel purchase complete handler"), result.sendGA = !0
+ });
+ var result = {
+ purchasesVO: [],
+ sendGA: !1,
+ onGetPurchases: function(data) {
+ result.purchasesVO = new PurchaseVO(data.commands[0]), $rootScope.$emit("on purchases vo", result.purchasesVO), console.log("PurchasesModel onGetPurchases result.purchasesVO: ", result.purchasesVO), result.sendGA && (AnalyticsService.sendData(result.purchasesVO, "transaction"), result.sendGA = !1)
+ }
+ };
+ return result
+}]);
+var PurchaseVO = function PurchaseVO(data) {
+ var i;
+ this.items = [];
+ for ("AEFT" == HOST_NAME ? 200 : 102, i = 0; i < data.items.length; i += 1) {
+ var j;
+ for (this.itemVO = new ItemVO(data.items[i], data.icon_base, data.flv_base, data.items[i].bid), this.itemVO.transactionID = data.items[i].versions[0].tr, this.itemVO.name = data.items[i].versions[0].n, this.itemVO.abbrName = getAbbrName(this.itemVO.name, 30), this.itemVO.expirationDate = data.items[i].versions[0].exp, this.itemVO.parentFormatID = data.items[i].versions[0].vm, this.itemVO.type = getMediaType(getConvertedVideoStandard(data.items[i].versions[0].vs)), this.itemVO.aq = data.items[i].versions[0].aq, this.itemVO.versionID = data.items[i].versions[0].v, this.itemVO.version = data.items[i].versions[0].bitoffset, j = 0; j < data.items[i].versions.length; j += 1) this.itemVO.versions[j] = new ItemVO(data.items[i].versions[j], data.icon_base, data.flv_base, data.items[i].bid);
+ this.items.push(this.itemVO)
+ }
+ PurchaseVO.prototype = {
+ toString: function() {
+ console.log("name & id: ", this.items)
+ }
+ }
+};
+
+function checkNested(obj) {
+ for (var args = Array.prototype.slice.call(arguments), i = (obj = args.shift(), 0); i < args.length; i++) {
+ if (!obj.hasOwnProperty(args[i])) return !1;
+ obj = obj[args[i]]
+ }
+ return !0
+}
+
+function compare(a, b) {
+ return a.name < b.name ? -1 : a.name > b.name ? 1 : 0
+}
+
+function sortArgs() {
+ return Array.prototype.slice.call(arguments, 0).sort()[0]
+}
+
+function getAspectRatio(as) {
+ var standard;
+ switch (as) {
+ case 1:
+ standard = "4:3";
+ break;
+ case 2:
+ standard = "16:9 anamorphic";
+ break;
+ case 3:
+ standard = "16:9 letterboxed";
+ break;
+ case 4:
+ standard = "n/a";
+ break;
+ case 5:
+ standard = "Other";
+ break;
+ case 6:
+ standard = "16:9 native"
+ }
+ return standard
+}
+
+function convertAspectRatio($max_x, $max_y, $aspect_quotient) {
+ var $out_x, $out_y;
+ return $aspect_quotient ? ($out_y = $max_y, $max_x < ($out_x = Math.round($max_y * parseFloat($aspect_quotient))) && ($out_x = $max_x, $out_y = Math.round($max_x / parseFloat($aspect_quotient))), new Point($out_x, $out_y)) : ($out_x = $max_x, $out_y = $max_y, new Point(370, 208))
+}
+app.factory("ReplaceModel", ["$rootScope", function($rootScope) {
+ var result = {
+ clipsInSequences: [],
+ aeItemsinProjectView: [],
+ state: DEFAULT,
+ missingDownloads: [],
+ hiresOnFS: [],
+ previewsOnFS: [],
+ sequences: [],
+ setState: function(newState) {
+ result.state = newState, console.log("ReplaceModel STATE:", result.state), result.state === DEFAULT && $rootScope.$root.$emit("replacing complete")
+ },
+ getState: function() {
+ return result.state
+ },
+ getAEItems: function() {
+ return result.aeItemsinProjectView
+ },
+ setAEItems: function(items) {
+ result.aeItemsinProjectView = items
+ },
+ setSequenceNames: function(seqNames) {
+ result.sequences = [];
+ for (var i = 0; i < seqNames.length; i++) {
+ var obj = {
+ name: seqNames[i],
+ checked: !1
+ };
+ result.sequences[i] = obj
+ }
+ 0 < seqNames.length ? $rootScope.$root.$emit("modal select sequences", result.sequences) : ($rootScope.$root.$emit("modal simple requested", ["Replace With Hi-Res Clips - Warning", "The 'Replace With Hi-Res clips' button replaces lo-res previews with hi-res clips that you have purchased and downloaded. There are currently no sequences in your project."]), result.setState(DEFAULT))
+ },
+ setSequences: function(sequences) {
+ result.sequences = [];
+ for (var i = 0; i < sequences.length; i++) sequences[i].checked = !1;
+ var newArray = [];
+ newArray.push(sequences[0]);
+ for (i = 1; i < sequences.length; i++) {
+ for (var j = 0; j < newArray.length; j++) newArray[j].name === sequences[i].name && (console.log("already exists ", i, j, sequences[i].name), 0, sequences[i].name = sequences[i].name + " (id: " + sequences[i].id + ")");
+ newArray.push(sequences[i])
+ }
+ result.sequences = newArray, console.log("ReplaceModel, sequences:", result.sequences), 0 < sequences.length ? $rootScope.$root.$emit("modal select sequences", result.sequences) : ($rootScope.$root.$emit("modal simple requested", ["Replace With Hi-Res Clips - Warning", "The 'Replace With Hi-Res clips' button replaces lo-res previews with hi-res clips that you have purchased and downloaded. There are currently no sequences in your project."]), result.setState(DEFAULT))
+ },
+ setComps: function(comps) {
+ result.sequences = comps, $rootScope.$root.$emit("modal select comps", result.sequences)
+ },
+ addHires: function(dest, files) {
+ for (var hiresVO, i = 0; i < files.length; i += 1)(hiresVO = new HiresVO(dest, files[i].fileName)).type = files[i].vs, hiresVO.replace = !0, result.hiresOnFS.push(hiresVO)
+ }
+ };
+ return result
+}]), app.service("SearchModel", ["$rootScope", function($rootScope) {
+ var result = {
+ allowInfiniteScroll: !1,
+ searchResultItems: [],
+ numOfResults: 0,
+ onSearch: function(data) {
+ result.searchResultVO = new ItemsVO(data.commands[0]), result.numOfResults = data.commands[0].nbr_footage + data.commands[0].nbr_music + data.commands[0].nbr_sfx + data.commands[0].nbr_ae, console.log("SearchModel onSearch num of results: ", result.numOfResults), "replace" === result.resultType && (result.searchResultItems = [], window.scrollTo(0, 0), 0 === result.numOfResults ? $rootScope.$emit("message view requested", !0, NO_RESULTS, !0, NO_RESULTS_ICON) : $rootScope.$emit("message view requested", !1));
+ for (var i = 0; i < result.searchResultVO.items.length; i++) result.searchResultItems.push(result.searchResultVO.items[i]);
+ result.isSearching = !1, resizePanel()
+ },
+ sumOfBitmasks: "",
+ query: "",
+ filter: "1",
+ resultType: "replace",
+ page: 0,
+ isSearching: !1,
+ filteredItems: [],
+ fps: "",
+ fpsgt: "",
+ res: "",
+ pricegt: "",
+ pricelt: "",
+ durationgt: "",
+ durationlt: ""
+ };
+ return result
+}]), app.factory("UserModel", [function() {
+ var firstTimeUser = !0,
+ user = {
+ onUserInfo: function(data) {
+ user.setCredits(data.credit), user.setUserName(data.un), user.setFirstName(data.fn), user.setLastName(data.ln), user.setAvatarURL(data.icon_base, data.av)
+ },
+ setCredits: function(num) {
+ user.credits = num
+ },
+ getCredits: function() {
+ return user.credits
+ },
+ setUID: function(uid) {
+ user.uid = uid
+ },
+ getUID: function() {
+ return user.uid
+ },
+ setCM: function(cm) {
+ user.cm = cm
+ },
+ getCM: function() {
+ return user.cm
+ },
+ setCX: function(cx) {
+ user.cx = cx
+ },
+ getCX: function() {
+ return user.cx
+ },
+ setUserName: function(name) {
+ user.userName = name
+ },
+ getUserName: function() {
+ return user.userName
+ },
+ setFirstName: function(name) {
+ user.firstName = name
+ },
+ getFirstName: function() {
+ return user.firstName
+ },
+ setLastName: function(name) {
+ user.lastName = name
+ },
+ getLastName: function() {
+ return user.lastName
+ },
+ setAvatarURL: function(base, url) {
+ user.avatarURL = base + url
+ },
+ getAvatarURL: function() {
+ return user.avatarURL
+ },
+ setFirstTimeUser: function(state) {
+ firstTimeUser = state
+ },
+ getFirstTimeUser: function() {
+ return firstTimeUser
+ }
+ };
+ return user
+}]), app.factory("VersionsModel", ["$rootScope", function($rootScope) {
+ var result = {
+ versions: [],
+ setVersions: function(v) {
+ result.versions = [];
+ for (var i = 0; i < v.length; i++) result.versions[i] = v[i];
+ $rootScope.$emit("on versions selected", result.versions)
+ },
+ getVersions: function() {
+ return result.versions
+ }
+ };
+ return result
+}]), app.factory("ViewStateModel", ["$rootScope", "SearchModel", function($rootScope, SearchModel) {
+ var state;
+ return {
+ allowPreviews: !1,
+ setState: function(s) {
+ state = s, SearchModel.allowInfiniteScroll = "search" === state || ($rootScope.$emit("filters button clicked", !1), !1)
+ },
+ getState: function() {
+ return state
+ }
+ }
+}]), app.service("AnalyticsService", ["$http", "$rootScope", "UserModel", "CartModel", function($http, $rootScope, UserModel, CartModel) {
+ var result = {
+ sendData: function(data, type) {
+ GA_TRACKING_CODE,
+ UserModel.getUID(),
+ UserModel.getUID(),
+ HOST_NAME,
+ PLUGIN_VERSION
+ },
+ send: function(payload) {
+ $http({
+ method: "POST",
+ url: payload
+ }).then(function(response) {
+ console.log("AnalyticsService then: ", response)
+ }, function(response) {
+ console.log("AnalyticsService error: ", response)
+ })
+ }
+ };
+ return result
+}]), app.service("Service", ["$rootScope", "APIService", "LoginModel", "UserModel", "SearchModel", "FreebiesModel", "BinsModel", "ViewStateModel", "DownloadModel", "CheckOutModel", "PreviewsModel", "ReplaceModel", "ViewStateService", "ImportedPreviewsService", "AnalyticsService", "UserService", "BillingInfoModel", function($rootScope, APIService, LoginModel, UserModel, SearchModel, FreebiesModel, BinsModel, ViewStateModel, DownloadModel, CheckOutModel, PreviewsModel, ReplaceModel, ViewStateService, ImportedPreviewsService, AnalyticsService, UserService, BillingInfoModel) {
+ $rootScope.$on("api call", function(event, apiObj) {
+ call[apiObj.fn](sortArgs(apiObj.args))
+ });
+ var call = {
+ login: function() {
+ var obj = [{
+ command: "login",
+ username: arguments[0][0],
+ password: arguments[0][1]
+ }];
+ APIService.call(obj).then(function(data) {
+ LoginModel.setLoggedIn(!0), LoginModel.setCX(data.commands[0].cx), LoginModel.setCM(data.commands[0].cm), UserService.saveData(data.commands[0].cx, data.commands[0].cm), call.getUserInfo()
+ }).catch(function(err) {})
+ },
+ logout: function() {
+ console.log("Service logout");
+ APIService.call([{
+ command: "logout"
+ }]).then(function(data) {
+ LoginModel.setLoggedIn(!1)
+ }).catch(function(err) {})
+ },
+ getUserInfo: function() {
+ APIService.call([{
+ command: "userinfo"
+ }]).then(function(data) {
+ "" != data.commands[0].uid && (UserModel.onUserInfo(data.commands[0]), call.getBins(), setTimeout(function() {
+ call.getCart()
+ }, 1e3), call.getActiveBin(), call.getBillingAddresses(), LoginModel.getLoggedIn() || LoginModel.setLoggedIn(!0))
+ }).catch(function(err) {})
+ },
+ search: function() {
+ var obj = [{
+ command: "search",
+ query: SearchModel.query + SearchModel.res + SearchModel.fps + SearchModel.fpsgt + SearchModel.pricegt + SearchModel.pricelt + SearchModel.durationgt + SearchModel.durationlt,
+ sb: SearchModel.filter,
+ bm: SearchModel.sumOfBitmasks,
+ no: "25",
+ p: SearchModel.page,
+ col: "1523"
+ }];
+ APIService.call(obj).then(function(data) {
+ SearchModel.onSearch(data), ViewStateModel.allowPreviews = !0
+ }).catch(function(err) {})
+ },
+ getFreeClips: function() {
+ APIService.call([{
+ command: "get_free_clips"
+ }]).then(function(data) {
+ FreebiesModel.onFreebies(data)
+ }).catch(function(err) {})
+ },
+ getCart: function() {
+ APIService.call([{
+ command: "get_cart_formatted",
+ artistinfo: "1"
+ }]).then(function(data) {
+ console.log("Service getCart data", data), $rootScope.$emit("on cart", data)
+ }).catch(function(err) {})
+ },
+ getCartTotal: function() {
+ var obj = [{
+ command: "get_cart_total",
+ addressid: BillingInfoModel.getDefaultInfo() ? BillingInfoModel.getDefaultInfo().addressid : "",
+ use_credits: "1"
+ }];
+ APIService.call(obj).then(function(data) {
+ $rootScope.$emit("on cart total", data)
+ }).catch(function(err) {})
+ },
+ getBillingAddresses: function(setState) {
+ APIService.call([{
+ command: "get_billing_addresses"
+ }]).then(function(data) {
+ BillingInfoModel.onBillingInfo(data), setState && $rootScope.$emit("on modal choose billing info requested"), call.getCartTotal()
+ }).catch(function(err) {})
+ },
+ setBillingAddress: function(info) {
+ console.log("Service setBillingAddresses obj:", info);
+ var data = info[0];
+ data.addressID || (data.addressID = "");
+ var obj = [{
+ command: "set_billing_address",
+ country: data.country,
+ addressid: data.addressID,
+ first_name: data.firstName,
+ last_name: data.lastName,
+ company_name: data.organization,
+ company_department: data.department,
+ company_id: data.companyID,
+ vat_id: data.vatID,
+ street1: data.street1,
+ street2: data.street2,
+ city: data.city,
+ state: data.state,
+ province: data.province,
+ postal_code: data.zipCode
+ }];
+ APIService.call(obj).then(function(data) {
+ call.getBillingAddresses(!0)
+ }).catch(function(err) {})
+ },
+ getBins: function() {
+ APIService.call([{
+ command: "get_bins"
+ }]).then(function(data) {
+ BinsModel.onBins(data)
+ }).catch(function(err) {})
+ },
+ getActiveBin: function() {
+ APIService.call([{
+ command: "get_active_bin"
+ }]).then(function(data) {
+ BinsModel.onActiveBin(data)
+ }).catch(function(err) {})
+ },
+ setActiveBin: function(id) {
+ var obj = [{
+ command: "set_active_bin",
+ binid: id
+ }];
+ APIService.call(obj).then(function(data) {
+ setTimeout(function() {
+ call.getActiveBin()
+ }, 1e3)
+ }).catch(function(err) {})
+ },
+ getBin: function() {
+ var obj = [{
+ command: "get_bin_formatted",
+ binid: BinsModel.showBin.id
+ }];
+ APIService.call(obj).then(function(data) {
+ BinsModel.onBin(data)
+ }).catch(function(err) {})
+ },
+ modifyBin: function(binID, addID, rmID) {
+ var obj = [{
+ command: "modify_active_bin",
+ binid: binID,
+ addid: addID,
+ rmid: rmID
+ }];
+ APIService.call(obj).then(function(data) {
+ "1" == data.commands[0].nbr_removed ? call.getBin(BinsModel.binVO.id) : $rootScope.$emit("added to bin")
+ }).catch(function(err) {})
+ },
+ createBin: function(binName) {
+ var obj = [{
+ command: "create_bin",
+ name: binName
+ }];
+ APIService.call(obj).then(function(data) {
+ BinsModel.newBinName;
+ call.setActiveBin(data.commands[0].binid), call.getBins()
+ }).catch(function(err) {})
+ },
+ removeBin: function(id) {
+ var obj = [{
+ command: "delete_bin",
+ binid: id
+ }];
+ APIService.call(obj).then(function(data) {
+ call.getBins(), $rootScope.$emit("collection removed", data)
+ }).catch(function(err) {})
+ },
+ getPurchases: function() {
+ APIService.call([{
+ command: "get_downloads_formatted"
+ }]).then(function(data) {
+ console.log("Service getPurchases data", data), $rootScope.$emit("on purchases", data)
+ }).catch(function(err) {})
+ },
+ getPurchaseURL: function(itemID, transactionID, versionID, version) {
+ console.log("Service getPurchaseURL", itemID, transactionID, versionID, version);
+ var obj = [{
+ command: "download",
+ bid: itemID,
+ tr: transactionID,
+ v: versionID,
+ bitoffset: version
+ }];
+ APIService.call(obj).then(function(data) {
+ console.log("Service getPurchaseURL data", data), DownloadModel.downloadingBatchURLs ? DownloadModel.onGetAllPurchaseURLs(data) : DownloadModel.onGetPurchaseURL(data)
+ }).catch(function(err) {})
+ },
+ modifyCart: function() {
+ var obj = [{
+ command: "modify_active_cart",
+ addid: arguments[0][0],
+ rmid: arguments[0][1]
+ }];
+ APIService.call(obj).then(function(data) {
+ 1 === data.commands[0].nbr_added && $rootScope.$emit("added to cart"), call.getCart(), call.getCartTotal()
+ }).catch(function(err) {})
+ },
+ purchaseWithCredits: function(buyAnyway, userData) {
+ var obj = [{
+ command: "purchase_using_credits",
+ override: buyAnyway,
+ userdata: userData,
+ addressid: BillingInfoModel.getDefaultInfo().addressid
+ }];
+ APIService.call(obj).then(function(data) {
+ console.log("purchaseWithCredits data", data), ReplaceModel.getState() === DEFAULT && $rootScope.$emit("modal simple requested", ["Your purchase has been successful!", "Your items are now ready to download."]), $rootScope.$emit("purchase complete"), ReplaceModel.getState() === NOT_PURCHASED ? call.getPurchases() : ViewStateService.viewRequested("downloads"), call.getUserInfo()
+ }).catch(function(err) {})
+ },
+ purchaseWithCash: function(buyAnyway, userData) {
+ var obj = [{
+ command: "purchase_using_cash",
+ AdobePremierePlugin: "html",
+ override: buyAnyway,
+ userdata: userData,
+ addressid: BillingInfoModel.getDefaultInfo().addressid,
+ use_credits: "1"
+ }];
+ APIService.call(obj).then(function(data) {
+ console.log("Service purchaseWithCash data", data), CheckOutModel.onPurchase(data)
+ }).catch(function(err) {})
+ },
+ promoRedeem: function(code) {
+ var obj = [{
+ command: "promo_redeem",
+ promocode: code
+ }];
+ APIService.call(obj).then(function(data) {
+ call.getUserInfo(), $rootScope.$emit("promo code added", data)
+ }).catch(function(err) {})
+ },
+ getImportedPreviews: function() {
+ console.log("Service getImportedPreviews", ImportedPreviewsService.idsString);
+ var obj = [{
+ command: "get_clip_data_array",
+ itemids: ImportedPreviewsService.idsString,
+ col: "1523",
+ verboselvl: "100"
+ }];
+ APIService.call(obj).then(function(data) {
+ PreviewsModel.onPreviews(data)
+ }).catch(function(err) {})
+ },
+ getFormats: function(item) {
+ console.log("Service getFormats", item.id);
+ var obj = [{
+ command: "get_versions_formatted",
+ vm: item.id
+ }];
+ APIService.call(obj).then(function(data) {
+ console.log("Service getFormats data", data);
+ var formats = data.commands[0].items;
+ $rootScope.$emit("formats complete", item, formats)
+ }).catch(function(err) {})
+ },
+ getFormatsReplacing: function(item) {
+ console.log("Service getFormatsReplacing", item.id);
+ var obj = [{
+ command: "get_versions_formatted",
+ vm: item.id
+ }];
+ APIService.call(obj).then(function(data) {
+ console.log("Service getFormatsReplacing data", data);
+ var formats = data.commands[0].items;
+ $rootScope.$emit("formats replacing complete", item, formats)
+ }).catch(function(err) {})
+ },
+ getMissingItems: function(itemIDsString) {
+ console.log("Service getMissingItems itemIDsString", itemIDsString);
+ var obj = [{
+ command: "get_clip_data_array",
+ itemids: itemIDsString,
+ col: "1523",
+ verboselvl: "100"
+ }];
+ APIService.call(obj).then(function(data) {
+ ReplaceModel.setState(MISSING_ITEMS), console.log("Service getMissingItems data", data), $rootScope.$emit("missing items complete", data)
+ }).catch(function(err) {})
+ }
+ };
+ return call
+}]), app.factory("APIService", ["$http", "ViewStateModel", "LoginModel", function($http, ViewStateModel, LoginModel) {
+ return {
+ call: function(data) {
+ ViewStateModel.allowPreviews = !1;
+ var url, secret, apiKey, _0xf310 = ["test", "https://test.pond5.com/?page=api", "live", "https://www.pond5.com/?page=api", "oi23Jan3Inwh2io", "220655_769351580"];
+ MODE === _0xf310[0] ? API_URL = _0xf310[1] : MODE === _0xf310[2] && (API_URL = _0xf310[3]), API_SECRET = _0xf310[4], API_KEY = _0xf310[5], url = API_URL, secret = API_SECRET, apiKey = API_KEY;
+ var stringified = JSON.stringify(data),
+ md5target = stringified + secret + "dragspel",
+ md5tostring = CryptoJS.MD5(md5target).toString(),
+ cx = LoginModel.getCX(),
+ cm = LoginModel.getCM(),
+ dataObj = {
+ api_key: apiKey,
+ commands_json: stringified,
+ commands_hash: md5tostring,
+ ver: 1,
+ https: 1
+ },
+ jsnstr = JSON.stringify(dataObj);
+ return $http({
+ url: url,
+ method: "POST",
+ data: "api=" + jsnstr + "&apicx=" + cx + "&apicm=" + cm,
+ headers: {
+ "Content-Type": "application/x-www-form-urlencoded"
+ }
+ }).then(function(result) {
+ return ViewStateModel.allowPreviews = !0, result.data
+ })
+ }
+ }
+}]), app.factory("myHttpInterceptor", ["$q", "$rootScope", "ViewStateModel", function($q, $rootScope, ViewStateModel) {
+ return {
+ response: function(response) {
+ var errorFree = !0;
+ return "POST" === response.config.method && (response.data.e ? (console.log("Apiservice myHttpInterceptor error >>>", response.data), errorFree = !1) : response.data.commands && response.data.commands.forEach(function(entry) {
+ if (entry && entry.hasOwnProperty("e")) {
+ if (response.config.data && -1 != response.config.data.indexOf("userinfo")) console.log("myHttpInterceptor user info, do not show alert ", response);
+ else if (103 === response.data.commands[0].c) response.data.commands[0].a && (console.log("APIService myHttpInterceptor alreadyBought or onwClips", response.data.commands[0].a), 0 < response.data.commands[0].a.bought_before.length && ($rootScope.$emit("alreadyBought", response.data.commands[0].a.bought_before), console.log("APIService myHttpInterceptor alreadyBought", response.data.commands[0].a.bought_before)), 0 < response.data.commands[0].a.ownClips.length && ($rootScope.$emit("ownClips", response.data.commands[0].a.ownClips), console.log("APIService myHttpInterceptor ownClips", response.data.commands[0].a.ownClips)));
+ else {
+ console.log("myHttpInterceptor modal simple requested :", entry), "You are not logged in" == entry.s.split(": ")[1] ? $rootScope.$emit("modal not logged in", [ERROR]) : $rootScope.$emit("modal simple requested", [ERROR, entry.s.split(": ")[1]])
+ }
+ errorFree = !1
+ }
+ })), errorFree ? response : $q.reject(response)
+ },
+ responseError: function(response) {
+ return response.config.url == MODAL_INTRO_HTML || response.config.url == MODAL_CHOOSE_BILLING_INFO_HTML ? console.log("apiService don't show error modal for ", response.config.url) : ($rootScope.$emit("modal simple requested", [ERROR, response.headers().status]), console.log("apiService don't show error modal but response ", response)), $q.reject(response)
+ }
+ }
+}]), app.config(function($httpProvider) {
+ $httpProvider.interceptors.push("myHttpInterceptor")
+}), app.service("CheckOutService", ["CartModel", "UserModel", "Service", function(CartModel, UserModel, Service) {
+ this.onCheckOutRequested = function(buyAnyway) {
+ console.log("CheckOutService total before VAT: ", CartModel.cartTotal.subtotals.afterVat), console.log("CheckOutService credits: ", CartModel.cartTotal.creditsData.availableSum), console.log("CheckOutService buyAnyway: ", buyAnyway), CartModel.cartTotal.creditsData.availableSum < CartModel.cartTotal.subtotals.afterVat ? Service.purchaseWithCash(buyAnyway) : Service.purchaseWithCredits(buyAnyway)
+ }
+}]), app.service("CreateOnFileSystemService", ["AppModel", "CreateFileCompleteService", function(AppModel, CreateFileCompleteService) {
+ var call = {
+ createUserHomeFolder: function() {
+ call.createDir(AppModel.getDirHomePond5())
+ },
+ createUserSubFolders: function() {
+ console.log("CreateOnFileSystemService createUserSubFolders", AppModel.getDirDefaultLib());
+ for (var dirs = [AppModel.getDirImports(), AppModel.getDirPrefs(), AppModel.getDirDefaultLib(), AppModel.getDirDestinations(), AppModel.getDirUser()], i = 0; i < dirs.length; i++) {
+ var dir = dirs[i];
+ call.createDir(dir)
+ }
+ },
+ createDestinationBaseFolder: function() {
+ call.createDir(AppModel.currentBaseFolder + path.sep + "pond5", !0)
+ },
+ createDestinationFolders: function() {
+ AppModel.previewsDir = AppModel.currentBaseFolder + path.sep + "pond5" + path.sep + "previews", AppModel.purchasedDir = AppModel.currentBaseFolder + path.sep + "pond5" + path.sep + "purchased", call.createDir(AppModel.previewsDir), call.createDir(AppModel.purchasedDir)
+ },
+ createDir: function(dir, isDestination) {
+ fs.exists(dir, function(exists) {
+ exists ? call.onDirReady(dir, isDestination) : fs.mkdir(dir, 511, function(err) {
+ if (err) throw err;
+ call.onDirReady(dir, isDestination)
+ })
+ })
+ },
+ onDirReady: function(dir, isDestination) {
+ if (isDestination = isDestination || !1) this.createDestinationFolders();
+ else {
+ var filePath, xml;
+ switch (dir) {
+ case AppModel.getDirHomePond5():
+ call.createUserSubFolders();
+ break;
+ case AppModel.getDirImports():
+ filePath = "imported_previews.xml", xml = ' ';
+ break;
+ case AppModel.getDirPrefs():
+ filePath = "preferences.xml", xml = ' ';
+ break;
+ case AppModel.getDirUser():
+ filePath = "user.xml", xml = ' ';
+ break;
+ case AppModel.getDirDestinations():
+ filePath = "destinations.xml", xml = ' ';
+ break;
+ case AppModel.getDirDefaultLib():
+ filePath = "defaultLib.xml", xml = ' ';
+ break;
+ case AppModel.currentBaseFolder:
+ this.createDestinationFolders();
+ break;
+ default:
+ return
+ }
+ filePath && call.createFile(dir + path.sep + filePath, '' + xml)
+ }
+ },
+ createFile: function(file, content) {
+ fs.exists(file, function(exists) {
+ exists ? CreateFileCompleteService.onFileReady(file) : fs.writeFile(file, content, function(err) {
+ if (err) throw err;
+ console.log("CreateOnFileSystemService, created file: ", file), CreateFileCompleteService.onFileReady(file)
+ })
+ })
+ }
+ };
+ return call
+}]), app.service("DeleteOnFileSystemService", [function() {
+ return {
+ deleteFiles: function(items) {
+ items.forEach(function(item) {
+ var file = item.downloadDestination + item.fileName;
+ fs.exists(file, function(exists) {
+ exists && fs.unlink(file, function(err) {
+ if (err) throw err
+ })
+ })
+ })
+ },
+ deleteFolder: function(folders, cb) {
+ console.log("DeleteOnFileSystemService deleteFolder, folders, length:", folders.length), folders.forEach(function(folder) {
+ console.log("DeleteOnFileSystemService deleteFolder, folder:", folder), fs.exists(folder, function(exists) {
+ exists ? rimraf(folder, function(err) {
+ if (err) throw err;
+ console.log("DeleteOnFileSystemService deleteFolder deleted: ", folder), cb()
+ }) : (console.log("DeleteOnFileSystemService deleteFile folder does not exist:", folder), cb())
+ })
+ })
+ }
+ }
+}]), app.factory("DownloadBatchService", ["Service", "PurchasesModel", "DownloadModel", function(Service, PurchasesModel, DownloadModel) {
+ return {
+ onBatchRequested: function(purchases) {
+ var j, i;
+ for (purchases = purchases || PurchasesModel.purchasesVO.items, i = 0; i < purchases.length; i += 1)
+ for (j = 0; j < PurchasesModel.purchasesVO.items.length; j += 1) purchases[i].id == PurchasesModel.purchasesVO.items[j].id && (purchases[i] = PurchasesModel.purchasesVO.items[j]);
+ for (DownloadModel.downloadingBatchURLs = !0, purchases = purchases.filter(function(v, i, a) {
+ return a.indexOf(v) == i
+ }), i = 0; i < purchases.length; i += 1) Service.getPurchaseURL(purchases[i].id, purchases[i].transactionID, purchases[i].versionID, purchases[i].version)
+ }
+ }
+}]), app.service("DownloadCancelService", ["$rootScope", "DeleteOnFileSystemService", "ProgressService", "DownloadModel", function($rootScope, DeleteOnFileSystemService, ProgressService, DownloadModel) {
+ return {
+ onCancelSingle: function(item) {
+ console.log("DownloadCancelService onCancelSingle: ", item, item.downloadType), item.canceled = !0, $rootScope.$emit("cancel download", item), ProgressService.clearItem(item), DeleteOnFileSystemService.deleteFiles([item]), item.downloading && (item.downloading = !1, DownloadModel.downloadCounter--);
+ for (var len = DownloadModel.itemsDownloadList.length; len--;)
+ if (DownloadModel.itemsDownloadList[len].fileName === item.fileName) {
+ var removal = DownloadModel.itemsDownloadList[len];
+ DownloadModel.itemsDownloadList = DownloadModel.itemsDownloadList.filter(function(itm) {
+ return itm !== removal
+ })
+ } console.log("DownloadCancelService onCancelSingle num of items: ", DownloadModel.itemsDownloadList.length), $rootScope.$emit("modal simple requested", ["", "Download of " + item.fileName + " has been canceled."], "sm")
+ },
+ onCancelAll: function() {
+ console.log("DownloadCancelService cancel all downloads", DownloadModel.itemsDownloadList);
+ for (var len = DownloadModel.itemsDownloadList.length; len--;) {
+ var item = DownloadModel.itemsDownloadList[len];
+ 100 !== item.progressPerc && (item.canceled = !0, $rootScope.$emit("cancel download", item), ProgressService.clearItem(item), DeleteOnFileSystemService.deleteFiles([item]))
+ }
+ $rootScope.$emit("modal simple requested", ["", "All incomplete downloads have been canceled and deleted."], "sm"), DownloadModel.downloadCounter = -1, DownloadModel.itemsDownloadList = []
+ }
+ }
+}]), app.service("DownloadCompleteService", ["$rootScope", "UnzipService", function($rootScope, UnzipService) {
+ return {
+ onComplete: function(items) {
+ UnzipService.unzipItems(items)
+ }
+ }
+}]), app.service("DownloadRequestService", ["$rootScope", "DownloadService", "ProgressService", "DownloadModel", "ReplaceModel", "AppModel", "ImportService", "ReplaceService", "StayAwakeService", "UnzipService", function($rootScope, DownloadService, ProgressService, DownloadModel, ReplaceModel, AppModel, ImportService, ReplaceService, StayAwakeService, UnzipService) {
+ $rootScope.$on("download requested", function(event, items) {
+ var downloadFolderName;
+ console.log("DownloadRequestService DownloadModel.itemsDownloadList: ", DownloadModel.itemsDownloadList), "preview" === items[0].downloadType ? downloadFolderName = "previews" : "purchase" === items[0].downloadType && (downloadFolderName = "purchased");
+ var item, dest = AppModel.currentBaseFolder + path.sep + "pond5" + path.sep + downloadFolderName + path.sep;
+ console.log("DownloadRequestService downloadRequested items:", items), $rootScope.$emit("scroll progress to top");
+ for (var i = 0; i < items.length; i++) {
+ var codec;
+ (item = items[i]).downloadDestination = dest, "preview" === item.downloadType ? "Video" == item.type || "AE" == item.type ? item.downloadURL = item.h264URL : "Sound effect" == item.type || "Music" == item.type ? item.downloadURL = item.m4aURL : "Photo" != item.type && "Illustration" != item.type || (item.downloadURL = item.iconLargeURL) : "purchase" === item.downloadType && (item.downloadURL = item.hiresURL), "Photo" == item.type ? item.ext = "jpg" : item.ext = item.downloadURL.substr(item.downloadURL.lastIndexOf(".") + 1).split("?")[0], item.videoCodec && (codec = item.videoCodec), "preview" !== item.downloadType && "unknown" !== codec && void 0 !== codec || (codec = ""), item.fileName = getFormattedName(item.id + " " + codec + " " + item.name + "." + item.ext), item.progressName = getAbbrName(item.fileName, 20), "preview" === item.downloadType && "AE" === item.vs && (item.fileName = "AE " + item.fileName), "purchase" === item.downloadType && ("AE" === item.vs ? item.fileName = "AE " + item.fileName : item.fileName = "hires " + item.fileName), $rootScope.$emit("open progress", !1), item.progressPerc = "", item.progressMB = "", ProgressService.addItem(item)
+ }
+ $rootScope.$$listenerCount["on item downloaded"] || $rootScope.$on("on item downloaded", function(event) {
+ DownloadModel.downloadCounter++, console.log("DownloadRequestService on item downloaded DownloadModel.downloadCounter: ", DownloadModel.downloadCounter), console.log("DownloadRequestService on item downloaded DownloadModel.itemsDownloadList: ", DownloadModel.itemsDownloadList);
+ var item = DownloadModel.itemsDownloadList[DownloadModel.downloadCounter];
+ if (item) {
+ StayAwakeService.updateState(!0);
+ new DownloadService.download(item)
+ } else if (StayAwakeService.updateState(!1), DownloadModel.downloadCounter--, console.log("DownloadRequestService download complete, check if something needs to be done, complete previews", ProgressService.getCompletedPreviews()), ProgressService.getCompletedPreviewsStatus() && ImportService.importClips(ProgressService.getCompletedPreviews()), ProgressService.getCompletedPurchasesStatus()) {
+ console.log("DownloadRequestService purchases completed: ", ProgressService.getCompletedPurchases()), console.log("DownloadRequestService purchases completed ReplaceModel.getState(): ", ReplaceModel.getState());
+ var AEItems = [];
+ if (ProgressService.getCompletedPurchases().forEach(function(item) {
+ "AE" == item.type && AEItems.push(item)
+ }), "1.0.8" != PLUGIN_VERSION && UnzipService.unzipItems(AEItems), ReplaceModel.getState() === NOT_DOWNLOADED) {
+ var dest = AppModel.currentBaseFolder + path.sep + "pond5" + path.sep + "purchased" + path.sep;
+ ProgressService.getCompletedPurchases().forEach(function(entry) {
+ ReplaceModel.addHires(dest, [entry])
+ }), ReplaceService.onPurchasedAndDownloaded(AEItems.length)
+ }
+ }
+ }), console.log("DownloadRequestService new request, ProgressService.getIncompleteItems ", ProgressService.getIncompleteItems()), 0 < ProgressService.getIncompleteItems().length && !ProgressService.getDownloadingStatus() && $rootScope.$emit("on item downloaded")
+ })
+}]), app.service("DownloadService", ["$rootScope", "ProgressService", function($rootScope, ProgressService) {
+ function download(item) {
+ console.log("DownloadService download item: ", item);
+ var allowWriting = !0;
+ $rootScope.$on("cancel download", function(event, itm) {
+ itm.fileName === item.fileName && (itm.canceled = !0, item.canceled = !0, allowWriting = !1)
+ }), item.downloading = !0;
+ var file, sizeOnFS, writeOptions, path = item.downloadDestination + item.fileName;
+ writeOptions = fs.existsSync(path) ? (sizeOnFS = fs.statSync(path).size, console.log("DownloadService sizeOnFS: ", sizeOnFS), {
+ flags: "r+"
+ }) : (console.log("DownloadService file does not exist yet, create stream"), {
+ flags: "w"
+ }), file = fs.createWriteStream(path, writeOptions), https.get(item.downloadURL, function(res) {
+ var len;
+ res.headers["content-length"] ? (len = parseInt(res.headers["content-length"], 10), console.log("DownloadService res has content-length: ", res)) : console.log("DownloadService content-length unknown", res);
+ var progressPerc, cur = 0,
+ total = len / 1048576;
+
+ function setToComplete() {
+ item.canceled || (item.progressPerc = 100, item.progressMB = total.toFixed(2) + "/" + total.toFixed(2) + "MB", item.completed = !0), item.canceled = !1, item.downloading = !1, $rootScope.$emit("on item downloaded"), $rootScope.$digest()
+ }
+ res.pipe(file), len <= sizeOnFS && (file.end(), setToComplete()), res.on("data", function(chunk) {
+ allowWriting ? (cur += chunk.length, progressPerc = (100 * cur / len).toFixed(2), $rootScope.$apply(function() {
+ item.progressPerc = progressPerc.split(".")[0], item.progressMB = (cur / 1048576).toFixed(2) + "/" + total.toFixed(2) + "MB"
+ })) : res.destroy()
+ }).on("error", function(e) {
+ console.log("DownloadService error: " + e.message)
+ }).on("end", function() {
+ file.end(), setToComplete()
+ })
+ }).on("error", function(err) {
+ console.error("Download Error code and filename:", err.code, item.fileName), console.error("Download err:", err), item.progressPerc = 0, item.progressMB = "", setTimeout(function() {
+ download(item, options)
+ }, 1e3)
+ })
+ }
+ return {
+ download: function(item, options) {
+ return new download(item, options)
+ }
+ }
+}]), app.service("ImportAEService", ["$rootScope", "ReplaceModel", function($rootScope, ReplaceModel) {
+ var call = {
+ showingModal: !1,
+ import: function(sourceDir) {
+ var walk = function(dir, done) {
+ var files = [];
+ fs.readdir(dir, function(err, list) {
+ if (err) return done(err);
+ var i = 0;
+ ! function next() {
+ var file = list[i++];
+ if (!file) return done(null, files);
+ file = dir + "/" + file, fs.stat(file, function(err, stat) {
+ stat && stat.isDirectory() ? walk(file, function(err, res) {
+ files = files.concat(res), next()
+ }) : (files.push(file), next())
+ })
+ }()
+ })
+ };
+ walk(sourceDir, function(err, files) {
+ if (err) throw err;
+ for (var i = 0; i < files.length; i += 1) console.log("ImportService file", files[i]), -1 != files[i].indexOf(".aep") && csInterface.evalScript("importAETemplate(" + JSON.stringify(files[i]) + ")", function(result) {
+ call.showingModal || ($rootScope.$emit("modal simple requested", ["", "Your project has been updated."]), call.showingModal = !0), console.log("ImportAEService import showingModal", call.showingModal)
+ })
+ })
+ }
+ };
+ return call
+}]), app.factory("ImportedPreviewsService", ["$rootScope", function($rootScope) {
+ var result = {
+ readXML: function() {
+ var dest = path.sep + "pond5" + path.sep + "imports" + path.sep + "imported_previews.xml";
+ result.file = getUserHome() + dest, fs.readFile(result.file, "utf8", function(err, data) {
+ if (err) throw err;
+ result.xml = data, result.parseXML()
+ })
+ },
+ saveItem: function(id) {
+ var idsString = result.idsString.toString(); - 1 == idsString.indexOf(id.toString()) && (0 < idsString.length ? result.idsString += "," + id : result.idsString = id, result.writeToDisk())
+ },
+ deleteItem: function(id) {
+ -1 != result.idsString.indexOf(id) && (result.idsString = result.idsString.replace(id, "")), "," == result.idsString.substr(0, 1) && (result.idsString = result.idsString.substr(1)), "," == result.idsString.substr(result.idsString.length - 1, result.idsString.length) && (result.idsString = result.idsString.slice(0, -1)), result.writeToDisk(), $rootScope.$emit("api call", {
+ fn: "getImportedPreviews"
+ })
+ },
+ parseXML: function() {
+ var parser = new xml2js.Parser;
+ parser.addListener("end", function(res) {
+ (result.parsedXML = res) && (result.idsString = res.root.previews[0].$.ids)
+ }), parser.parseString(result.xml)
+ },
+ writeToDisk: function() {
+ result.parsedXML.root.previews[0].$.ids = result.idsString;
+ var xml = (new xml2js.Builder).buildObject(result.parsedXML);
+ fs.writeFile(result.file, xml, function(err) {
+ if (err) throw err
+ })
+ }
+ };
+ return result
+}]), app.service("MissingItemsService", ["$rootScope", "MissingItemsModel", "ReplaceModel", "Service", "CartModel", "ReplaceServiceShared", function($rootScope, MissingItemsModel, ReplaceModel, Service, CartModel, ReplaceServiceShared) {
+ $rootScope.$on("missing items complete", function(event, items) {
+ console.log("MissingItemsService on missing items: ", items), ReplaceModel.getState() === MISSING_ITEMS && result.onMissingItems(items)
+ }), $rootScope.$on("formats replacing complete", function(event, item, formats) {
+ ReplaceModel.getState() === MISSING_ITEMS && result.onMissingItemsFormats(item, formats)
+ }), $rootScope.$on("on purchases vo", function(event, vo) {
+ console.log("MissingItemsService on purchases vo, state: ", ReplaceModel.getState()), ReplaceModel.getState() != DEFAULT && result.onPurchasesVO(vo)
+ });
+ var result = {
+ missingItemsCounter: 0,
+ onMissingItems: function(data) {
+ var missingItemsVO = new MissingItemsVO(data.commands[0]);
+ (MissingItemsModel.missingItemsVO = missingItemsVO).items.forEach(function(entry) {
+ Service.getFormatsReplacing(entry)
+ })
+ },
+ onMissingItemsFormats: function(item, formats) {
+ if (result.missingItemsCounter++, 1 < (formats = _.uniq(formats, function(p) {
+ return p.ti
+ })).length)
+ for (i = 0; i < formats.length; i++) item.formats[i] = new ItemVO(formats[i]), item.parentFormatID = item.id, item.formats[i].offset = formats[i].offset;
+ result.missingItemsCounter === MissingItemsModel.missingItemsVO.items.length && (result.missingItemsCounter = 0, Service.getPurchases())
+ },
+ onPurchasesVO: function(purchasesVO) {
+ for (var item, missingItems = MissingItemsModel.missingItemsVO.items, cartItems = CartModel.cartVO.items, purchasedItems = purchasesVO.items, i = 0; i < missingItems.length; i++) {
+ var cartItem, purchase;
+ item = missingItems[i];
+ for (var j = 0; j < cartItems.length; j++) {
+ cartItem = cartItems[j], item.id == cartItem.id && (item.inCart = !0);
+ for (var formats = item.formats, k = 0; k < formats.length; k++) formats[k].id == cartItem.id && formats[k].offset == cartItem.offset && (formats[k].inCart = !0, item.inCart = !0)
+ }
+ for (j = 0; j < purchasedItems.length; j++) {
+ purchase = purchasedItems[j], item.id == purchase.id && (item.inDownloads = !0, item.transactionID = purchase.transactionID);
+ for (formats = item.formats, k = 0; k < formats.length; k++) formats[k].id == purchase.id && (formats[k].inDownloads = !0, formats[k].transactionID = purchase.transactionID, purchasedItems[j].parentFormatID && (formats[k].parentFormatID = purchase.parentFormatID))
+ }
+ }
+ ReplaceModel.getState() === MISSING_ITEMS ? $rootScope.$emit("modal replace", missingItems) : ReplaceModel.getState() === NOT_PURCHASED && ReplaceServiceShared.onPurchased(missingItems)
+ }
+ };
+ return result
+}]), app.service("ProgressService", ["$rootScope", "DownloadModel", function($rootScope, DownloadModel) {
+ var result = {
+ alreadyHasItem: function(item) {
+ var itemsContainItem = !1;
+ return DownloadModel.itemsDownloadList.forEach(function(entry) {
+ entry.fileName === item.fileName && (itemsContainItem = !0)
+ }), itemsContainItem
+ },
+ addItem: function(item) {
+ DownloadModel.itemsDownloadList.forEach(function(entry) {
+ entry.fileName === item.fileName && (console.log("ProgressService already in list: ", item.fileName), item.completed = !1, item.imported = !1, item.canceled = !1, item.progressPerc = 0, item.progressMB = "", DownloadModel.downloadCounter--, result.clearItem(item), console.log("ProgressService already in list, cleared: ", DownloadModel.itemsDownloadList))
+ }), DownloadModel.itemsDownloadList.push(item), console.log("ProgressService addItem, list: ", DownloadModel.itemsDownloadList), $rootScope.$emit("added to progress")
+ },
+ clearCompleteItems: function() {
+ console.log("ProgressService clearCompleteItems ");
+ for (var len = DownloadModel.itemsDownloadList.length, oldLen = len; len--;) {
+ var item = DownloadModel.itemsDownloadList[len];
+ if (100 === item.progressPerc) {
+ item.completed = !1, item.imported = !1, item.canceled = !1, item.progressPerc = 0;
+ var removal = DownloadModel.itemsDownloadList[len];
+ DownloadModel.itemsDownloadList = DownloadModel.itemsDownloadList.filter(function(itm) {
+ return itm !== removal
+ })
+ }
+ }
+ var diff = oldLen - DownloadModel.itemsDownloadList.length;
+ DownloadModel.downloadCounter = DownloadModel.downloadCounter - diff, console.log("ProgressService clearCompleteItems DownloadModel.itemsDownloadList: ", DownloadModel.itemsDownloadList), console.log("ProgressService clearCompleteItems new downloadCounter: ", DownloadModel.downloadCounter), $rootScope.$emit("clear progress")
+ },
+ clearIncompleteItems: function() {
+ console.log("ProgressService clearIncompleteItems ");
+ for (var len = DownloadModel.itemsDownloadList.length; len--;)
+ if (100 !== DownloadModel.itemsDownloadList[len].progressPerc) {
+ var removal = DownloadModel.itemsDownloadList[len];
+ DownloadModel.itemsDownloadList = DownloadModel.itemsDownloadList.filter(function(itm) {
+ return itm !== removal
+ })
+ } $rootScope.$emit("on clear", DownloadModel.itemsDownloadList)
+ },
+ clearAllItems: function() {
+ console.log("ProgressService clearAllItems "), DownloadModel.itemsDownloadList = [], $rootScope.$emit("clear progress"), DownloadModel.downloadCounter = 0
+ },
+ clearItem: function(item) {
+ console.log("ProgressService clearItem ");
+ for (var len = DownloadModel.itemsDownloadList.length; len--;)
+ if (DownloadModel.itemsDownloadList[len].fileName === item.fileName) {
+ var removal = DownloadModel.itemsDownloadList[len];
+ DownloadModel.itemsDownloadList = DownloadModel.itemsDownloadList.filter(function(itm) {
+ return itm !== removal
+ })
+ } $rootScope.$emit("clear progress")
+ },
+ getIncompleteItems: function() {
+ var incompletes = [];
+ return DownloadModel.itemsDownloadList.forEach(function(entry) {
+ entry.completed || (console.log("ProgressService not completed: ", entry.fileName), incompletes.push(entry))
+ }), incompletes
+ },
+ getCompletedPreviewsStatus: function() {
+ var allCompleted = !0;
+ return DownloadModel.itemsDownloadList.forEach(function(entry) {
+ entry.completed || "preview" !== entry.downloadType || (allCompleted = !1)
+ }), 0 === DownloadModel.itemsDownloadList.length && (allCompleted = !1), console.log("ProgressService getCompletedPreviewsStatus allCompleted", allCompleted), allCompleted
+ },
+ getCompletedPreviews: function() {
+ var completes = [];
+ return DownloadModel.itemsDownloadList.forEach(function(entry) {
+ entry.completed && "preview" == entry.downloadType && completes.push(entry)
+ }), completes
+ },
+ getCompletedPurchasesStatus: function() {
+ var allCompleted = !0;
+ return DownloadModel.itemsDownloadList.forEach(function(entry) {
+ entry.completed || "purchase" !== entry.downloadType || (allCompleted = !1)
+ }), 0 === DownloadModel.itemsDownloadList.length && (allCompleted = !1), console.log("ProgressService getCompletedPurchasesStatus allCompleted", allCompleted), allCompleted
+ },
+ getCompletedPurchases: function() {
+ var completes = [];
+ return DownloadModel.itemsDownloadList.forEach(function(entry) {
+ entry.completed && "purchase" == entry.downloadType && completes.push(entry)
+ }), completes
+ },
+ getDownloadingStatus: function() {
+ var downloading = !1;
+ return DownloadModel.itemsDownloadList.forEach(function(entry) {
+ entry.downloading && (downloading = !0)
+ }), downloading
+ }
+ };
+ return result
+}]), app.service("ReadClipsOnFSService", ["$rootScope", "ReplaceModel", "MissingItemsModel", "ViewStateService", "DownloadBatchService", "AppModel", function($rootScope, ReplaceModel, MissingItemsModel, ViewStateService, DownloadBatchService, AppModel) {
+ var call = {
+ listPurchasesOnFS: function(cb) {
+ ReplaceModel.hiresOnFS = [];
+ for (var cbCounter = 0, i = 0; i < AppModel.baseFolders.length; i++) call.readPurchasesFolders(AppModel.baseFolders[i] + path.sep + "pond5" + path.sep + "purchased" + path.sep, function() {
+ ++cbCounter === AppModel.baseFolders.length && (console.log("\nReadClipsOnFSService ReplaceModel.hiresOnFS done: ", cbCounter, ReplaceModel.hiresOnFS), call.listPreviewsOnFS(function() {
+ cb()
+ }))
+ })
+ },
+ readPurchasesFolders: function(dest, cb) {
+ fs.readdir(dest, function(err, files) {
+ if (err) throw new Error("ReadClipsOnFSService: " + dest + " does not exist.");
+ var hiresVO;
+ files = files.filter(junk.not);
+ for (var i = 0; i < files.length; i += 1) hiresVO = new HiresVO(dest, files[i]), ReplaceModel.hiresOnFS.push(hiresVO), 0 === path.extname(files[i]).length ? hiresVO.type = "AE folder" : ".zip" === path.extname(files[i]) ? hiresVO.type = "AE zip" : ".mov" === path.extname(files[i]) ? hiresVO.type = "video" : ".wav" === path.extname(files[i]) && (hiresVO.type = "audio");
+ cb()
+ })
+ },
+ listPreviewsOnFS: function(cb) {
+ ReplaceModel.previewsOnFS = [];
+ for (var i = 0; i < AppModel.baseFolders.length; i++) {
+ var walk = function(dir, done) {
+ var files = [];
+ fs.readdir(dir, function(err, list) {
+ if (err) return done(err);
+ var i = 0;
+ ! function next() {
+ var file = list[i++];
+ if (!file) return done(null, files);
+ file = dir + "/" + file, fs.stat(file, function(err, stat) {
+ stat && stat.isDirectory() ? walk(file, function(err, res) {
+ files = files.concat(res), next()
+ }) : (files.push(file), next())
+ })
+ }()
+ })
+ },
+ dest = AppModel.baseFolders[i] + path.sep + "pond5" + path.sep + "previews",
+ counter = 0;
+ walk(dest, function(err, files) {
+ if (err) throw err;
+ for (var previewVO, i = 0; i < files.length; i += 1) previewVO = new PreviewVO(dest, files[i]), ReplaceModel.previewsOnFS.push(previewVO);
+ ++counter === AppModel.baseFolders.length && cb()
+ })
+ }
+ }
+ };
+ return call
+}]), app.service("ReplaceServiceShared", ["$rootScope", "ReplaceModel", "Service", "MissingItemsModel", "ViewStateService", "DownloadBatchService", "ImportAEService", "DeleteOnFileSystemService", function($rootScope, ReplaceModel, Service, MissingItemsModel, ViewStateService, DownloadBatchService, ImportAEService, DeleteOnFileSystemService) {
+ var call = {
+ removeDuplicates: function(clips) {
+ return clips = clips.filter(function(v, i, a) {
+ return a.indexOf(v) === i
+ })
+ },
+ getPreviewsOnFSNames: function() {
+ var previewNamesonFS = [];
+ return ReplaceModel.previewsOnFS.forEach(function(entry) {
+ previewNamesonFS.push(entry.name)
+ }), previewNamesonFS
+ },
+ filterNonP5Clips: function(clips, previewNamesOnFS) {
+ return clips = clips.filter(function(n) {
+ return -1 != previewNamesOnFS.indexOf(n)
+ })
+ },
+ getPreviewsIDs: function(clips) {
+ var previewIDs = [];
+ return clips.forEach(function(entry) {
+ var substr = entry.split(" ");
+ "AE" === substr[0] ? previewIDs.push(substr[1]) : previewIDs.push(substr[0])
+ }), console.log("\nReplaceServiceShared previewIDs: " + previewIDs), previewIDs
+ },
+ setReplaceProp: function(ids) {
+ for (var i = 0; i < ids.length; i++)
+ for (var j = 0; j < ReplaceModel.hiresOnFS.length; j++) ids[i] === ReplaceModel.hiresOnFS[j].id && (ReplaceModel.hiresOnFS[j].replace = !0)
+ },
+ getMissingItemIDs: function(clipsInSeqs) {
+ var clipsInSelectedSequences = clipsInSeqs;
+ console.log("ReplaceService ReplaceModel.aeItemsinProjectView: ", ReplaceModel.getAEItems()), 0 < ReplaceModel.getAEItems().length && (clipsInSelectedSequences = clipsInSelectedSequences.concat(ReplaceModel.getAEItems())), console.log("ReplaceService clips after concat layer items and AE items: ", clipsInSelectedSequences), clipsInSelectedSequences = call.removeDuplicates(clipsInSelectedSequences), console.log("\nReplaceServiceShared clipsInSelectedSequences after removing duplicates: ", clipsInSelectedSequences);
+ var previewNamesonFS = call.getPreviewsOnFSNames();
+ console.log("\nReplaceServiceShared previewNamesonFS: ", previewNamesonFS), clipsInSelectedSequences = call.filterNonP5Clips(clipsInSelectedSequences, previewNamesonFS), console.log("\nReplaceServiceShared after filterNonP5Clips", clipsInSelectedSequences);
+ var previewIDs = call.getPreviewsIDs(clipsInSelectedSequences);
+ console.log("\nReplaceServiceShared previewIDs: " + previewIDs), call.setReplaceProp(previewIDs), console.log("\nReplaceServiceShared after set replace: " + ReplaceModel.hiresOnFS);
+ var hiresIDs = call.getHiresIDsonFS();
+ console.log("\nReplaceServiceShared hiresIDs: " + hiresIDs);
+ var missingItemIDs = _(previewIDs).difference(hiresIDs),
+ missingIDsToString = missingItemIDs.join(",");
+ if (console.log("nReplaceServiceShared missingIDsToString: " + missingIDsToString), 0 < missingItemIDs.length) Service.getMissingItems(missingIDsToString);
+ else {
+ if (0 < hiresIDs.length) return hiresIDs.length;
+ 0 === clipsInSelectedSequences.length && (ReplaceModel.setState(DEFAULT), $rootScope.$emit("modal simple requested", ["", "There are no Pond5 previews in your current project."]))
+ }
+ },
+ getHiresIDsonFS: function() {
+ var hiresIDs = [];
+ return ReplaceModel.hiresOnFS.forEach(function(entry) {
+ (entry.replace || entry.importAE) && hiresIDs.push(entry.id)
+ }), hiresIDs
+ },
+ onModalReplaceOK: function() {
+ for (var item, missingItems = MissingItemsModel.missingItemsVO.items, itemsNotPurchased = [], itemsNotDownloaded = [], i = 0; i < missingItems.length; i++)(item = missingItems[i]).selected && !item.inDownloads && itemsNotPurchased.push(item), item.selected && item.inDownloads && itemsNotDownloaded.push(item);
+ 0 < itemsNotPurchased.length ? call.onNotPurchased(itemsNotPurchased) : 0 < itemsNotDownloaded.length ? (console.log("ReplaceServiceShared onModalReplaceOK, download items: ", itemsNotDownloaded), ReplaceModel.missingDownloads = itemsNotDownloaded, call.onNotDownloaded(itemsNotDownloaded)) : (ReplaceModel.setState(PURCHASED_AND_DOWNLOADED), console.log("ReplaceServiceShared onModalReplaceOK, replace"), call.onPurchasedAndDownloaded())
+ },
+ onNotPurchased: function(itemsNotPurchased) {
+ for (var addToCartItems = [], i = 0; i < itemsNotPurchased.length; i++)
+ if (item = itemsNotPurchased[i], 0 < itemsNotPurchased[i].formats.length)
+ for (var j = 0; j < itemsNotPurchased[i].formats.length; j++) format = itemsNotPurchased[i].formats[j], format.selected && (console.log("ReplaceServiceShared onNotPurchased add this format to cart: ", format), addToCartItems.push(format.id));
+ else console.log("ReplaceServiceShared onNotPurchased add this item to cart: ", item), addToCartItems.push(item.id);
+ $rootScope.$emit("modal simple requested", ["", "Please review your Cart. Press the 'Checkout' button to proceed with replacing your previews."]);
+ var apiObj = {
+ fn: "modifyCart",
+ args: [addToCartItems.join(","), ""]
+ };
+ $rootScope.$emit("api call", apiObj), ViewStateService.viewRequested("cart"), ReplaceModel.setState(NOT_PURCHASED)
+ },
+ onPurchased: function(downloadItems) {
+ console.log("ReplaceServiceShared onPurchased: ", downloadItems);
+ for (var item, missingItems = MissingItemsModel.missingItemsVO.items, itemsNotDownloaded = [], i = 0; i < missingItems.length; i++)(item = missingItems[i]).inDownloads && itemsNotDownloaded.push(item);
+ 0 < itemsNotDownloaded.length && (console.log("ReplaceServiceShared onPurchased, download items: ", itemsNotDownloaded), ReplaceModel.missingDownloads = itemsNotDownloaded, $rootScope.$emit("modal simple requested", ["Your purchase has been successful.", "Your purchased clips will begin downloading now. Once the downloads are completed, your lo-res previews will be replaced with your high-res clips."]), call.onNotDownloaded(itemsNotDownloaded, !0))
+ },
+ onNotDownloaded: function(itemsNotDownloaded, afterPurchase) {
+ afterPurchase = afterPurchase || !1, console.log("ReplaceServiceShared onNotDownloaded missing items:", itemsNotDownloaded);
+ for (var downloadItems = [], i = 0; i < itemsNotDownloaded.length; i++)
+ if (item = itemsNotDownloaded[i], 0 < itemsNotDownloaded[i].formats.length)
+ for (var j = 0; j < itemsNotDownloaded[i].formats.length; j++) format = itemsNotDownloaded[i].formats[j], format.selected && (console.log("ReplaceServiceShared onNotDownloaded download this format: ", format), downloadItems.push(format));
+ else console.log("ReplaceServiceShared onNotDownloaded download item: ", item), downloadItems.push(item);
+ afterPurchase || $rootScope.$emit("modal simple requested", ["You have purchases that are missing in your project. ", "They will be downloaded. Once the downloads are completed, your lo-res previews will be replaced with your high-res clips."]), DownloadBatchService.onBatchRequested(downloadItems), ReplaceModel.setState(NOT_DOWNLOADED)
+ }
+ };
+ return call
+}]), app.service("ScrollService", ["SearchModel", "Service", function(SearchModel, Service) {
+ this.onScroll = function() {
+ if (SearchModel.allowInfiniteScroll) {
+ var m = document.getElementById("main-holder");
+ 1 === (getScroll()[1] - 72) / (m.scrollHeight - window.innerHeight) && (console.log("ScrollService show more: " + SearchModel.isSearching), SearchModel.isSearching || (SearchModel.isSearching = !0, SearchModel.resultType = "add", SearchModel.page = SearchModel.page + 1, Service.search()))
+ }
+ }
+}]), app.factory("StartUpService", ["$rootScope", "CreateOnFileSystemService", "MissingItemsService", "ViewStateService", "AppModel", function($rootScope, CreateOnFileSystemService, MissingItemsService, ViewStateService, AppModel) {
+ return $("#logo").click(function() {
+ location.reload()
+ }), $rootScope.$on("environment set", function() {
+ console.log("StartUpService, 26/10 pointing at ", window.location.href), gup("tp", window.location.href) && (THIRD_PARTY = gup("tp", window.location.href)), -1 < window.location.href.indexOf("test") ? MODE = "test" : MODE = "live", console.log("StartUpService MODE:", MODE), console.log("StartUpService OS:", os.platform()), console.log("StartUpService, app version: ", PLUGIN_VERSION), AppModel.currentBaseFolder = AppModel.getDocumentsPath(), console.log("StartUpService currentBaseFolder: ", AppModel.currentBaseFolder + "\n\n"), CreateOnFileSystemService.createUserHomeFolder(), MissingItemsService.missingItemsCounter = 0, ViewStateService.viewRequested("search")
+ }), {
+ init: function() {
+ setTimeout(function() {
+ AppModel.setEnv()
+ }, 2e3)
+ }
+ }
+}]), app.factory("StayAwakeService", ["$rootScope", "DownloadModel", function($rootScope, DownloadModel) {
+ return {
+ updateState: function(state) {
+ console.log("StayAwakeService state: ", state), state && !DownloadModel.stayAwake ? (sleep.prevent(), DownloadModel.stayAwake = !0) : !state && DownloadModel.stayAwake && (sleep.allow(), DownloadModel.stayAwake = !1)
+ }
+ }
+}]), app.service("TransactionService", ["$q", "ViewStateService", "Service", "ReplaceModel", "AnalyticsService", "CartModel", function($q, ViewStateService, Service, ReplaceModel, AnalyticsService, CartModel) {
+ this.onMessageReceivedFromAdyen = function(event) {
+ console.log("event.source: ", event.source), console.log("event origin: ", event.origin), console.log("event data: ", event.data);
+ var deferred = $q.defer();
+ switch (event.data) {
+ case "PAID":
+ console.log("TransactionService PAID"), deferred.resolve("PAID"), ReplaceModel.getState() === NOT_PURCHASED ? Service.getPurchases() : ViewStateService.viewRequested("downloads"), AnalyticsService.sendData(null, "transaction"), Service.getUserInfo();
+ break;
+ case "CANCELED":
+ deferred.reject("CANCELED"), console.log("TransactionService CANCELED");
+ break;
+ case "PENDING":
+ console.log("TransactionService PENDING"), deferred.reject("PENDING");
+ break;
+ default:
+ deferred.reject("UNKNOWN")
+ }
+ return deferred.promise
+ }
+}]), app.service("UnzipService", ["$rootScope", "DeleteOnFileSystemService", "ReplaceModel", "ImportAEService", function($rootScope, DeleteOnFileSystemService, ReplaceModel, ImportAEService) {
+ var call = {
+ unzippedCounter: 0,
+ deletedCounter: 0,
+ numOfItems: 0,
+ items: [],
+ deleteObjects: [],
+ itemObjects: [],
+ unzipItems: function(items) {
+ call.unzippedCounter = 0, call.deletedCounter = 0, call.numOfItems = items.length, call.items = items, call.deleteObjects = [], call.itemObjects = [], call.items.forEach(function(item) {
+ var itemObj = {
+ dest: item.downloadDestination + "AE " + item.id,
+ source: item.downloadDestination + item.fileName
+ };
+ call.itemObjects.push(itemObj), call.deleteObjects.push(itemObj.source, itemObj.dest + path.sep + "__MACOSX"), call.unzip(itemObj)
+ }), console.log("UnzipService unzipItems numOfItems:", call.numOfItems), console.log("UnzipService unzipItems call.deleteObjects:", call.deleteObjects), console.log("UnzipService unzipItems call.deleteObjects.length:", call.deleteObjects.length)
+ },
+ unzip: function(itemObj) {
+ var unzipper = new DecompressZip(itemObj.source);
+ unzipper.on("error", function(err) {
+ console.log("UnzipService Caught an error: ", err)
+ }), unzipper.on("extract", function(log) {
+ console.log("UnzipService Finished extracting"), call.unzippedCounter++, call.unzippedCounter === call.numOfItems && (console.log("UnzipService Finished extracting all items, unzippedCounter", call.unzippedCounter), DeleteOnFileSystemService.deleteFolder(call.deleteObjects, function() {
+ console.log("UnzipService zip or mac os folder deleted"), call.deletedCounter++, console.log("UnzipService call.deletedCounter: ", call.deletedCounter), console.log("UnzipService call.deleteObjects.length: ", call.deleteObjects.length), call.deletedCounter === call.deleteObjects.length && (console.log("UnzipService ALL zip or mac os folders deleted", ReplaceModel.getState()), call.itemObjects.forEach(function(item) {
+ ReplaceModel.getState() === NOT_DOWNLOADED && "AEFT" == HOST_NAME && ImportAEService.import(item.dest)
+ }), ReplaceModel.getState() === DEFAULT && 1 < call.numOfItems ? opn(call.items[0].downloadDestination) : ReplaceModel.getState() === DEFAULT && 1 === call.numOfItems && (console.log("UnzipService opn finder"), opn(itemObj.dest)), ReplaceModel.setState(DEFAULT))
+ }))
+ }), unzipper.on("progress", function(fileIndex, fileCount) {
+ console.log("UnzipService Extracted file " + (fileIndex + 1) + " of " + fileCount)
+ }), unzipper.extract({
+ path: itemObj.dest
+ })
+ }
+ };
+ return call
+}]), app.factory("UserService", ["$rootScope", "AppModel", "LoginModel", function($rootScope, AppModel, LoginModel) {
+ var file, parsedLocalXML, cm, cx, result = {
+ readXML: function() {
+ file = AppModel.getUserXML(), fs.readFile(file, "utf8", function(err, data) {
+ if (err) throw err;
+ result.parseLocalXML(data)
+ })
+ },
+ saveData: function(cx, cm) {
+ parsedLocalXML.root.user[0].$.cm = cm, parsedLocalXML.root.user[0].$.cx = cx, result.writeToDisk()
+ },
+ parseLocalXML: function(xml) {
+ var parser = new xml2js.Parser;
+ parser.addListener("end", function(res) {
+ if (cm = (parsedLocalXML = res).root.user[0].$.cm, cx = res.root.user[0].$.cx, 0 < cm.length && 0 < cx.length) {
+ LoginModel.setCX(cx), LoginModel.setCM(cm);
+ $rootScope.$emit("api call", {
+ fn: "getUserInfo"
+ })
+ }
+ }), parser.parseString(xml)
+ },
+ writeToDisk: function() {
+ var xml = (new xml2js.Builder).buildObject(parsedLocalXML);
+ fs.writeFile(file, xml, function(err) {
+ if (err) throw err
+ })
+ }
+ };
+ return result
+}]), app.factory("ViewStateService", ["$rootScope", "ViewStateModel", "ReplaceModel", "LoginModel", function($rootScope, ViewStateModel, ReplaceModel, LoginModel) {
+ var requestedState, result = {
+ viewRequested: function(state) {
+ console.log("ViewStateService viewRequested: ", state), "downloads" !== (requestedState = state) && "previews" !== requestedState && "cart" !== requestedState || LoginModel.getLoggedIn() ? (ViewStateModel.setState(state), result.onViewApproved(!0)) : $rootScope.$emit("modal not logged in", [ERROR])
+ },
+ onViewApproved: function(result) {
+ if (console.log("ViewStateService onViewApproved ", result, requestedState), result) {
+ var fName;
+ switch (ViewStateModel.setState(requestedState), requestedState) {
+ case "downloads":
+ fName = "getPurchases";
+ break;
+ case "previews":
+ fName = "getImportedPreviews";
+ break;
+ case "cart":
+ fName = "getCart";
+ break;
+ case "freebies":
+ fName = "getFreeClips";
+ break;
+ case "bins":
+ fName = "getBin";
+ break;
+ case "search":
+ default:
+ fName = "search"
+ }
+ $rootScope.$emit("api call", {
+ fn: fName
+ })
+ } else console.log("ViewStateService onViewApproved cancel clicked in modal, stay in current view")
+ }
+ };
+ return result
+}]);
+var imgHeight, imgWidth, COUNTRIES = [{
+ name: "United States",
+ code: "US"
+ }, {
+ name: "Afghanistan",
+ code: "AF"
+ }, {
+ name: "Aland Islands",
+ code: "AX"
+ }, {
+ name: "Albania",
+ code: "AL"
+ }, {
+ name: "Algeria",
+ code: "DZ"
+ }, {
+ name: "American Samoa",
+ code: "AS"
+ }, {
+ name: "Andorra",
+ code: "AD"
+ }, {
+ name: "Angola",
+ code: "AO"
+ }, {
+ name: "Anguilla",
+ code: "AI"
+ }, {
+ name: "Antarctica",
+ code: "AQ"
+ }, {
+ name: "Antigua and Barbuda",
+ code: "AG"
+ }, {
+ name: "Argentina",
+ code: "AR"
+ }, {
+ name: "Armenia",
+ code: "AM"
+ }, {
+ name: "Aruba",
+ code: "AW"
+ }, {
+ name: "Australia",
+ code: "AU"
+ }, {
+ name: "Austria",
+ code: "AT"
+ }, {
+ name: "Azerbaijan",
+ code: "AZ"
+ }, {
+ name: "Bahamas",
+ code: "BS"
+ }, {
+ name: "Bahrain",
+ code: "BH"
+ }, {
+ name: "Bangladesh",
+ code: "BD"
+ }, {
+ name: "Barbados",
+ code: "BB"
+ }, {
+ name: "Belarus",
+ code: "BY"
+ }, {
+ name: "Belgium",
+ code: "BE"
+ }, {
+ name: "Belize",
+ code: "BZ"
+ }, {
+ name: "Benin",
+ code: "BJ"
+ }, {
+ name: "Bermuda",
+ code: "BM"
+ }, {
+ name: "Bhutan",
+ code: "BT"
+ }, {
+ name: "Bolivia",
+ code: "BO"
+ }, {
+ name: "Bosnia and Herzegovina",
+ code: "BA"
+ }, {
+ name: "Botswana",
+ code: "BW"
+ }, {
+ name: "Bouvet Island",
+ code: "BV"
+ }, {
+ name: "Brazil",
+ code: "BR"
+ }, {
+ name: "British Indian Ocean Territory",
+ code: "IO"
+ }, {
+ name: "Brunei Darussalam",
+ code: "BN"
+ }, {
+ name: "Bulgaria",
+ code: "BG"
+ }, {
+ name: "Burkina Faso",
+ code: "BF"
+ }, {
+ name: "Burundi",
+ code: "BI"
+ }, {
+ name: "Cambodia",
+ code: "KH"
+ }, {
+ name: "Cameroon",
+ code: "CM"
+ }, {
+ name: "Canada",
+ code: "CA"
+ }, {
+ name: "Cape Verde",
+ code: "CV"
+ }, {
+ name: "Cayman Islands",
+ code: "KY"
+ }, {
+ name: "Central African Republic",
+ code: "CF"
+ }, {
+ name: "Chad",
+ code: "TD"
+ }, {
+ name: "Chile",
+ code: "CL"
+ }, {
+ name: "China",
+ code: "CN"
+ }, {
+ name: "Christmas Island",
+ code: "CX"
+ }, {
+ name: "Cocos (Keeling) Islands",
+ code: "CC"
+ }, {
+ name: "Colombia",
+ code: "CO"
+ }, {
+ name: "Comoros",
+ code: "KM"
+ }, {
+ name: "Congo",
+ code: "CG"
+ }, {
+ name: "Congo, The Democratic Republic of the",
+ code: "CD"
+ }, {
+ name: "Cook Islands",
+ code: "CK"
+ }, {
+ name: "Costa Rica",
+ code: "CR"
+ }, {
+ name: "Cote D'Ivoire",
+ code: "CI"
+ }, {
+ name: "Croatia",
+ code: "HR"
+ }, {
+ name: "Cuba",
+ code: "CU"
+ }, {
+ name: "Cyprus",
+ code: "CY"
+ }, {
+ name: "Czech Republic",
+ code: "CZ"
+ }, {
+ name: "Denmark",
+ code: "DK"
+ }, {
+ name: "Djibouti",
+ code: "DJ"
+ }, {
+ name: "Dominica",
+ code: "DM"
+ }, {
+ name: "Dominican Republic",
+ code: "DO"
+ }, {
+ name: "Ecuador",
+ code: "EC"
+ }, {
+ name: "Egypt",
+ code: "EG"
+ }, {
+ name: "El Salvador",
+ code: "SV"
+ }, {
+ name: "Equatorial Guinea",
+ code: "GQ"
+ }, {
+ name: "Eritrea",
+ code: "ER"
+ }, {
+ name: "Estonia",
+ code: "EE"
+ }, {
+ name: "Ethiopia",
+ code: "ET"
+ }, {
+ name: "Falkland Islands (Malvinas)",
+ code: "FK"
+ }, {
+ name: "Faroe Islands",
+ code: "FO"
+ }, {
+ name: "Fiji",
+ code: "FJ"
+ }, {
+ name: "Finland",
+ code: "FI"
+ }, {
+ name: "France",
+ code: "FR"
+ }, {
+ name: "French Guiana",
+ code: "GF"
+ }, {
+ name: "French Polynesia",
+ code: "PF"
+ }, {
+ name: "French Southern Territories",
+ code: "TF"
+ }, {
+ name: "Gabon",
+ code: "GA"
+ }, {
+ name: "Gambia",
+ code: "GM"
+ }, {
+ name: "Georgia",
+ code: "GE"
+ }, {
+ name: "Germany",
+ code: "DE"
+ }, {
+ name: "Ghana",
+ code: "GH"
+ }, {
+ name: "Gibraltar",
+ code: "GI"
+ }, {
+ name: "Greece",
+ code: "GR"
+ }, {
+ name: "Greenland",
+ code: "GL"
+ }, {
+ name: "Grenada",
+ code: "GD"
+ }, {
+ name: "Guadeloupe",
+ code: "GP"
+ }, {
+ name: "Guam",
+ code: "GU"
+ }, {
+ name: "Guatemala",
+ code: "GT"
+ }, {
+ name: "Guernsey",
+ code: "GG"
+ }, {
+ name: "Guinea",
+ code: "GN"
+ }, {
+ name: "Guinea-Bissau",
+ code: "GW"
+ }, {
+ name: "Guyana",
+ code: "GY"
+ }, {
+ name: "Haiti",
+ code: "HT"
+ }, {
+ name: "Heard Island and Mcdonald Islands",
+ code: "HM"
+ }, {
+ name: "Holy See (Vatican City State)",
+ code: "VA"
+ }, {
+ name: "Honduras",
+ code: "HN"
+ }, {
+ name: "Hong Kong",
+ code: "HK"
+ }, {
+ name: "Hungary",
+ code: "HU"
+ }, {
+ name: "Iceland",
+ code: "IS"
+ }, {
+ name: "India",
+ code: "IN"
+ }, {
+ name: "Indonesia",
+ code: "ID"
+ }, {
+ name: "Iran, Islamic Republic Of",
+ code: "IR"
+ }, {
+ name: "Iraq",
+ code: "IQ"
+ }, {
+ name: "Ireland",
+ code: "IE"
+ }, {
+ name: "Isle of Man",
+ code: "IM"
+ }, {
+ name: "Israel",
+ code: "IL"
+ }, {
+ name: "Italy",
+ code: "IT"
+ }, {
+ name: "Jamaica",
+ code: "JM"
+ }, {
+ name: "Japan",
+ code: "JP"
+ }, {
+ name: "Jersey",
+ code: "JE"
+ }, {
+ name: "Jordan",
+ code: "JO"
+ }, {
+ name: "Kazakhstan",
+ code: "KZ"
+ }, {
+ name: "Kenya",
+ code: "KE"
+ }, {
+ name: "Kiribati",
+ code: "KI"
+ }, {
+ name: "Korea, Democratic People's Republic of",
+ code: "KP"
+ }, {
+ name: "Korea, Republic of",
+ code: "KR"
+ }, {
+ name: "Kuwait",
+ code: "KW"
+ }, {
+ name: "Kyrgyzstan",
+ code: "KG"
+ }, {
+ name: "Lao People's Democratic Republic",
+ code: "LA"
+ }, {
+ name: "Latvia",
+ code: "LV"
+ }, {
+ name: "Lebanon",
+ code: "LB"
+ }, {
+ name: "Lesotho",
+ code: "LS"
+ }, {
+ name: "Liberia",
+ code: "LR"
+ }, {
+ name: "Libyan Arab Jamahiriya",
+ code: "LY"
+ }, {
+ name: "Liechtenstein",
+ code: "LI"
+ }, {
+ name: "Lithuania",
+ code: "LT"
+ }, {
+ name: "Luxembourg",
+ code: "LU"
+ }, {
+ name: "Macao",
+ code: "MO"
+ }, {
+ name: "Macedonia, The Former Yugoslav Republic of",
+ code: "MK"
+ }, {
+ name: "Madagascar",
+ code: "MG"
+ }, {
+ name: "Malawi",
+ code: "MW"
+ }, {
+ name: "Malaysia",
+ code: "MY"
+ }, {
+ name: "Maldives",
+ code: "MV"
+ }, {
+ name: "Mali",
+ code: "ML"
+ }, {
+ name: "Malta",
+ code: "MT"
+ }, {
+ name: "Marshall Islands",
+ code: "MH"
+ }, {
+ name: "Martinique",
+ code: "MQ"
+ }, {
+ name: "Mauritania",
+ code: "MR"
+ }, {
+ name: "Mauritius",
+ code: "MU"
+ }, {
+ name: "Mayotte",
+ code: "YT"
+ }, {
+ name: "Mexico",
+ code: "MX"
+ }, {
+ name: "Micronesia, Federated States of",
+ code: "FM"
+ }, {
+ name: "Moldova, Republic of",
+ code: "MD"
+ }, {
+ name: "Monaco",
+ code: "MC"
+ }, {
+ name: "Mongolia",
+ code: "MN"
+ }, {
+ name: "Montserrat",
+ code: "MS"
+ }, {
+ name: "Morocco",
+ code: "MA"
+ }, {
+ name: "Mozambique",
+ code: "MZ"
+ }, {
+ name: "Myanmar",
+ code: "MM"
+ }, {
+ name: "Namibia",
+ code: "NA"
+ }, {
+ name: "Nauru",
+ code: "NR"
+ }, {
+ name: "Nepal",
+ code: "NP"
+ }, {
+ name: "Netherlands",
+ code: "NL"
+ }, {
+ name: "Netherlands Antilles",
+ code: "AN"
+ }, {
+ name: "New Caledonia",
+ code: "NC"
+ }, {
+ name: "New Zealand",
+ code: "NZ"
+ }, {
+ name: "Nicaragua",
+ code: "NI"
+ }, {
+ name: "Niger",
+ code: "NE"
+ }, {
+ name: "Nigeria",
+ code: "NG"
+ }, {
+ name: "Niue",
+ code: "NU"
+ }, {
+ name: "Norfolk Island",
+ code: "NF"
+ }, {
+ name: "Northern Mariana Islands",
+ code: "MP"
+ }, {
+ name: "Norway",
+ code: "NO"
+ }, {
+ name: "Oman",
+ code: "OM"
+ }, {
+ name: "Pakistan",
+ code: "PK"
+ }, {
+ name: "Palau",
+ code: "PW"
+ }, {
+ name: "Palestinian Territory, Occupied",
+ code: "PS"
+ }, {
+ name: "Panama",
+ code: "PA"
+ }, {
+ name: "Papua New Guinea",
+ code: "PG"
+ }, {
+ name: "Paraguay",
+ code: "PY"
+ }, {
+ name: "Peru",
+ code: "PE"
+ }, {
+ name: "Philippines",
+ code: "PH"
+ }, {
+ name: "Pitcairn",
+ code: "PN"
+ }, {
+ name: "Poland",
+ code: "PL"
+ }, {
+ name: "Portugal",
+ code: "PT"
+ }, {
+ name: "Puerto Rico",
+ code: "PR"
+ }, {
+ name: "Qatar",
+ code: "QA"
+ }, {
+ name: "Reunion",
+ code: "RE"
+ }, {
+ name: "Romania",
+ code: "RO"
+ }, {
+ name: "Russian Federation",
+ code: "RU"
+ }, {
+ name: "Rwanda",
+ code: "RW"
+ }, {
+ name: "Saint Helena",
+ code: "SH"
+ }, {
+ name: "Saint Kitts and Nevis",
+ code: "KN"
+ }, {
+ name: "Saint Lucia",
+ code: "LC"
+ }, {
+ name: "Saint Pierre and Miquelon",
+ code: "PM"
+ }, {
+ name: "Saint Vincent and the Grenadines",
+ code: "VC"
+ }, {
+ name: "Samoa",
+ code: "WS"
+ }, {
+ name: "San Marino",
+ code: "SM"
+ }, {
+ name: "Sao Tome and Principe",
+ code: "ST"
+ }, {
+ name: "Saudi Arabia",
+ code: "SA"
+ }, {
+ name: "Senegal",
+ code: "SN"
+ }, {
+ name: "Serbia and Montenegro",
+ code: "CS"
+ }, {
+ name: "Seychelles",
+ code: "SC"
+ }, {
+ name: "Sierra Leone",
+ code: "SL"
+ }, {
+ name: "Singapore",
+ code: "SG"
+ }, {
+ name: "Slovakia",
+ code: "SK"
+ }, {
+ name: "Slovenia",
+ code: "SI"
+ }, {
+ name: "Solomon Islands",
+ code: "SB"
+ }, {
+ name: "Somalia",
+ code: "SO"
+ }, {
+ name: "South Africa",
+ code: "ZA"
+ }, {
+ name: "South Georgia and the South Sandwich Islands",
+ code: "GS"
+ }, {
+ name: "Spain",
+ code: "ES"
+ }, {
+ name: "Sri Lanka",
+ code: "LK"
+ }, {
+ name: "Sudan",
+ code: "SD"
+ }, {
+ name: "Suriname",
+ code: "SR"
+ }, {
+ name: "Svalbard and Jan Mayen",
+ code: "SJ"
+ }, {
+ name: "Swaziland",
+ code: "SZ"
+ }, {
+ name: "Sweden",
+ code: "SE"
+ }, {
+ name: "Switzerland",
+ code: "CH"
+ }, {
+ name: "Syrian Arab Republic",
+ code: "SY"
+ }, {
+ name: "Taiwan, Province of China",
+ code: "TW"
+ }, {
+ name: "Tajikistan",
+ code: "TJ"
+ }, {
+ name: "Tanzania, United Republic of",
+ code: "TZ"
+ }, {
+ name: "Thailand",
+ code: "TH"
+ }, {
+ name: "Timor-Leste",
+ code: "TL"
+ }, {
+ name: "Togo",
+ code: "TG"
+ }, {
+ name: "Tokelau",
+ code: "TK"
+ }, {
+ name: "Tonga",
+ code: "TO"
+ }, {
+ name: "Trinidad and Tobago",
+ code: "TT"
+ }, {
+ name: "Tunisia",
+ code: "TN"
+ }, {
+ name: "Turkey",
+ code: "TR"
+ }, {
+ name: "Turkmenistan",
+ code: "TM"
+ }, {
+ name: "Turks and Caicos Islands",
+ code: "TC"
+ }, {
+ name: "Tuvalu",
+ code: "TV"
+ }, {
+ name: "Uganda",
+ code: "UG"
+ }, {
+ name: "Ukraine",
+ code: "UA"
+ }, {
+ name: "United Arab Emirates",
+ code: "AE"
+ }, {
+ name: "United Kingdom",
+ code: "GB"
+ }, {
+ name: "United States",
+ code: "US"
+ }, {
+ name: "United States Minor Outlying Islands",
+ code: "UM"
+ }, {
+ name: "Uruguay",
+ code: "UY"
+ }, {
+ name: "Uzbekistan",
+ code: "UZ"
+ }, {
+ name: "Vanuatu",
+ code: "VU"
+ }, {
+ name: "Venezuela",
+ code: "VE"
+ }, {
+ name: "Vietnam",
+ code: "VN"
+ }, {
+ name: "Virgin Islands, British",
+ code: "VG"
+ }, {
+ name: "Virgin Islands, U.S.",
+ code: "VI"
+ }, {
+ name: "Wallis and Futuna",
+ code: "WF"
+ }, {
+ name: "Western Sahara",
+ code: "EH"
+ }, {
+ name: "Yemen",
+ code: "YE"
+ }, {
+ name: "Zambia",
+ code: "ZM"
+ }, {
+ name: "Zimbabwe",
+ code: "ZW"
+ }],
+ STATES = [{
+ name: "Alabama",
+ label: "Alabama",
+ code: "AL"
+ }, {
+ name: "Alaska",
+ label: "Alaska",
+ code: "AK"
+ }, {
+ name: "American Samoa",
+ label: "American Samoa",
+ code: "AS"
+ }, {
+ name: "Arizona",
+ label: "Arizona",
+ code: "AZ"
+ }, {
+ name: "Arkansas",
+ label: "Arkansas",
+ code: "AR"
+ }, {
+ name: "Armed Forces Europe",
+ label: "Armed Forces Europe",
+ code: "AE"
+ }, {
+ name: "Armed Forces Pacific",
+ label: "Armed Forces Pacific",
+ code: "AP"
+ }, {
+ name: "Armed Forces the Americas",
+ label: "Armed Forces the Americas",
+ code: "AA"
+ }, {
+ name: "California",
+ label: "California",
+ code: "CA"
+ }, {
+ name: "Colorado",
+ label: "Colorado",
+ code: "CO"
+ }, {
+ name: "Connecticut",
+ label: "Connecticut",
+ code: "CT"
+ }, {
+ name: "Delaware",
+ label: "Delaware",
+ code: "DE"
+ }, {
+ name: "District of Columbia",
+ label: "District of Columbia",
+ code: "DC"
+ }, {
+ name: "Federated States of Micronesia",
+ label: "Federated States of Micronesia",
+ code: "FM"
+ }, {
+ name: "Florida",
+ label: "Florida",
+ code: "FL"
+ }, {
+ name: "Georgia",
+ label: "Georgia",
+ code: "GA"
+ }, {
+ name: "Guam",
+ label: "Guam",
+ code: "GU"
+ }, {
+ name: "Hawaii",
+ label: "Hawaii",
+ code: "HI"
+ }, {
+ name: "Idaho",
+ label: "Idaho",
+ code: "ID"
+ }, {
+ name: "Illinois",
+ label: "Illinois",
+ code: "IL"
+ }, {
+ name: "Indiana",
+ label: "Indiana",
+ code: "IN"
+ }, {
+ name: "Iowa",
+ label: "Iowa",
+ code: "IA"
+ }, {
+ name: "Kansas",
+ label: "Kansas",
+ code: "KS"
+ }, {
+ name: "Kentucky",
+ label: "Kentucky",
+ code: "KY"
+ }, {
+ name: "Louisiana",
+ label: "Louisiana",
+ code: "LA"
+ }, {
+ name: "Maine",
+ label: "Maine",
+ code: "ME"
+ }, {
+ name: "Marshall Islands",
+ label: "Marshall Islands",
+ code: "MH"
+ }, {
+ name: "Maryland",
+ label: "Maryland",
+ code: "MD"
+ }, {
+ name: "Massachusetts",
+ label: "Massachusetts",
+ code: "MA"
+ }, {
+ name: "Michigan",
+ label: "Michigan",
+ code: "MI"
+ }, {
+ name: "Minnesota",
+ label: "Minnesota",
+ code: "MN"
+ }, {
+ name: "Mississippi",
+ label: "Mississippi",
+ code: "MS"
+ }, {
+ name: "Missouri",
+ label: "Missouri",
+ code: "MO"
+ }, {
+ name: "Montana",
+ label: "Montana",
+ code: "MT"
+ }, {
+ name: "Nebraska",
+ label: "Nebraska",
+ code: "NE"
+ }, {
+ name: "Nevada",
+ label: "Nevada",
+ code: "NV"
+ }, {
+ name: "New Hampshire",
+ label: "New Hampshire",
+ code: "NH"
+ }, {
+ name: "New Jersey",
+ label: "New Jersey",
+ code: "NJ"
+ }, {
+ name: "New Mexico",
+ label: "New Mexico",
+ code: "NM"
+ }, {
+ name: "New York",
+ label: "New York",
+ code: "NY"
+ }, {
+ name: "North Carolina",
+ label: "North Carolina",
+ code: "NC"
+ }, {
+ name: "North Dakota",
+ label: "North Dakota",
+ code: "ND"
+ }, {
+ name: "Northern Mariana Islands",
+ label: "Northern Mariana Islands",
+ code: "MP"
+ }, {
+ name: "Ohio",
+ label: "Ohio",
+ code: "OH"
+ }, {
+ name: "Oklahoma",
+ label: "Oklahoma",
+ code: "OK"
+ }, {
+ name: "Oregon",
+ label: "Oregon",
+ code: "OR"
+ }, {
+ name: "Pennsylvania",
+ label: "Pennsylvania",
+ code: "PA"
+ }, {
+ name: "Puerto Rico",
+ label: "Puerto Rico",
+ code: "PR"
+ }, {
+ name: "Rhode Island",
+ label: "Rhode Island",
+ code: "RI"
+ }, {
+ name: "South Carolina",
+ label: "South Carolina",
+ code: "SC"
+ }, {
+ name: "South Dakota",
+ label: "South Dakota",
+ code: "SD"
+ }, {
+ name: "Tennessee",
+ label: "Tennessee",
+ code: "TN"
+ }, {
+ name: "Texas",
+ label: "Texas",
+ code: "TX"
+ }, {
+ name: "Utah",
+ label: "Utah",
+ code: "UT"
+ }, {
+ name: "Vermont",
+ label: "Vermont",
+ code: "VT"
+ }, {
+ name: "Virgin Islands, U.S.",
+ label: "Virgin Islands, U.S.",
+ code: "VI"
+ }, {
+ name: "Virginia",
+ label: "Virginia",
+ code: "VA"
+ }, {
+ name: "Washington",
+ label: "Washington",
+ code: "WA"
+ }, {
+ name: "West Virginia",
+ label: "West Virginia",
+ code: "WV"
+ }, {
+ name: "Wisconsin",
+ label: "Wisconsin",
+ code: "WI"
+ }, {
+ name: "Wyoming",
+ label: "Wyoming",
+ code: "WY"
+ }];
+
+function get_browser() {
+ var tem, ua = navigator.userAgent,
+ M = ua.match(/(opera|chrome|safari|firefox|msie|trident(?=\/))\/?\s*(\d+)/i) || [];
+ return /trident/i.test(M[1]) ? "IE " + ((tem = /\brv[ :]+(\d+)/g.exec(ua) || [])[1] || "") : "Chrome" === M[1] && null != (tem = ua.match(/\bOPR\/(\d+)/)) ? "Opera " + tem[1] : (M = M[2] ? [M[1], M[2]] : [navigator.appName, navigator.appVersion, "-?"], null != (tem = ua.match(/version\/(\d+)/i)) && M.splice(1, 1, tem[1]), M[0])
+}
+
+function get_browser_version() {
+ var tem, ua = navigator.userAgent,
+ M = ua.match(/(opera|chrome|safari|firefox|msie|trident(?=\/))\/?\s*(\d+)/i) || [];
+ return /trident/i.test(M[1]) ? "IE " + ((tem = /\brv[ :]+(\d+)/g.exec(ua) || [])[1] || "") : "Chrome" === M[1] && null != (tem = ua.match(/\bOPR\/(\d+)/)) ? "Opera " + tem[1] : (M = M[2] ? [M[1], M[2]] : [navigator.appName, navigator.appVersion, "-?"], null != (tem = ua.match(/version\/(\d+)/i)) && M.splice(1, 1, tem[1]), M[1])
+}
+
+function findHHandWW() {
+ return imgHeight = this.height, imgWidth = this.width, !0
+}
+
+function showImage(imgPath) {
+ var myImage = new Image;
+ myImage.name = imgPath, myImage.onload = findHHandWW, myImage.src = imgPath
+}
+
+function log(className, prefix, obj) {
+ if (prefix = " " + prefix + ": ", obj instanceof Array) obj.forEach(function(entry) {
+ log(className, "item", entry)
+ });
+ else
+ for (key in console.log(className + ":"), obj) console.log(prefix + key + ": " + obj[key]), "formats" === key && obj[key].forEach(function(entry) {
+ log(className, " format", entry)
+ }), "versions" === key && obj[key].forEach(function(entry) {
+ log(className, " versions", entry)
+ })
+}
+
+function ExtendedID() {}
+
+function getAbbrName(name, len) {
+ return name && name.length > len ? name.slice(0, len) + "..." : name
+}
+
+function convertArrayToCommaSeperatedString(ids) {
+ var idsToString = "";
+ return ids.forEach(function(id) {
+ idsToString += id + ","
+ }), idsToString = idsToString.slice(0, -1)
+}
+
+function getFormattedName(input) {
+ for (; - 1 != input.indexOf(",");) input = input.replace(",", " ");
+ for (; - 1 != input.indexOf("&");) input = input.replace("&", "and");
+ for (; - 1 != input.indexOf("/");) input = input.replace("/", " ");
+ for (; - 1 != input.indexOf("'");) input = input.replace("'", " ");
+ for (; - 1 != input.indexOf("(");) input = input.replace("(", " ");
+ for (; - 1 != input.indexOf(")");) input = input.replace(")", " ");
+ for (; - 1 != input.indexOf(":");) input = input.replace(":", " ");
+ for (; - 1 != input.indexOf(" ");) input = input.replace(" ", " ");
+ return input
+}
+
+function getUID() {
+ var d = (new Date).getTime();
+ return "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, function(c) {
+ var r = (d + 16 * Math.random()) % 16 | 0;
+ return d = Math.floor(d / 16), ("x" == c ? r : 3 & r | 8).toString(16)
+ })
+}
+
+function getStringPosition(string, subString, index) {
+ return string.split(subString, index).join(subString).length
+}
+
+function gup(name, url) {
+ url || (url = location.href), name = name.replace(/[\[]/, "\\[").replace(/[\]]/, "\\]");
+ var results = new RegExp("[\\?&]" + name + "=([^]*)").exec(url);
+ return null == results ? null : results[1]
+}
+
+function checkVersion(tv, uv) {
+ var updaterVersion = uv;
+ if (tv === updaterVersion) return !1;
+ var splitThis = tv.split("."),
+ splitThisInt = [];
+ splitThis.forEach(function(string) {
+ splitThisInt.push(parseInt(string))
+ });
+ var splitUpdater = updaterVersion.split("."),
+ splitUpdaterInt = [];
+ return splitUpdater.forEach(function(string) {
+ splitUpdaterInt.push(parseInt(string))
+ }), splitUpdaterInt[0] > splitThisInt[0] || (splitUpdaterInt[0] >= splitThisInt[0] && splitUpdaterInt[1] > splitThisInt[1] || splitUpdaterInt[0] >= splitThisInt[0] && splitUpdaterInt[1] >= splitThisInt[1] && splitUpdaterInt[2] > splitThisInt[2])
+}
+
+function getConvertedVideoStandard(vs) {
+ var standard;
+ switch (parseInt(vs)) {
+ case 0:
+ standard = "Multimedia / Unknown";
+ break;
+ case 1:
+ standard = "NTSC D1";
+ break;
+ case 2:
+ standard = "NTSC DV";
+ break;
+ case 3:
+ standard = "PAL / PAL DV";
+ break;
+ case 4:
+ standard = "HD 1080";
+ break;
+ case 5:
+ standard = "HDV 720p";
+ break;
+ case 6:
+ standard = "Other Hi-Def";
+ break;
+ case 7:
+ standard = "Multimedia";
+ break;
+ case 8:
+ standard = "HDV 1080i";
+ break;
+ case 9:
+ standard = "HD 720";
+ break;
+ case 10:
+ standard = "4k+";
+ break;
+ case 100:
+ standard = "Music";
+ break;
+ case 101:
+ standard = "Sound effect";
+ break;
+ case 200:
+ standard = "AE";
+ break;
+ case 300:
+ standard = "Photo";
+ break;
+ case 301:
+ standard = "Illustration";
+ break;
+ case 400:
+ standard = "3D"
+ }
+ return standard
+}
+
+function getMediaType(vs) {
+ var type;
+ switch (vs) {
+ case "Music":
+ case "Sound effect":
+ case "Photo":
+ case "Illustration":
+ case "AE":
+ type = vs;
+ break;
+ default:
+ type = "Video"
+ }
+ return type
+}
+Number.prototype.formatMoney = function(decPlaces, thouSeparator, decSeparator, currencySymbol) {
+ decPlaces = isNaN(decPlaces = Math.abs(decPlaces)) ? 2 : decPlaces, decSeparator = null == decSeparator ? "." : decSeparator, thouSeparator = null == thouSeparator ? "," : thouSeparator, currencySymbol = null == currencySymbol ? "$" : currencySymbol;
+ var n = this,
+ sign = n < 0 ? "-" : "",
+ i = parseInt(n = Math.abs(+n || 0).toFixed(decPlaces)) + "",
+ j = 3 < (j = i.length) ? j % 3 : 0;
+ return sign + currencySymbol + (j ? i.substr(0, j) + thouSeparator : "") + i.substr(j).replace(/(\d{3})(?=\d)/g, "$1" + thouSeparator) + (decPlaces ? decSeparator + Math.abs(n - i).toFixed(decPlaces).slice(2) : "")
+ },
+ function() {
+ function Point(x, y) {
+ this.x = x || 0, this.y = y || 0
+ }
+ Point.prototype.x = null, Point.prototype.y = null, Point.prototype.add = function(v) {
+ return new Point(this.x + v.x, this.y + v.y)
+ }, Point.prototype.clone = function() {
+ return new Point(this.x, this.y)
+ }, Point.prototype.degreesTo = function(v) {
+ var dx = this.x - v.x,
+ dy = this.y - v.y;
+ return Math.atan2(dy, dx) * (180 / Math.PI)
+ }, Point.prototype.distance = function(v) {
+ var x = this.x - v.x,
+ y = this.y - v.y;
+ return Math.sqrt(x * x + y * y)
+ }, Point.prototype.equals = function(toCompare) {
+ return this.x == toCompare.x && this.y == toCompare.y
+ }, Point.prototype.interpolate = function(v, f) {
+ return new Point((this.x + v.x) * f, (this.y + v.y) * f)
+ }, Point.prototype.length = function() {
+ return Math.sqrt(this.x * this.x + this.y * this.y)
+ }, Point.prototype.normalize = function(thickness) {
+ var l = this.length();
+ this.x = this.x / l * thickness, this.y = this.y / l * thickness
+ }, Point.prototype.orbit = function(origin, arcWidth, arcHeight, degrees) {
+ var radians = degrees * (Math.PI / 180);
+ this.x = origin.x + arcWidth * Math.cos(radians), this.y = origin.y + arcHeight * Math.sin(radians)
+ }, Point.prototype.offset = function(dx, dy) {
+ this.x += dx, this.y += dy
+ }, Point.prototype.subtract = function(v) {
+ return new Point(this.x - v.x, this.y - v.y)
+ }, Point.prototype.toString = function() {
+ return "(x=" + this.x + ", y=" + this.y + ")"
+ }, Point.interpolate = function(pt1, pt2, f) {
+ return new Point((pt1.x + pt2.x) * f, (pt1.y + pt2.y) * f)
+ }, Point.polar = function(len, angle) {
+ return new Point(len * Math.sin(angle), len * Math.cos(angle))
+ }, Point.distance = function(pt1, pt2) {
+ var x = pt1.x - pt2.x,
+ y = pt1.y - pt2.y;
+ return Math.sqrt(x * x + y * y)
+ }, this.Point = window.Point = Point
+ }(), ExtendedID.extend = function(id) {
+ if (id) {
+ for (var extendedID = id.toString(); extendedID.length < 9;) extendedID = "0" + extendedID;
+ return extendedID
+ }
+ }, String.prototype.insert = function(index, string) {
+ return 0 < index ? this.substring(0, index) + string + this.substring(index, this.length) : string + this
+ }, String.prototype.replaceAll = function(search, replacement) {
+ return this.replace(new RegExp(search, "g"), replacement)
+ }, getMousePosition = function(element) {
+ for (var xPosition = 0, yPosition = 0; element;) xPosition += element.offsetLeft - element.scrollLeft + element.clientLeft, yPosition += element.offsetTop - element.scrollTop + element.clientTop, element = element.offsetParent;
+ return {
+ x: xPosition,
+ y: yPosition
+ }
+ }, getScroll = function() {
+ if (null != window.pageYOffset) return [pageXOffset, pageYOffset];
+ var d = document,
+ r = d.documentElement,
+ b = d.body;
+ return [r.scrollLeft || b.scrollLeft || 0, r.scrollTop || b.scrollTop || 0]
+ }, getUserHome = function() {
+ return require("os").homedir()
+ }, getName = function(input) {
+ for (; - 1 != input.indexOf(",");) input = input.replace(",", " ");
+ for (; - 1 != input.indexOf("&");) input = input.replace("&", "and");
+ for (; - 1 != input.indexOf("/");) input = input.replace("/", " ");
+ for (; - 1 != input.indexOf("'");) input = input.replace("'", " ");
+ for (; - 1 != input.indexOf("(");) input = input.replace("(", " ");
+ for (; - 1 != input.indexOf(")");) input = input.replace(")", " ");
+ for (; - 1 != input.indexOf(":");) input = input.replace(":", " ");
+ return input
+ }, getPosition = function(element) {
+ for (var xPosition = 0, yPosition = 0; element;) xPosition += element.offsetLeft - element.scrollLeft + element.clientLeft, yPosition += element.offsetTop - element.scrollTop + element.clientTop, element = element.offsetParent;
+ return {
+ x: xPosition,
+ y: yPosition
+ }
+ }, getChromeVersion = function() {
+ var raw = navigator.userAgent.match(/Chrom(e|ium)\/([0-9]+)\./);
+ return !!raw && parseInt(raw[2], 10)
+ };
diff --git a/pype/aport/static/index.html b/pype/aport/static/index.html
index 0da3f2abdb..d9ed3b8218 100644
--- a/pype/aport/static/index.html
+++ b/pype/aport/static/index.html
@@ -1,5 +1,6 @@
+
Pype extention
@@ -7,6 +8,18 @@
+
+
+
+
+
-
+
+
+ Refresh panel
-
+
+
diff --git a/pype/premiere/extensions/com.pond5.ppro/remote/index.html b/pype/premiere/extensions/com.pond5.ppro/remote/index.html
new file mode 100644
index 0000000000..19427f2b94
--- /dev/null
+++ b/pype/premiere/extensions/com.pond5.ppro/remote/index.html
@@ -0,0 +1,337 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/pype/premiere/extensions/com.pond5.ppro/remote/index_files/CSInterface-8.js b/pype/premiere/extensions/com.pond5.ppro/remote/index_files/CSInterface-8.js
new file mode 100644
index 0000000000..4239391efd
--- /dev/null
+++ b/pype/premiere/extensions/com.pond5.ppro/remote/index_files/CSInterface-8.js
@@ -0,0 +1,1193 @@
+/**************************************************************************************************
+*
+* ADOBE SYSTEMS INCORPORATED
+* Copyright 2013 Adobe Systems Incorporated
+* All Rights Reserved.
+*
+* NOTICE: Adobe permits you to use, modify, and distribute this file in accordance with the
+* terms of the Adobe license agreement accompanying it. If you have received this file from a
+* source other than Adobe, then your use, modification, or distribution of it requires the prior
+* written permission of Adobe.
+*
+**************************************************************************************************/
+
+/** CSInterface - v8.0.0 */
+
+/**
+ * Stores constants for the window types supported by the CSXS infrastructure.
+ */
+function CSXSWindowType()
+{
+}
+
+/** Constant for the CSXS window type Panel. */
+CSXSWindowType._PANEL = "Panel";
+
+/** Constant for the CSXS window type Modeless. */
+CSXSWindowType._MODELESS = "Modeless";
+
+/** Constant for the CSXS window type ModalDialog. */
+CSXSWindowType._MODAL_DIALOG = "ModalDialog";
+
+/** EvalScript error message */
+EvalScript_ErrMessage = "EvalScript error.";
+
+/**
+ * @class Version
+ * Defines a version number with major, minor, micro, and special
+ * components. The major, minor and micro values are numeric; the special
+ * value can be any string.
+ *
+ * @param major The major version component, a positive integer up to nine digits long.
+ * @param minor The minor version component, a positive integer up to nine digits long.
+ * @param micro The micro version component, a positive integer up to nine digits long.
+ * @param special The special version component, an arbitrary string.
+ *
+ * @return A new \c Version object.
+ */
+function Version(major, minor, micro, special)
+{
+ this.major = major;
+ this.minor = minor;
+ this.micro = micro;
+ this.special = special;
+}
+
+/**
+ * The maximum value allowed for a numeric version component.
+ * This reflects the maximum value allowed in PlugPlug and the manifest schema.
+ */
+Version.MAX_NUM = 999999999;
+
+/**
+ * @class VersionBound
+ * Defines a boundary for a version range, which associates a \c Version object
+ * with a flag for whether it is an inclusive or exclusive boundary.
+ *
+ * @param version The \c #Version object.
+ * @param inclusive True if this boundary is inclusive, false if it is exclusive.
+ *
+ * @return A new \c VersionBound object.
+ */
+function VersionBound(version, inclusive)
+{
+ this.version = version;
+ this.inclusive = inclusive;
+}
+
+/**
+ * @class VersionRange
+ * Defines a range of versions using a lower boundary and optional upper boundary.
+ *
+ * @param lowerBound The \c #VersionBound object.
+ * @param upperBound The \c #VersionBound object, or null for a range with no upper boundary.
+ *
+ * @return A new \c VersionRange object.
+ */
+function VersionRange(lowerBound, upperBound)
+{
+ this.lowerBound = lowerBound;
+ this.upperBound = upperBound;
+}
+
+/**
+ * @class Runtime
+ * Represents a runtime related to the CEP infrastructure.
+ * Extensions can declare dependencies on particular
+ * CEP runtime versions in the extension manifest.
+ *
+ * @param name The runtime name.
+ * @param version A \c #VersionRange object that defines a range of valid versions.
+ *
+ * @return A new \c Runtime object.
+ */
+function Runtime(name, versionRange)
+{
+ this.name = name;
+ this.versionRange = versionRange;
+}
+
+/**
+* @class Extension
+* Encapsulates a CEP-based extension to an Adobe application.
+*
+* @param id The unique identifier of this extension.
+* @param name The localizable display name of this extension.
+* @param mainPath The path of the "index.html" file.
+* @param basePath The base path of this extension.
+* @param windowType The window type of the main window of this extension.
+ Valid values are defined by \c #CSXSWindowType.
+* @param width The default width in pixels of the main window of this extension.
+* @param height The default height in pixels of the main window of this extension.
+* @param minWidth The minimum width in pixels of the main window of this extension.
+* @param minHeight The minimum height in pixels of the main window of this extension.
+* @param maxWidth The maximum width in pixels of the main window of this extension.
+* @param maxHeight The maximum height in pixels of the main window of this extension.
+* @param defaultExtensionDataXml The extension data contained in the default \c ExtensionDispatchInfo section of the extension manifest.
+* @param specialExtensionDataXml The extension data contained in the application-specific \c ExtensionDispatchInfo section of the extension manifest.
+* @param requiredRuntimeList An array of \c Runtime objects for runtimes required by this extension.
+* @param isAutoVisible True if this extension is visible on loading.
+* @param isPluginExtension True if this extension has been deployed in the Plugins folder of the host application.
+*
+* @return A new \c Extension object.
+*/
+function Extension(id, name, mainPath, basePath, windowType, width, height, minWidth, minHeight, maxWidth, maxHeight,
+ defaultExtensionDataXml, specialExtensionDataXml, requiredRuntimeList, isAutoVisible, isPluginExtension)
+{
+ this.id = id;
+ this.name = name;
+ this.mainPath = mainPath;
+ this.basePath = basePath;
+ this.windowType = windowType;
+ this.width = width;
+ this.height = height;
+ this.minWidth = minWidth;
+ this.minHeight = minHeight;
+ this.maxWidth = maxWidth;
+ this.maxHeight = maxHeight;
+ this.defaultExtensionDataXml = defaultExtensionDataXml;
+ this.specialExtensionDataXml = specialExtensionDataXml;
+ this.requiredRuntimeList = requiredRuntimeList;
+ this.isAutoVisible = isAutoVisible;
+ this.isPluginExtension = isPluginExtension;
+}
+
+/**
+ * @class CSEvent
+ * A standard JavaScript event, the base class for CEP events.
+ *
+ * @param type The name of the event type.
+ * @param scope The scope of event, can be "GLOBAL" or "APPLICATION".
+ * @param appId The unique identifier of the application that generated the event.
+ * @param extensionId The unique identifier of the extension that generated the event.
+ *
+ * @return A new \c CSEvent object
+ */
+function CSEvent(type, scope, appId, extensionId)
+{
+ this.type = type;
+ this.scope = scope;
+ this.appId = appId;
+ this.extensionId = extensionId;
+}
+
+/** Event-specific data. */
+CSEvent.prototype.data = "";
+
+/**
+ * @class SystemPath
+ * Stores operating-system-specific location constants for use in the
+ * \c #CSInterface.getSystemPath() method.
+ * @return A new \c SystemPath object.
+ */
+function SystemPath()
+{
+}
+
+/** The path to user data. */
+SystemPath.USER_DATA = "userData";
+
+/** The path to common files for Adobe applications. */
+SystemPath.COMMON_FILES = "commonFiles";
+
+/** The path to the user's default document folder. */
+SystemPath.MY_DOCUMENTS = "myDocuments";
+
+/** @deprecated. Use \c #SystemPath.Extension. */
+SystemPath.APPLICATION = "application";
+
+/** The path to current extension. */
+SystemPath.EXTENSION = "extension";
+
+/** The path to hosting application's executable. */
+SystemPath.HOST_APPLICATION = "hostApplication";
+
+/**
+ * @class ColorType
+ * Stores color-type constants.
+ */
+function ColorType()
+{
+}
+
+/** RGB color type. */
+ColorType.RGB = "rgb";
+
+/** Gradient color type. */
+ColorType.GRADIENT = "gradient";
+
+/** Null color type. */
+ColorType.NONE = "none";
+
+/**
+ * @class RGBColor
+ * Stores an RGB color with red, green, blue, and alpha values.
+ * All values are in the range [0.0 to 255.0]. Invalid numeric values are
+ * converted to numbers within this range.
+ *
+ * @param red The red value, in the range [0.0 to 255.0].
+ * @param green The green value, in the range [0.0 to 255.0].
+ * @param blue The blue value, in the range [0.0 to 255.0].
+ * @param alpha The alpha (transparency) value, in the range [0.0 to 255.0].
+ * The default, 255.0, means that the color is fully opaque.
+ *
+ * @return A new RGBColor object.
+ */
+function RGBColor(red, green, blue, alpha)
+{
+ this.red = red;
+ this.green = green;
+ this.blue = blue;
+ this.alpha = alpha;
+}
+
+/**
+ * @class Direction
+ * A point value in which the y component is 0 and the x component
+ * is positive or negative for a right or left direction,
+ * or the x component is 0 and the y component is positive or negative for
+ * an up or down direction.
+ *
+ * @param x The horizontal component of the point.
+ * @param y The vertical component of the point.
+ *
+ * @return A new \c Direction object.
+ */
+function Direction(x, y)
+{
+ this.x = x;
+ this.y = y;
+}
+
+/**
+ * @class GradientStop
+ * Stores gradient stop information.
+ *
+ * @param offset The offset of the gradient stop, in the range [0.0 to 1.0].
+ * @param rgbColor The color of the gradient at this point, an \c #RGBColor object.
+ *
+ * @return GradientStop object.
+ */
+function GradientStop(offset, rgbColor)
+{
+ this.offset = offset;
+ this.rgbColor = rgbColor;
+}
+
+/**
+ * @class GradientColor
+ * Stores gradient color information.
+ *
+ * @param type The gradient type, must be "linear".
+ * @param direction A \c #Direction object for the direction of the gradient
+ (up, down, right, or left).
+ * @param numStops The number of stops in the gradient.
+ * @param gradientStopList An array of \c #GradientStop objects.
+ *
+ * @return A new \c GradientColor object.
+ */
+function GradientColor(type, direction, numStops, arrGradientStop)
+{
+ this.type = type;
+ this.direction = direction;
+ this.numStops = numStops;
+ this.arrGradientStop = arrGradientStop;
+}
+
+/**
+ * @class UIColor
+ * Stores color information, including the type, anti-alias level, and specific color
+ * values in a color object of an appropriate type.
+ *
+ * @param type The color type, 1 for "rgb" and 2 for "gradient".
+ The supplied color object must correspond to this type.
+ * @param antialiasLevel The anti-alias level constant.
+ * @param color A \c #RGBColor or \c #GradientColor object containing specific color information.
+ *
+ * @return A new \c UIColor object.
+ */
+function UIColor(type, antialiasLevel, color)
+{
+ this.type = type;
+ this.antialiasLevel = antialiasLevel;
+ this.color = color;
+}
+
+/**
+ * @class AppSkinInfo
+ * Stores window-skin properties, such as color and font. All color parameter values are \c #UIColor objects except that systemHighlightColor is \c #RGBColor object.
+ *
+ * @param baseFontFamily The base font family of the application.
+ * @param baseFontSize The base font size of the application.
+ * @param appBarBackgroundColor The application bar background color.
+ * @param panelBackgroundColor The background color of the extension panel.
+ * @param appBarBackgroundColorSRGB The application bar background color, as sRGB.
+ * @param panelBackgroundColorSRGB The background color of the extension panel, as sRGB.
+ * @param systemHighlightColor The highlight color of the extension panel, if provided by the host application. Otherwise, the operating-system highlight color.
+ *
+ * @return AppSkinInfo object.
+ */
+function AppSkinInfo(baseFontFamily, baseFontSize, appBarBackgroundColor, panelBackgroundColor, appBarBackgroundColorSRGB, panelBackgroundColorSRGB, systemHighlightColor)
+{
+ this.baseFontFamily = baseFontFamily;
+ this.baseFontSize = baseFontSize;
+ this.appBarBackgroundColor = appBarBackgroundColor;
+ this.panelBackgroundColor = panelBackgroundColor;
+ this.appBarBackgroundColorSRGB = appBarBackgroundColorSRGB;
+ this.panelBackgroundColorSRGB = panelBackgroundColorSRGB;
+ this.systemHighlightColor = systemHighlightColor;
+}
+
+/**
+ * @class HostEnvironment
+ * Stores information about the environment in which the extension is loaded.
+ *
+ * @param appName The application's name.
+ * @param appVersion The application's version.
+ * @param appLocale The application's current license locale.
+ * @param appUILocale The application's current UI locale.
+ * @param appId The application's unique identifier.
+ * @param isAppOnline True if the application is currently online.
+ * @param appSkinInfo An \c #AppSkinInfo object containing the application's default color and font styles.
+ *
+ * @return A new \c HostEnvironment object.
+ */
+function HostEnvironment(appName, appVersion, appLocale, appUILocale, appId, isAppOnline, appSkinInfo)
+{
+ this.appName = appName;
+ this.appVersion = appVersion;
+ this.appLocale = appLocale;
+ this.appUILocale = appUILocale;
+ this.appId = appId;
+ this.isAppOnline = isAppOnline;
+ this.appSkinInfo = appSkinInfo;
+}
+
+/**
+ * @class HostCapabilities
+ * Stores information about the host capabilities.
+ *
+ * @param EXTENDED_PANEL_MENU True if the application supports panel menu.
+ * @param EXTENDED_PANEL_ICONS True if the application supports panel icon.
+ * @param DELEGATE_APE_ENGINE True if the application supports delegated APE engine.
+ * @param SUPPORT_HTML_EXTENSIONS True if the application supports HTML extensions.
+ * @param DISABLE_FLASH_EXTENSIONS True if the application disables FLASH extensions.
+ *
+ * @return A new \c HostCapabilities object.
+ */
+function HostCapabilities(EXTENDED_PANEL_MENU, EXTENDED_PANEL_ICONS, DELEGATE_APE_ENGINE, SUPPORT_HTML_EXTENSIONS, DISABLE_FLASH_EXTENSIONS)
+{
+ this.EXTENDED_PANEL_MENU = EXTENDED_PANEL_MENU;
+ this.EXTENDED_PANEL_ICONS = EXTENDED_PANEL_ICONS;
+ this.DELEGATE_APE_ENGINE = DELEGATE_APE_ENGINE;
+ this.SUPPORT_HTML_EXTENSIONS = SUPPORT_HTML_EXTENSIONS;
+ this.DISABLE_FLASH_EXTENSIONS = DISABLE_FLASH_EXTENSIONS; // Since 5.0.0
+}
+
+/**
+ * @class ApiVersion
+ * Stores current api version.
+ *
+ * Since 4.2.0
+ *
+ * @param major The major version
+ * @param minor The minor version.
+ * @param micro The micro version.
+ *
+ * @return ApiVersion object.
+ */
+function ApiVersion(major, minor, micro)
+{
+ this.major = major;
+ this.minor = minor;
+ this.micro = micro;
+}
+
+/**
+ * @class MenuItemStatus
+ * Stores flyout menu item status
+ *
+ * Since 5.2.0
+ *
+ * @param menuItemLabel The menu item label.
+ * @param enabled True if user wants to enable the menu item.
+ * @param checked True if user wants to check the menu item.
+ *
+ * @return MenuItemStatus object.
+ */
+function MenuItemStatus(menuItemLabel, enabled, checked)
+{
+ this.menuItemLabel = menuItemLabel;
+ this.enabled = enabled;
+ this.checked = checked;
+}
+
+/**
+ * @class ContextMenuItemStatus
+ * Stores the status of the context menu item.
+ *
+ * Since 5.2.0
+ *
+ * @param menuItemID The menu item id.
+ * @param enabled True if user wants to enable the menu item.
+ * @param checked True if user wants to check the menu item.
+ *
+ * @return MenuItemStatus object.
+ */
+function ContextMenuItemStatus(menuItemID, enabled, checked)
+{
+ this.menuItemID = menuItemID;
+ this.enabled = enabled;
+ this.checked = checked;
+}
+//------------------------------ CSInterface ----------------------------------
+
+/**
+ * @class CSInterface
+ * This is the entry point to the CEP extensibility infrastructure.
+ * Instantiate this object and use it to:
+ *
+ * Access information about the host application in which an extension is running
+ * Launch an extension
+ * Register interest in event notifications, and dispatch events
+ *
+ *
+ * @return A new \c CSInterface object
+ */
+function CSInterface()
+{
+}
+
+/**
+ * User can add this event listener to handle native application theme color changes.
+ * Callback function gives extensions ability to fine-tune their theme color after the
+ * global theme color has been changed.
+ * The callback function should be like below:
+ *
+ * @example
+ * // event is a CSEvent object, but user can ignore it.
+ * function OnAppThemeColorChanged(event)
+ * {
+ * // Should get a latest HostEnvironment object from application.
+ * var skinInfo = JSON.parse(window.__adobe_cep__.getHostEnvironment()).appSkinInfo;
+ * // Gets the style information such as color info from the skinInfo,
+ * // and redraw all UI controls of your extension according to the style info.
+ * }
+ */
+CSInterface.THEME_COLOR_CHANGED_EVENT = "com.adobe.csxs.events.ThemeColorChanged";
+
+/** The host environment data object. */
+CSInterface.prototype.hostEnvironment = window.__adobe_cep__ ? JSON.parse(window.__adobe_cep__.getHostEnvironment()) : null;
+
+/** Retrieves information about the host environment in which the
+ * extension is currently running.
+ *
+ * @return A \c #HostEnvironment object.
+ */
+CSInterface.prototype.getHostEnvironment = function()
+{
+ this.hostEnvironment = JSON.parse(window.__adobe_cep__.getHostEnvironment());
+ return this.hostEnvironment;
+};
+
+/** Closes this extension. */
+CSInterface.prototype.closeExtension = function()
+{
+ window.__adobe_cep__.closeExtension();
+};
+
+/**
+ * Retrieves a path for which a constant is defined in the system.
+ *
+ * @param pathType The path-type constant defined in \c #SystemPath ,
+ *
+ * @return The platform-specific system path string.
+ */
+CSInterface.prototype.getSystemPath = function(pathType)
+{
+ var path = decodeURI(window.__adobe_cep__.getSystemPath(pathType));
+ var OSVersion = this.getOSInformation();
+ if (OSVersion.indexOf("Windows") >= 0)
+ {
+ path = path.replace("file:///", "");
+ }
+ else if (OSVersion.indexOf("Mac") >= 0)
+ {
+ path = path.replace("file://", "");
+ }
+ return path;
+};
+
+/**
+ * Evaluates a JavaScript script, which can use the JavaScript DOM
+ * of the host application.
+ *
+ * @param script The JavaScript script.
+ * @param callback Optional. A callback function that receives the result of execution.
+ * If execution fails, the callback function receives the error message \c EvalScript_ErrMessage.
+ */
+CSInterface.prototype.evalScript = function(script, callback)
+{
+ if(callback === null || callback === undefined)
+ {
+ callback = function(result){};
+ }
+ window.__adobe_cep__.evalScript(script, callback);
+};
+
+/**
+ * Retrieves the unique identifier of the application.
+ * in which the extension is currently running.
+ *
+ * @return The unique ID string.
+ */
+CSInterface.prototype.getApplicationID = function()
+{
+ var appId = this.hostEnvironment.appId;
+ return appId;
+};
+
+/**
+ * Retrieves host capability information for the application
+ * in which the extension is currently running.
+ *
+ * @return A \c #HostCapabilities object.
+ */
+CSInterface.prototype.getHostCapabilities = function()
+{
+ var hostCapabilities = JSON.parse(window.__adobe_cep__.getHostCapabilities() );
+ return hostCapabilities;
+};
+
+/**
+ * Triggers a CEP event programmatically. Yoy can use it to dispatch
+ * an event of a predefined type, or of a type you have defined.
+ *
+ * @param event A \c CSEvent object.
+ */
+CSInterface.prototype.dispatchEvent = function(event)
+{
+ if (typeof event.data == "object")
+ {
+ event.data = JSON.stringify(event.data);
+ }
+
+ window.__adobe_cep__.dispatchEvent(event);
+};
+
+/**
+ * Registers an interest in a CEP event of a particular type, and
+ * assigns an event handler.
+ * The event infrastructure notifies your extension when events of this type occur,
+ * passing the event object to the registered handler function.
+ *
+ * @param type The name of the event type of interest.
+ * @param listener The JavaScript handler function or method.
+ * @param obj Optional, the object containing the handler method, if any.
+ * Default is null.
+ */
+CSInterface.prototype.addEventListener = function(type, listener, obj)
+{
+ window.__adobe_cep__.addEventListener(type, listener, obj);
+};
+
+/**
+ * Removes a registered event listener.
+ *
+ * @param type The name of the event type of interest.
+ * @param listener The JavaScript handler function or method that was registered.
+ * @param obj Optional, the object containing the handler method, if any.
+ * Default is null.
+ */
+CSInterface.prototype.removeEventListener = function(type, listener, obj)
+{
+ window.__adobe_cep__.removeEventListener(type, listener, obj);
+};
+
+/**
+ * Loads and launches another extension, or activates the extension if it is already loaded.
+ *
+ * @param extensionId The extension's unique identifier.
+ * @param startupParams Not currently used, pass "".
+ *
+ * @example
+ * To launch the extension "help" with ID "HLP" from this extension, call:
+ * requestOpenExtension("HLP", "");
+ *
+ */
+CSInterface.prototype.requestOpenExtension = function(extensionId, params)
+{
+ window.__adobe_cep__.requestOpenExtension(extensionId, params);
+};
+
+/**
+ * Retrieves the list of extensions currently loaded in the current host application.
+ * The extension list is initialized once, and remains the same during the lifetime
+ * of the CEP session.
+ *
+ * @param extensionIds Optional, an array of unique identifiers for extensions of interest.
+ * If omitted, retrieves data for all extensions.
+ *
+ * @return Zero or more \c #Extension objects.
+ */
+CSInterface.prototype.getExtensions = function(extensionIds)
+{
+ var extensionIdsStr = JSON.stringify(extensionIds);
+ var extensionsStr = window.__adobe_cep__.getExtensions(extensionIdsStr);
+
+ var extensions = JSON.parse(extensionsStr);
+ return extensions;
+};
+
+/**
+ * Retrieves network-related preferences.
+ *
+ * @return A JavaScript object containing network preferences.
+ */
+CSInterface.prototype.getNetworkPreferences = function()
+{
+ var result = window.__adobe_cep__.getNetworkPreferences();
+ var networkPre = JSON.parse(result);
+
+ return networkPre;
+};
+
+/**
+ * Initializes the resource bundle for this extension with property values
+ * for the current application and locale.
+ * To support multiple locales, you must define a property file for each locale,
+ * containing keyed display-string values for that locale.
+ * See localization documentation for Extension Builder and related products.
+ *
+ * Keys can be in the
+ * form key.value="localized string", for use in HTML text elements.
+ * For example, in this input element, the localized \c key.value string is displayed
+ * instead of the empty \c value string:
+ *
+ *
+ *
+ * @return An object containing the resource bundle information.
+ */
+CSInterface.prototype.initResourceBundle = function()
+{
+ var resourceBundle = JSON.parse(window.__adobe_cep__.initResourceBundle());
+ var resElms = document.querySelectorAll('[data-locale]');
+ for (var n = 0; n < resElms.length; n++)
+ {
+ var resEl = resElms[n];
+ // Get the resource key from the element.
+ var resKey = resEl.getAttribute('data-locale');
+ if (resKey)
+ {
+ // Get all the resources that start with the key.
+ for (var key in resourceBundle)
+ {
+ if (key.indexOf(resKey) === 0)
+ {
+ var resValue = resourceBundle[key];
+ if (key.length == resKey.length)
+ {
+ resEl.innerHTML = resValue;
+ }
+ else if ('.' == key.charAt(resKey.length))
+ {
+ var attrKey = key.substring(resKey.length + 1);
+ resEl[attrKey] = resValue;
+ }
+ }
+ }
+ }
+ }
+ return resourceBundle;
+};
+
+/**
+ * Writes installation information to a file.
+ *
+ * @return The file path.
+ */
+CSInterface.prototype.dumpInstallationInfo = function()
+{
+ return window.__adobe_cep__.dumpInstallationInfo();
+};
+
+/**
+ * Retrieves version information for the current Operating System,
+ * See http://www.useragentstring.com/pages/Chrome/ for Chrome \c navigator.userAgent values.
+ *
+ * @return A string containing the OS version, or "unknown Operation System".
+ * If user customizes the User Agent by setting CEF command parameter "--user-agent", only
+ * "Mac OS X" or "Windows" will be returned.
+ */
+CSInterface.prototype.getOSInformation = function()
+{
+ var userAgent = navigator.userAgent;
+
+ if ((navigator.platform == "Win32") || (navigator.platform == "Windows"))
+ {
+ var winVersion = "Windows";
+ var winBit = "";
+ if (userAgent.indexOf("Windows") > -1)
+ {
+ if (userAgent.indexOf("Windows NT 5.0") > -1)
+ {
+ winVersion = "Windows 2000";
+ }
+ else if (userAgent.indexOf("Windows NT 5.1") > -1)
+ {
+ winVersion = "Windows XP";
+ }
+ else if (userAgent.indexOf("Windows NT 5.2") > -1)
+ {
+ winVersion = "Windows Server 2003";
+ }
+ else if (userAgent.indexOf("Windows NT 6.0") > -1)
+ {
+ winVersion = "Windows Vista";
+ }
+ else if (userAgent.indexOf("Windows NT 6.1") > -1)
+ {
+ winVersion = "Windows 7";
+ }
+ else if (userAgent.indexOf("Windows NT 6.2") > -1)
+ {
+ winVersion = "Windows 8";
+ }
+ else if (userAgent.indexOf("Windows NT 6.3") > -1)
+ {
+ winVersion = "Windows 8.1";
+ }
+ else if (userAgent.indexOf("Windows NT 10") > -1)
+ {
+ winVersion = "Windows 10";
+ }
+
+ if (userAgent.indexOf("WOW64") > -1 || userAgent.indexOf("Win64") > -1)
+ {
+ winBit = " 64-bit";
+ }
+ else
+ {
+ winBit = " 32-bit";
+ }
+ }
+
+ return winVersion + winBit;
+ }
+ else if ((navigator.platform == "MacIntel") || (navigator.platform == "Macintosh"))
+ {
+ var result = "Mac OS X";
+
+ if (userAgent.indexOf("Mac OS X") > -1)
+ {
+ result = userAgent.substring(userAgent.indexOf("Mac OS X"), userAgent.indexOf(")"));
+ result = result.replace(/_/g, ".");
+ }
+
+ return result;
+ }
+
+ return "Unknown Operation System";
+};
+
+/**
+ * Opens a page in the default system browser.
+ *
+ * Since 4.2.0
+ *
+ * @param url The URL of the page/file to open, or the email address.
+ * Must use HTTP/HTTPS/file/mailto protocol. For example:
+ * "http://www.adobe.com"
+ * "https://github.com"
+ * "file:///C:/log.txt"
+ * "mailto:test@adobe.com"
+ *
+ * @return One of these error codes:\n
+ * \n
+ * NO_ERROR - 0 \n
+ * ERR_UNKNOWN - 1 \n
+ * ERR_INVALID_PARAMS - 2 \n
+ * ERR_INVALID_URL - 201 \n
+ * \n
+ */
+CSInterface.prototype.openURLInDefaultBrowser = function(url)
+{
+ return cep.util.openURLInDefaultBrowser(url);
+};
+
+/**
+ * Retrieves extension ID.
+ *
+ * Since 4.2.0
+ *
+ * @return extension ID.
+ */
+CSInterface.prototype.getExtensionID = function()
+{
+ return window.__adobe_cep__.getExtensionId();
+};
+
+/**
+ * Retrieves the scale factor of screen.
+ * On Windows platform, the value of scale factor might be different from operating system's scale factor,
+ * since host application may use its self-defined scale factor.
+ *
+ * Since 4.2.0
+ *
+ * @return One of the following float number.
+ * \n
+ * -1.0 when error occurs \n
+ * 1.0 means normal screen \n
+ * >1.0 means HiDPI screen \n
+ * \n
+ */
+CSInterface.prototype.getScaleFactor = function()
+{
+ return window.__adobe_cep__.getScaleFactor();
+};
+
+/**
+ * Set a handler to detect any changes of scale factor. This only works on Mac.
+ *
+ * Since 4.2.0
+ *
+ * @param handler The function to be called when scale factor is changed.
+ *
+ */
+CSInterface.prototype.setScaleFactorChangedHandler = function(handler)
+{
+ window.__adobe_cep__.setScaleFactorChangedHandler(handler);
+};
+
+/**
+ * Retrieves current API version.
+ *
+ * Since 4.2.0
+ *
+ * @return ApiVersion object.
+ *
+ */
+CSInterface.prototype.getCurrentApiVersion = function()
+{
+ var apiVersion = JSON.parse(window.__adobe_cep__.getCurrentApiVersion());
+ return apiVersion;
+};
+
+/**
+ * Set panel flyout menu by an XML.
+ *
+ * Since 5.2.0
+ *
+ * Register a callback function for "com.adobe.csxs.events.flyoutMenuClicked" to get notified when a
+ * menu item is clicked.
+ * The "data" attribute of event is an object which contains "menuId" and "menuName" attributes.
+ *
+ * Register callback functions for "com.adobe.csxs.events.flyoutMenuOpened" and "com.adobe.csxs.events.flyoutMenuClosed"
+ * respectively to get notified when flyout menu is opened or closed.
+ *
+ * @param menu A XML string which describes menu structure.
+ * An example menu XML:
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ */
+CSInterface.prototype.setPanelFlyoutMenu = function(menu)
+{
+ if ("string" != typeof menu)
+ {
+ return;
+ }
+
+ window.__adobe_cep__.invokeSync("setPanelFlyoutMenu", menu);
+};
+
+/**
+ * Updates a menu item in the extension window's flyout menu, by setting the enabled
+ * and selection status.
+ *
+ * Since 5.2.0
+ *
+ * @param menuItemLabel The menu item label.
+ * @param enabled True to enable the item, false to disable it (gray it out).
+ * @param checked True to select the item, false to deselect it.
+ *
+ * @return false when the host application does not support this functionality (HostCapabilities.EXTENDED_PANEL_MENU is false).
+ * Fails silently if menu label is invalid.
+ *
+ * @see HostCapabilities.EXTENDED_PANEL_MENU
+ */
+CSInterface.prototype.updatePanelMenuItem = function(menuItemLabel, enabled, checked)
+{
+ var ret = false;
+ if (this.getHostCapabilities().EXTENDED_PANEL_MENU)
+ {
+ var itemStatus = new MenuItemStatus(menuItemLabel, enabled, checked);
+ ret = window.__adobe_cep__.invokeSync("updatePanelMenuItem", JSON.stringify(itemStatus));
+ }
+ return ret;
+};
+
+
+/**
+ * Set context menu by XML string.
+ *
+ * Since 5.2.0
+ *
+ * There are a number of conventions used to communicate what type of menu item to create and how it should be handled.
+ * - an item without menu ID or menu name is disabled and is not shown.
+ * - if the item name is "---" (three hyphens) then it is treated as a separator. The menu ID in this case will always be NULL.
+ * - Checkable attribute takes precedence over Checked attribute.
+ * - a PNG icon. For optimal display results please supply a 16 x 16px icon as larger dimensions will increase the size of the menu item.
+ The Chrome extension contextMenus API was taken as a reference.
+ https://developer.chrome.com/extensions/contextMenus
+ * - the items with icons and checkable items cannot coexist on the same menu level. The former take precedences over the latter.
+ *
+ * @param menu A XML string which describes menu structure.
+ * @param callback The callback function which is called when a menu item is clicked. The only parameter is the returned ID of clicked menu item.
+ *
+ * @description An example menu XML:
+ *
+ *
+ *
+ *
+ *
+ *
+ */
+CSInterface.prototype.setContextMenu = function(menu, callback)
+{
+ if ("string" != typeof menu)
+ {
+ return;
+ }
+
+ window.__adobe_cep__.invokeAsync("setContextMenu", menu, callback);
+};
+
+/**
+ * Set context menu by JSON string.
+ *
+ * Since 6.0.0
+ *
+ * There are a number of conventions used to communicate what type of menu item to create and how it should be handled.
+ * - an item without menu ID or menu name is disabled and is not shown.
+ * - if the item label is "---" (three hyphens) then it is treated as a separator. The menu ID in this case will always be NULL.
+ * - Checkable attribute takes precedence over Checked attribute.
+ * - a PNG icon. For optimal display results please supply a 16 x 16px icon as larger dimensions will increase the size of the menu item.
+ The Chrome extension contextMenus API was taken as a reference.
+ * - the items with icons and checkable items cannot coexist on the same menu level. The former take precedences over the latter.
+ https://developer.chrome.com/extensions/contextMenus
+ *
+ * @param menu A JSON string which describes menu structure.
+ * @param callback The callback function which is called when a menu item is clicked. The only parameter is the returned ID of clicked menu item.
+ *
+ * @description An example menu JSON:
+ *
+ * {
+ * "menu": [
+ * {
+ * "id": "menuItemId1",
+ * "label": "testExample1",
+ * "enabled": true,
+ * "checkable": true,
+ * "checked": false,
+ * "icon": "./image/small_16X16.png"
+ * },
+ * {
+ * "id": "menuItemId2",
+ * "label": "testExample2",
+ * "menu": [
+ * {
+ * "id": "menuItemId2-1",
+ * "label": "testExample2-1",
+ * "menu": [
+ * {
+ * "id": "menuItemId2-1-1",
+ * "label": "testExample2-1-1",
+ * "enabled": false,
+ * "checkable": true,
+ * "checked": true
+ * }
+ * ]
+ * },
+ * {
+ * "id": "menuItemId2-2",
+ * "label": "testExample2-2",
+ * "enabled": true,
+ * "checkable": true,
+ * "checked": true
+ * }
+ * ]
+ * },
+ * {
+ * "label": "---"
+ * },
+ * {
+ * "id": "menuItemId3",
+ * "label": "testExample3",
+ * "enabled": false,
+ * "checkable": true,
+ * "checked": false
+ * }
+ * ]
+ * }
+ *
+ */
+CSInterface.prototype.setContextMenuByJSON = function(menu, callback)
+{
+ if ("string" != typeof menu)
+ {
+ return;
+ }
+
+ window.__adobe_cep__.invokeAsync("setContextMenuByJSON", menu, callback);
+};
+
+/**
+ * Updates a context menu item by setting the enabled and selection status.
+ *
+ * Since 5.2.0
+ *
+ * @param menuItemID The menu item ID.
+ * @param enabled True to enable the item, false to disable it (gray it out).
+ * @param checked True to select the item, false to deselect it.
+ */
+CSInterface.prototype.updateContextMenuItem = function(menuItemID, enabled, checked)
+{
+ var itemStatus = new ContextMenuItemStatus(menuItemID, enabled, checked);
+ ret = window.__adobe_cep__.invokeSync("updateContextMenuItem", JSON.stringify(itemStatus));
+};
+
+/**
+ * Get the visibility status of an extension window.
+ *
+ * Since 6.0.0
+ *
+ * @return true if the extension window is visible; false if the extension window is hidden.
+ */
+CSInterface.prototype.isWindowVisible = function()
+{
+ return window.__adobe_cep__.invokeSync("isWindowVisible", "");
+};
+
+/**
+ * Resize extension's content to the specified dimensions.
+ * 1. Works with modal and modeless extensions in all Adobe products.
+ * 2. Extension's manifest min/max size constraints apply and take precedence.
+ * 3. For panel extensions
+ * 3.1 This works in all Adobe products except:
+ * * Premiere Pro
+ * * Prelude
+ * * After Effects
+ * 3.2 When the panel is in certain states (especially when being docked),
+ * it will not change to the desired dimensions even when the
+ * specified size satisfies min/max constraints.
+ *
+ * Since 6.0.0
+ *
+ * @param width The new width
+ * @param height The new height
+ */
+CSInterface.prototype.resizeContent = function(width, height)
+{
+ window.__adobe_cep__.resizeContent(width, height);
+};
+
+/**
+ * Register the invalid certificate callback for an extension.
+ * This callback will be triggered when the extension tries to access the web site that contains the invalid certificate on the main frame.
+ * But if the extension does not call this function and tries to access the web site containing the invalid certificate, a default error page will be shown.
+ *
+ * Since 6.1.0
+ *
+ * @param callback the callback function
+ */
+CSInterface.prototype.registerInvalidCertificateCallback = function(callback)
+{
+ return window.__adobe_cep__.registerInvalidCertificateCallback(callback);
+};
+
+/**
+ * Register an interest in some key events to prevent them from being sent to the host application.
+ *
+ * This function works with modeless extensions and panel extensions.
+ * Generally all the key events will be sent to the host application for these two extensions if the current focused element
+ * is not text input or dropdown,
+ * If you want to intercept some key events and want them to be handled in the extension, please call this function
+ * in advance to prevent them being sent to the host application.
+ *
+ * Since 6.1.0
+ *
+ * @param keyEventsInterest A JSON string describing those key events you are interested in. A null object or
+ an empty string will lead to removing the interest
+ *
+ * This JSON string should be an array, each object has following keys:
+ *
+ * keyCode: [Required] represents an OS system dependent virtual key code identifying
+ * the unmodified value of the pressed key.
+ * ctrlKey: [optional] a Boolean that indicates if the control key was pressed (true) or not (false) when the event occurred.
+ * altKey: [optional] a Boolean that indicates if the alt key was pressed (true) or not (false) when the event occurred.
+ * shiftKey: [optional] a Boolean that indicates if the shift key was pressed (true) or not (false) when the event occurred.
+ * metaKey: [optional] (Mac Only) a Boolean that indicates if the Meta key was pressed (true) or not (false) when the event occurred.
+ * On Macintosh keyboards, this is the command key. To detect Windows key on Windows, please use keyCode instead.
+ * An example JSON string:
+ *
+ * [
+ * {
+ * "keyCode": 48
+ * },
+ * {
+ * "keyCode": 123,
+ * "ctrlKey": true
+ * },
+ * {
+ * "keyCode": 123,
+ * "ctrlKey": true,
+ * "metaKey": true
+ * }
+ * ]
+ *
+ */
+CSInterface.prototype.registerKeyEventsInterest = function(keyEventsInterest)
+{
+ return window.__adobe_cep__.registerKeyEventsInterest(keyEventsInterest);
+};
+
+/**
+ * Set the title of the extension window.
+ * This function works with modal and modeless extensions in all Adobe products, and panel extensions in Photoshop, InDesign, InCopy, Illustrator, Flash Pro and Dreamweaver.
+ *
+ * Since 6.1.0
+ *
+ * @param title The window title.
+ */
+CSInterface.prototype.setWindowTitle = function(title)
+{
+ window.__adobe_cep__.invokeSync("setWindowTitle", title);
+};
+
+/**
+ * Get the title of the extension window.
+ * This function works with modal and modeless extensions in all Adobe products, and panel extensions in Photoshop, InDesign, InCopy, Illustrator, Flash Pro and Dreamweaver.
+ *
+ * Since 6.1.0
+ *
+ * @return The window title.
+ */
+CSInterface.prototype.getWindowTitle = function()
+{
+ return window.__adobe_cep__.invokeSync("getWindowTitle", "");
+};
diff --git a/pype/premiere/extensions/com.pond5.ppro/remote/index_files/angular.rangeSlider.css b/pype/premiere/extensions/com.pond5.ppro/remote/index_files/angular.rangeSlider.css
new file mode 100644
index 0000000000..2a9535de2c
--- /dev/null
+++ b/pype/premiere/extensions/com.pond5.ppro/remote/index_files/angular.rangeSlider.css
@@ -0,0 +1,360 @@
+/**
+ * Angular RangeSlider SCSS
+ *
+ * Version: 0.0.14
+ *
+ * Author: Daniel Crisp, danielcrisp.com
+ *
+ * The rangeSlider has been styled to match the default styling
+ * of form elements styled using Twitter's Bootstrap
+ *
+ * Originally forked from https://github.com/leongersen/noUiSlider
+ *
+
+ This code is released under the MIT Licence - http://opensource.org/licenses/MIT
+
+ Copyright (c) 2013 Daniel Crisp
+
+ Permission is hereby granted, free of charge, to any person obtaining a copy
+ of this software and associated documentation files (the "Software"), to deal
+ in the Software without restriction, including without limitation the rights
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ copies of the Software, and to permit persons to whom the Software is
+ furnished to do so, subject to the following conditions:
+
+ The above copyright notice and this permission notice shall be included in
+ all copies or substantial portions of the Software.
+
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+ THE SOFTWARE.
+
+ */
+/*------------------------------------*\
+ COMPASS IMPORTS
+\*------------------------------------*/
+/*------------------------------------*\
+ SETTINGS
+\*------------------------------------*/
+/*------------------------------------*\
+ THE CSS
+\*------------------------------------*/
+/* line 25, scss/_rangeSlider.scss */
+.ngrs-range-slider {
+ position: relative;
+ margin: 10px 0 30px;
+ padding-left: 14px;
+padding-right: 14px;
+/* border: 1px solid #ccc;*/
+/* background: #fff;*/
+ -moz-border-radius: 4px;
+ -webkit-border-radius: 4px;
+ border-radius: 4px;
+ -moz-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+ -moz-transition: border 0.2s linear, box-shadow 0.2s linear;
+ -o-transition: border 0.2s linear, box-shadow 0.2s linear;
+ -webkit-transition: border 0.2s linear, box-shadow 0.2s linear;
+ transition: border 0.2s linear, box-shadow 0.2s linear;
+ -webkit-tap-highlight-color: transparent;
+ /*------------------------------------*\
+ RUNNER
+ \*------------------------------------*/
+ /*------------------------------------*\
+ JOIN (connects the two handles)
+ \*------------------------------------*/
+ /*------------------------------------*\
+ HANDLE
+ \*------------------------------------*/
+ /*------------------------------------*\
+ HANDLE SPECIFICS
+ \*------------------------------------*/
+ /*------------------------------------*\
+ VALUE LABELS
+ \*------------------------------------*/
+ /*------------------------------------*\
+ ATTACHED VALUE RUNNER
+ \*------------------------------------*/
+ /*------------------------------------*\
+ VERTICAL SLIDER
+ \*------------------------------------*/
+ /*------------------------------------*\
+ FOCUS STATE
+ \*------------------------------------*/
+ /*------------------------------------*\
+ DISABLED STATE
+ \*------------------------------------*/
+}
+/* line 28, scss/_rangeSlider.scss */
+.ngrs-range-slider, .ngrs-range-slider * {
+ display: block;
+ cursor: default;
+ -moz-box-sizing: border-box;
+ -webkit-box-sizing: border-box;
+ box-sizing: border-box;
+ -moz-user-select: -moz-none;
+ -ms-user-select: none;
+ -webkit-user-select: none;
+ user-select: none;
+}
+/* line 53, scss/_rangeSlider.scss */
+.ngrs-range-slider .ngrs-runner {
+ position: relative;
+ margin: 0 9px;
+ height: 18px;
+}
+/* line 63, scss/_rangeSlider.scss */
+.ngrs-range-slider .ngrs-join {
+ position: absolute;
+ z-index: 1;
+ top: 55%;
+ left: 0;
+ right: 100%;
+ height: 4px; /* CHANGED height, top and color line*/
+ margin: -4px 0 0 0;
+ -moz-border-radius: 4px;
+ -webkit-border-radius: 4px;
+ border-radius: 4px;
+ background-color: #1d84fa;
+/* background-image: url('');*/
+ background-size: 100%;
+/*
+ background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #5bc0de), color-stop(100%, #2f96b4));
+ background-image: -moz-linear-gradient(#5bc0de, #2f96b4);
+ background-image: -webkit-linear-gradient(#5bc0de, #2f96b4);
+ background-image: linear-gradient(#5bc0de, #2f96b4);
+*/
+}
+/* line 81, scss/_rangeSlider.scss CHANGED HANDLES */
+.ngrs-range-slider .ngrs-handle {
+ position: absolute;
+ z-index: 2;
+/* height: 100%;*/
+ width: 16px;
+ height: 16px;
+/* margin: 0 0 0 -9px;*/
+/* background: red;*/
+ background: url('../../images/slider-handle.png');
+ background-repeat: no-repeat;
+/* border: 1px solid #ccc;*/
+/* border-radius: 50%;*/
+ /*------------------------------------*\
+ HANDLE ICON
+ \*------------------------------------*/
+}
+/* line 95, scss/_rangeSlider.scss */
+.ngrs-range-slider .ngrs-handle i {
+ display: block;
+ width: 100%;
+ height: 100%;
+ background: no-repeat -9999px -9999px;
+ cursor: pointer;
+}
+/* line 104, scss/_rangeSlider.scss */
+.ngrs-range-slider .ngrs-handle.ngrs-over i {
+ background-position: 50% 50%;
+}
+/* line 109, scss/_rangeSlider.scss */
+.ngrs-range-slider .ngrs-handle.ngrs-down {
+ -moz-box-shadow: 0 0 4px rgba(0, 0, 0, 0.2);
+ -webkit-box-shadow: 0 0 4px rgba(0, 0, 0, 0.2);
+ box-shadow: 0 0 4px rgba(0, 0, 0, 0.2);
+}
+/* line 120, scss/_rangeSlider.scss */
+.ngrs-range-slider .ngrs-handle-min i {
+/* background-image: url("");*/
+}
+/* line 127, scss/_rangeSlider.scss */
+.ngrs-range-slider .ngrs-handle-max i {
+/* background-image: url("");*/
+}
+/* line 137, scss/_rangeSlider.scss */
+.ngrs-range-slider .ngrs-value {
+ position: absolute;
+ top: 100%;
+ left: 0;
+ padding: 5px 0 0 0;
+ font-size: 12px;
+ color: #fff;
+}
+/* line 145, scss/_rangeSlider.scss */
+.ngrs-range-slider .ngrs-value.ngrs-value-max {
+ left: auto;
+ right: 0;
+ text-align: right;
+}
+/* line 152, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-handle-min-down .ngrs-value-min, .ngrs-range-slider.ngrs-handle-max-down .ngrs-value-max {
+ color: #fff;
+}
+/* line 160, scss/_rangeSlider.scss */
+.ngrs-range-slider .ngrs-attached-handles {
+ margin: 0 9px;
+ position: relative;
+ /*------------------------------------*\
+ ATTACHED VALUE RUNNER LABELS
+ \*------------------------------------*/
+}
+/* line 167, scss/_rangeSlider.scss */
+.ngrs-range-slider .ngrs-attached-handles .ngrs-value {
+ text-align: left;
+}
+/* line 172, scss/_rangeSlider.scss */
+.ngrs-range-slider .ngrs-attached-handles .ngrs-value > div {
+ margin: 0 0 0 -50%;
+}
+/* line 181, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-vertical {
+ width: 28px;
+ margin: 10px auto;
+ /*------------------------------------*\
+ RUNNER
+ \*------------------------------------*/
+ /*------------------------------------*\
+ ATTACHED VALUE RUNNER
+ \*------------------------------------*/
+ /*------------------------------------*\
+ JOIN
+ \*------------------------------------*/
+ /*------------------------------------*\
+ HANDLE
+ \*------------------------------------*/
+ /*------------------------------------*\
+ HANDLE SPECIFICS
+ \*------------------------------------*/
+ /*------------------------------------*\
+ VALUE LABELS
+ \*------------------------------------*/
+ /*------------------------------------*\
+ VERTICAL LEFT SLIDER
+ \*------------------------------------*/
+ /*------------------------------------*\
+ VERTICAL RIGHT SLIDER
+ \*------------------------------------*/
+}
+/* line 189, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-vertical .ngrs-runner {
+ margin: 9px 0;
+ height: 300px;
+ width: 18px;
+}
+/* line 199, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-vertical .ngrs-value-runner.ngrs-attached-handles {
+ position: absolute;
+ top: 0;
+ left: 100%;
+ bottom: 0;
+ margin: 9px 0;
+}
+/* line 212, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-vertical .ngrs-join {
+ width: 8px;
+ height: auto;
+ top: 0;
+ bottom: 100%;
+ left: 50%;
+ right: auto;
+ margin: 0 0 0 -4px;
+}
+/* line 226, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-vertical .ngrs-handle {
+ width: 100%;
+ height: 18px;
+ margin: -9px 0 0 0;
+}
+/* line 237, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-vertical .ngrs-handle-min i {
+ background-image: url("");
+}
+/* line 244, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-vertical .ngrs-handle-max i {
+ background-image: url("");
+}
+/* line 254, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-vertical .ngrs-value {
+ top: 0;
+ left: 100%;
+ padding: 0 0 0 5px;
+}
+/* line 259, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-vertical .ngrs-value.ngrs-value-max {
+ top: auto;
+ bottom: 0;
+ right: auto;
+ text-align: left;
+}
+/* line 269, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-vertical .ngrs-attached-handles .ngrs-value > div {
+ margin: -50% 0 0 0;
+}
+/* line 279, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-vertical.ngrs-left {
+ margin: 10px 0;
+}
+/* line 287, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-vertical.ngrs-right {
+ margin: 10px 0 10px auto;
+ /*------------------------------------*\
+ VALUE LABELS
+ \*------------------------------------*/
+}
+/* line 294, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-vertical.ngrs-right .ngrs-value {
+ left: auto;
+ right: 100%;
+ padding: 0 5px 0 0;
+ text-align: right;
+}
+/* line 300, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-vertical.ngrs-right .ngrs-value.ngrs-value-max {
+ text-align: right;
+}
+/* line 306, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-vertical.ngrs-right .ngrs-value-runner.ngrs-attached-handles {
+ left: 0;
+}
+/* line 318, scss/_rangeSlider.scss */
+/*
+.ngrs-range-slider.ngrs-focus {
+ border-color: rgba(82, 168, 236, 0.8);
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 8px rgba(82, 168, 236, 0.6);
+}
+*/
+/* line 329, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-disabled, .ngrs-range-slider.ngrs-disabled.ngrs-focus {
+ border-color: #ddd;
+ -moz-box-shadow: none;
+ -webkit-box-shadow: none;
+ box-shadow: none;
+}
+/* line 335, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-disabled .ngrs-handle {
+ background: #fff;
+ border-color: #ddd;
+}
+/* line 339, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-disabled .ngrs-handle i {
+ background: none !important;
+ cursor: default;
+}
+/* line 345, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-disabled .ngrs-join {
+ background: #ddd;
+}
+/* line 349, scss/_rangeSlider.scss */
+.ngrs-range-slider.ngrs-disabled .ngrs-value {
+ color: #ddd;
+}
+
+/*------------------------------------*\
+ TOUCH STATE
+\*------------------------------------*/
+/* line 361, scss/_rangeSlider.scss */
+body.ngrs-touching {
+ -ms-touch-action: none;
+}
diff --git a/pype/premiere/extensions/com.pond5.ppro/remote/index_files/bootstrap.css b/pype/premiere/extensions/com.pond5.ppro/remote/index_files/bootstrap.css
new file mode 100644
index 0000000000..8e9957d9e4
--- /dev/null
+++ b/pype/premiere/extensions/com.pond5.ppro/remote/index_files/bootstrap.css
@@ -0,0 +1,5788 @@
+/*!
+ * Bootstrap v3.1.1 (http://getbootstrap.com)
+ * Copyright 2011-2014 Twitter, Inc.
+ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
+ */
+
+/*! normalize.css v3.0.0 | MIT License | git.io/normalize */
+html {
+ font-family: sans-serif;
+ -webkit-text-size-adjust: 100%;
+ -ms-text-size-adjust: 100%;
+}
+body {
+ margin: 0;
+}
+article,
+aside,
+details,
+figcaption,
+figure,
+footer,
+header,
+hgroup,
+main,
+nav,
+section,
+summary {
+ display: block;
+}
+audio,
+canvas,
+progress,
+video {
+ display: inline-block;
+ vertical-align: baseline;
+}
+audio:not([controls]) {
+ display: none;
+ height: 0;
+}
+[hidden],
+template {
+ display: none;
+}
+a {
+ background: transparent;
+}
+a:active,
+a:hover {
+ outline: 0;
+}
+abbr[title] {
+ border-bottom: 1px dotted;
+}
+b,
+strong {
+ font-weight: bold;
+}
+dfn {
+ font-style: italic;
+}
+h1 {
+ margin: .67em 0;
+ font-size: 2em;
+}
+mark {
+ color: #000;
+ background: #ff0;
+}
+small {
+ font-size: 80%;
+}
+sub,
+sup {
+ position: relative;
+ font-size: 75%;
+ line-height: 0;
+ vertical-align: baseline;
+}
+sup {
+ top: -.5em;
+}
+sub {
+ bottom: -.25em;
+}
+img {
+ border: 0;
+}
+svg:not(:root) {
+ overflow: hidden;
+}
+figure {
+ margin: 1em 40px;
+}
+hr {
+ height: 0;
+ -moz-box-sizing: content-box;
+ box-sizing: content-box;
+}
+pre {
+ overflow: auto;
+}
+code,
+kbd,
+pre,
+samp {
+ font-family: monospace, monospace;
+ font-size: 1em;
+}
+button,
+input,
+optgroup,
+select,
+textarea {
+ margin: 0;
+ font: inherit;
+ color: inherit;
+}
+button {
+ overflow: visible;
+}
+button,
+select {
+ text-transform: none;
+}
+button,
+html input[type="button"],
+input[type="reset"],
+input[type="submit"] {
+ -webkit-appearance: button;
+ cursor: pointer;
+}
+button[disabled],
+html input[disabled] {
+ cursor: default;
+}
+button::-moz-focus-inner,
+input::-moz-focus-inner {
+ padding: 0;
+ border: 0;
+}
+input {
+ line-height: normal;
+}
+input[type="checkbox"],
+input[type="radio"] {
+ box-sizing: border-box;
+ padding: 0;
+}
+input[type="number"]::-webkit-inner-spin-button,
+input[type="number"]::-webkit-outer-spin-button {
+ height: auto;
+}
+input[type="search"] {
+ -webkit-box-sizing: content-box;
+ -moz-box-sizing: content-box;
+ box-sizing: content-box;
+ -webkit-appearance: textfield;
+}
+input[type="search"]::-webkit-search-cancel-button,
+input[type="search"]::-webkit-search-decoration {
+ -webkit-appearance: none;
+}
+fieldset {
+ padding: .35em .625em .75em;
+ margin: 0 2px;
+ border: 1px solid #c0c0c0;
+}
+legend {
+ padding: 0;
+ border: 0;
+}
+textarea {
+ overflow: auto;
+}
+optgroup {
+ font-weight: bold;
+}
+table {
+ border-spacing: 0;
+ border-collapse: collapse;
+}
+td,
+th {
+ padding: 0;
+}
+@media print {
+ * {
+ color: #000 !important;
+ text-shadow: none !important;
+ background: transparent !important;
+ box-shadow: none !important;
+ }
+ a,
+ a:visited {
+ text-decoration: underline;
+ }
+ a[href]:after {
+ content: " (" attr(href) ")";
+ }
+ abbr[title]:after {
+ content: " (" attr(title) ")";
+ }
+ a[href^="javascript:"]:after,
+ a[href^="#"]:after {
+ content: "";
+ }
+ pre,
+ blockquote {
+ border: 1px solid #999;
+
+ page-break-inside: avoid;
+ }
+ thead {
+ display: table-header-group;
+ }
+ tr,
+ img {
+ page-break-inside: avoid;
+ }
+ img {
+ max-width: 100% !important;
+ }
+ p,
+ h2,
+ h3 {
+ orphans: 3;
+ widows: 3;
+ }
+ h2,
+ h3 {
+ page-break-after: avoid;
+ }
+ select {
+ background: #fff !important;
+ }
+ .navbar {
+ display: none;
+ }
+ .table td,
+ .table th {
+ background-color: #fff !important;
+ }
+ .btn > .caret,
+ .dropup > .btn > .caret {
+ border-top-color: #000 !important;
+ }
+ .label {
+ border: 1px solid #000;
+ }
+ .table {
+ border-collapse: collapse !important;
+ }
+ .table-bordered th,
+ .table-bordered td {
+ border: 1px solid #ddd !important;
+ }
+}
+* {
+ -webkit-box-sizing: border-box;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+}
+*:before,
+*:after {
+ -webkit-box-sizing: border-box;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+}
+html {
+ font-size: 62.5%;
+
+ -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
+}
+body {
+ font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
+ font-size: 14px;
+ line-height: 1.42857143;
+ color: #333;
+ background-color: #333;
+}
+input,
+button,
+select,
+textarea {
+ font-family: inherit;
+ font-size: inherit;
+ line-height: inherit;
+}
+a {
+ color: #428bca;
+ text-decoration: none;
+}
+a:hover,
+a:focus {
+ color: #2a6496;
+ text-decoration: underline;
+}
+a:focus {
+ outline: thin dotted;
+ outline: 5px auto -webkit-focus-ring-color;
+ outline-offset: -2px;
+}
+figure {
+ margin: 0;
+}
+img {
+ vertical-align: middle;
+}
+.img-responsive,
+.thumbnail > img,
+.thumbnail a > img,
+.carousel-inner > .item > img,
+.carousel-inner > .item > a > img {
+ display: block;
+ max-width: 100%;
+ height: auto;
+}
+.img-rounded {
+ border-radius: 6px;
+}
+.img-thumbnail {
+ display: inline-block;
+ max-width: 100%;
+ height: auto;
+ padding: 4px;
+ line-height: 1.42857143;
+ background-color: #fff;
+ border: 1px solid #ddd;
+ border-radius: 4px;
+ -webkit-transition: all .2s ease-in-out;
+ transition: all .2s ease-in-out;
+}
+.img-circle {
+ border-radius: 50%;
+}
+hr {
+ margin-top: 20px;
+ margin-bottom: 20px;
+ border: 0;
+ border-top: 1px solid #eee;
+}
+.sr-only {
+ position: absolute;
+ width: 1px;
+ height: 1px;
+ padding: 0;
+ margin: -1px;
+ overflow: hidden;
+ clip: rect(0, 0, 0, 0);
+ border: 0;
+}
+h1,
+h2,
+h3,
+h4,
+h5,
+h6,
+.h1,
+.h2,
+.h3,
+.h4,
+.h5,
+.h6 {
+ font-family: inherit;
+ font-weight: 500;
+ line-height: 1.1;
+ color: inherit;
+}
+h1 small,
+h2 small,
+h3 small,
+h4 small,
+h5 small,
+h6 small,
+.h1 small,
+.h2 small,
+.h3 small,
+.h4 small,
+.h5 small,
+.h6 small,
+h1 .small,
+h2 .small,
+h3 .small,
+h4 .small,
+h5 .small,
+h6 .small,
+.h1 .small,
+.h2 .small,
+.h3 .small,
+.h4 .small,
+.h5 .small,
+.h6 .small {
+ font-weight: normal;
+ line-height: 1;
+ color: #999;
+}
+h1,
+.h1,
+h2,
+.h2,
+h3,
+.h3 {
+ margin-top: 20px;
+ margin-bottom: 10px;
+}
+h1 small,
+.h1 small,
+h2 small,
+.h2 small,
+h3 small,
+.h3 small,
+h1 .small,
+.h1 .small,
+h2 .small,
+.h2 .small,
+h3 .small,
+.h3 .small {
+ font-size: 65%;
+}
+h4,
+.h4,
+h5,
+.h5,
+h6,
+.h6 {
+ margin-top: 10px;
+ margin-bottom: 10px;
+}
+h4 small,
+.h4 small,
+h5 small,
+.h5 small,
+h6 small,
+.h6 small,
+h4 .small,
+.h4 .small,
+h5 .small,
+.h5 .small,
+h6 .small,
+.h6 .small {
+ font-size: 75%;
+}
+h1,
+.h1 {
+ font-size: 36px;
+}
+h2,
+.h2 {
+ font-size: 30px;
+}
+h3,
+.h3 {
+ font-size: 24px;
+}
+h4,
+.h4 {
+ font-size: 18px;
+}
+h5,
+.h5 {
+ font-size: 14px;
+}
+h6,
+.h6 {
+ font-size: 12px;
+}
+p {
+ margin: 0 0 10px;
+}
+.lead {
+ margin-bottom: 20px;
+ font-size: 16px;
+ font-weight: 200;
+ line-height: 1.4;
+}
+@media (min-width: 768px) {
+ .lead {
+ font-size: 21px;
+ }
+}
+small,
+.small {
+ font-size: 85%;
+}
+cite {
+ font-style: normal;
+}
+.text-left {
+ text-align: left;
+}
+.text-right {
+ text-align: right;
+}
+.text-center {
+ text-align: center;
+}
+.text-justify {
+ text-align: justify;
+}
+.text-muted {
+ color: #999;
+}
+.text-primary {
+ color: #428bca;
+}
+a.text-primary:hover {
+ color: #3071a9;
+}
+.text-success {
+ color: #3c763d;
+}
+a.text-success:hover {
+ color: #2b542c;
+}
+.text-info {
+ color: #31708f;
+}
+a.text-info:hover {
+ color: #245269;
+}
+.text-warning {
+ color: #8a6d3b;
+}
+a.text-warning:hover {
+ color: #66512c;
+}
+.text-danger {
+ color: #a94442;
+}
+a.text-danger:hover {
+ color: #843534;
+}
+.bg-primary {
+ color: #fff;
+ background-color: #428bca;
+}
+a.bg-primary:hover {
+ background-color: #3071a9;
+}
+.bg-success {
+ background-color: #dff0d8;
+}
+a.bg-success:hover {
+ background-color: #c1e2b3;
+}
+.bg-info {
+ background-color: #d9edf7;
+}
+a.bg-info:hover {
+ background-color: #afd9ee;
+}
+.bg-warning {
+ background-color: #fcf8e3;
+}
+a.bg-warning:hover {
+ background-color: #f7ecb5;
+}
+.bg-danger {
+ background-color: #f2dede;
+}
+a.bg-danger:hover {
+ background-color: #e4b9b9;
+}
+.page-header {
+ padding-bottom: 9px;
+ margin: 40px 0 20px;
+ border-bottom: 1px solid #eee;
+}
+ul,
+ol {
+ margin-top: 0;
+ margin-bottom: 10px;
+}
+ul ul,
+ol ul,
+ul ol,
+ol ol {
+ margin-bottom: 0;
+}
+.list-unstyled {
+ padding-left: 0;
+ list-style: none;
+}
+.list-inline {
+ padding-left: 0;
+ margin-left: -5px;
+ list-style: none;
+}
+.list-inline > li {
+ display: inline-block;
+ padding-right: 5px;
+ padding-left: 5px;
+}
+dl {
+ margin-top: 0;
+ margin-bottom: 20px;
+}
+dt,
+dd {
+ line-height: 1.42857143;
+}
+dt {
+ font-weight: bold;
+}
+dd {
+ margin-left: 0;
+}
+@media (min-width: 768px) {
+ .dl-horizontal dt {
+ float: left;
+ width: 160px;
+ overflow: hidden;
+ clear: left;
+ text-align: right;
+ text-overflow: ellipsis;
+ white-space: nowrap;
+ }
+ .dl-horizontal dd {
+ margin-left: 180px;
+ }
+}
+abbr[title],
+abbr[data-original-title] {
+ cursor: help;
+ border-bottom: 1px dotted #999;
+}
+.initialism {
+ font-size: 90%;
+ text-transform: uppercase;
+}
+blockquote {
+ padding: 10px 20px;
+ margin: 0 0 20px;
+ font-size: 17.5px;
+ border-left: 5px solid #eee;
+}
+blockquote p:last-child,
+blockquote ul:last-child,
+blockquote ol:last-child {
+ margin-bottom: 0;
+}
+blockquote footer,
+blockquote small,
+blockquote .small {
+ display: block;
+ font-size: 80%;
+ line-height: 1.42857143;
+ color: #999;
+}
+blockquote footer:before,
+blockquote small:before,
+blockquote .small:before {
+ content: '\2014 \00A0';
+}
+.blockquote-reverse,
+blockquote.pull-right {
+ padding-right: 15px;
+ padding-left: 0;
+ text-align: right;
+ border-right: 5px solid #eee;
+ border-left: 0;
+}
+.blockquote-reverse footer:before,
+blockquote.pull-right footer:before,
+.blockquote-reverse small:before,
+blockquote.pull-right small:before,
+.blockquote-reverse .small:before,
+blockquote.pull-right .small:before {
+ content: '';
+}
+.blockquote-reverse footer:after,
+blockquote.pull-right footer:after,
+.blockquote-reverse small:after,
+blockquote.pull-right small:after,
+.blockquote-reverse .small:after,
+blockquote.pull-right .small:after {
+ content: '\00A0 \2014';
+}
+blockquote:before,
+blockquote:after {
+ content: "";
+}
+address {
+ margin-bottom: 20px;
+ font-style: normal;
+ line-height: 1.42857143;
+}
+code,
+kbd,
+pre,
+samp {
+ font-family: Menlo, Monaco, Consolas, "Courier New", monospace;
+}
+code {
+ padding: 2px 4px;
+ font-size: 90%;
+ color: #c7254e;
+ white-space: nowrap;
+ background-color: #f9f2f4;
+ border-radius: 4px;
+}
+kbd {
+ padding: 2px 4px;
+ font-size: 90%;
+ color: #fff;
+ background-color: #333;
+ border-radius: 3px;
+ box-shadow: inset 0 -1px 0 rgba(0, 0, 0, .25);
+}
+pre {
+ display: block;
+ padding: 9.5px;
+ margin: 0 0 10px;
+ font-size: 13px;
+ line-height: 1.42857143;
+ color: #333;
+ word-break: break-all;
+ word-wrap: break-word;
+ background-color: #f5f5f5;
+ border: 1px solid #ccc;
+ border-radius: 4px;
+}
+pre code {
+ padding: 0;
+ font-size: inherit;
+ color: inherit;
+ white-space: pre-wrap;
+ background-color: transparent;
+ border-radius: 0;
+}
+.pre-scrollable {
+ max-height: 340px;
+ overflow-y: scroll;
+}
+.container {
+ padding-right: 15px;
+ padding-left: 15px;
+ margin-right: auto;
+ margin-left: auto;
+}
+@media (min-width: 768px) {
+ .container {
+ width: 750px;
+ }
+}
+@media (min-width: 992px) {
+ .container {
+ width: 970px;
+ }
+}
+@media (min-width: 1200px) {
+ .container {
+ width: 1170px;
+ }
+}
+.container-fluid {
+ padding-right: 15px;
+ padding-left: 15px;
+ margin-right: auto;
+ margin-left: auto;
+}
+.row {
+ margin-right: -15px;
+ margin-left: -15px;
+}
+.col-xs-1, .col-sm-1, .col-md-1, .col-lg-1, .col-xs-2, .col-sm-2, .col-md-2, .col-lg-2, .col-xs-3, .col-sm-3, .col-md-3, .col-lg-3, .col-xs-4, .col-sm-4, .col-md-4, .col-lg-4, .col-xs-5, .col-sm-5, .col-md-5, .col-lg-5, .col-xs-6, .col-sm-6, .col-md-6, .col-lg-6, .col-xs-7, .col-sm-7, .col-md-7, .col-lg-7, .col-xs-8, .col-sm-8, .col-md-8, .col-lg-8, .col-xs-9, .col-sm-9, .col-md-9, .col-lg-9, .col-xs-10, .col-sm-10, .col-md-10, .col-lg-10, .col-xs-11, .col-sm-11, .col-md-11, .col-lg-11, .col-xs-12, .col-sm-12, .col-md-12, .col-lg-12 {
+ position: relative;
+ min-height: 1px;
+ padding-right: 15px;
+ padding-left: 15px;
+}
+.col-xs-1, .col-xs-2, .col-xs-3, .col-xs-4, .col-xs-5, .col-xs-6, .col-xs-7, .col-xs-8, .col-xs-9, .col-xs-10, .col-xs-11, .col-xs-12 {
+ float: left;
+}
+.col-xs-12 {
+ width: 100%;
+}
+.col-xs-11 {
+ width: 91.66666667%;
+}
+.col-xs-10 {
+ width: 83.33333333%;
+}
+.col-xs-9 {
+ width: 75%;
+}
+.col-xs-8 {
+ width: 66.66666667%;
+}
+.col-xs-7 {
+ width: 58.33333333%;
+}
+.col-xs-6 {
+ width: 50%;
+}
+.col-xs-5 {
+ width: 41.66666667%;
+}
+.col-xs-4 {
+ width: 33.33333333%;
+}
+.col-xs-3 {
+ width: 25%;
+}
+.col-xs-2 {
+ width: 16.66666667%;
+}
+.col-xs-1 {
+ width: 8.33333333%;
+}
+.col-xs-pull-12 {
+ right: 100%;
+}
+.col-xs-pull-11 {
+ right: 91.66666667%;
+}
+.col-xs-pull-10 {
+ right: 83.33333333%;
+}
+.col-xs-pull-9 {
+ right: 75%;
+}
+.col-xs-pull-8 {
+ right: 66.66666667%;
+}
+.col-xs-pull-7 {
+ right: 58.33333333%;
+}
+.col-xs-pull-6 {
+ right: 50%;
+}
+.col-xs-pull-5 {
+ right: 41.66666667%;
+}
+.col-xs-pull-4 {
+ right: 33.33333333%;
+}
+.col-xs-pull-3 {
+ right: 25%;
+}
+.col-xs-pull-2 {
+ right: 16.66666667%;
+}
+.col-xs-pull-1 {
+ right: 8.33333333%;
+}
+.col-xs-pull-0 {
+ right: 0;
+}
+.col-xs-push-12 {
+ left: 100%;
+}
+.col-xs-push-11 {
+ left: 91.66666667%;
+}
+.col-xs-push-10 {
+ left: 83.33333333%;
+}
+.col-xs-push-9 {
+ left: 75%;
+}
+.col-xs-push-8 {
+ left: 66.66666667%;
+}
+.col-xs-push-7 {
+ left: 58.33333333%;
+}
+.col-xs-push-6 {
+ left: 50%;
+}
+.col-xs-push-5 {
+ left: 41.66666667%;
+}
+.col-xs-push-4 {
+ left: 33.33333333%;
+}
+.col-xs-push-3 {
+ left: 25%;
+}
+.col-xs-push-2 {
+ left: 16.66666667%;
+}
+.col-xs-push-1 {
+ left: 8.33333333%;
+}
+.col-xs-push-0 {
+ left: 0;
+}
+.col-xs-offset-12 {
+ margin-left: 100%;
+}
+.col-xs-offset-11 {
+ margin-left: 91.66666667%;
+}
+.col-xs-offset-10 {
+ margin-left: 83.33333333%;
+}
+.col-xs-offset-9 {
+ margin-left: 75%;
+}
+.col-xs-offset-8 {
+ margin-left: 66.66666667%;
+}
+.col-xs-offset-7 {
+ margin-left: 58.33333333%;
+}
+.col-xs-offset-6 {
+ margin-left: 50%;
+}
+.col-xs-offset-5 {
+ margin-left: 41.66666667%;
+}
+.col-xs-offset-4 {
+ margin-left: 33.33333333%;
+}
+.col-xs-offset-3 {
+ margin-left: 25%;
+}
+.col-xs-offset-2 {
+ margin-left: 16.66666667%;
+}
+.col-xs-offset-1 {
+ margin-left: 8.33333333%;
+}
+.col-xs-offset-0 {
+ margin-left: 0;
+}
+@media (min-width: 768px) {
+ .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12 {
+ float: left;
+ }
+ .col-sm-12 {
+ width: 100%;
+ }
+ .col-sm-11 {
+ width: 91.66666667%;
+ }
+ .col-sm-10 {
+ width: 83.33333333%;
+ }
+ .col-sm-9 {
+ width: 75%;
+ }
+ .col-sm-8 {
+ width: 66.66666667%;
+ }
+ .col-sm-7 {
+ width: 58.33333333%;
+ }
+ .col-sm-6 {
+ width: 50%;
+ }
+ .col-sm-5 {
+ width: 41.66666667%;
+ }
+ .col-sm-4 {
+ width: 33.33333333%;
+ }
+ .col-sm-3 {
+ width: 25%;
+ }
+ .col-sm-2 {
+ width: 16.66666667%;
+ }
+ .col-sm-1 {
+ width: 8.33333333%;
+ }
+ .col-sm-pull-12 {
+ right: 100%;
+ }
+ .col-sm-pull-11 {
+ right: 91.66666667%;
+ }
+ .col-sm-pull-10 {
+ right: 83.33333333%;
+ }
+ .col-sm-pull-9 {
+ right: 75%;
+ }
+ .col-sm-pull-8 {
+ right: 66.66666667%;
+ }
+ .col-sm-pull-7 {
+ right: 58.33333333%;
+ }
+ .col-sm-pull-6 {
+ right: 50%;
+ }
+ .col-sm-pull-5 {
+ right: 41.66666667%;
+ }
+ .col-sm-pull-4 {
+ right: 33.33333333%;
+ }
+ .col-sm-pull-3 {
+ right: 25%;
+ }
+ .col-sm-pull-2 {
+ right: 16.66666667%;
+ }
+ .col-sm-pull-1 {
+ right: 8.33333333%;
+ }
+ .col-sm-pull-0 {
+ right: 0;
+ }
+ .col-sm-push-12 {
+ left: 100%;
+ }
+ .col-sm-push-11 {
+ left: 91.66666667%;
+ }
+ .col-sm-push-10 {
+ left: 83.33333333%;
+ }
+ .col-sm-push-9 {
+ left: 75%;
+ }
+ .col-sm-push-8 {
+ left: 66.66666667%;
+ }
+ .col-sm-push-7 {
+ left: 58.33333333%;
+ }
+ .col-sm-push-6 {
+ left: 50%;
+ }
+ .col-sm-push-5 {
+ left: 41.66666667%;
+ }
+ .col-sm-push-4 {
+ left: 33.33333333%;
+ }
+ .col-sm-push-3 {
+ left: 25%;
+ }
+ .col-sm-push-2 {
+ left: 16.66666667%;
+ }
+ .col-sm-push-1 {
+ left: 8.33333333%;
+ }
+ .col-sm-push-0 {
+ left: 0;
+ }
+ .col-sm-offset-12 {
+ margin-left: 100%;
+ }
+ .col-sm-offset-11 {
+ margin-left: 91.66666667%;
+ }
+ .col-sm-offset-10 {
+ margin-left: 83.33333333%;
+ }
+ .col-sm-offset-9 {
+ margin-left: 75%;
+ }
+ .col-sm-offset-8 {
+ margin-left: 66.66666667%;
+ }
+ .col-sm-offset-7 {
+ margin-left: 58.33333333%;
+ }
+ .col-sm-offset-6 {
+ margin-left: 50%;
+ }
+ .col-sm-offset-5 {
+ margin-left: 41.66666667%;
+ }
+ .col-sm-offset-4 {
+ margin-left: 33.33333333%;
+ }
+ .col-sm-offset-3 {
+ margin-left: 25%;
+ }
+ .col-sm-offset-2 {
+ margin-left: 16.66666667%;
+ }
+ .col-sm-offset-1 {
+ margin-left: 8.33333333%;
+ }
+ .col-sm-offset-0 {
+ margin-left: 0;
+ }
+}
+@media (min-width: 992px) {
+ .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12 {
+ float: left;
+ }
+ .col-md-12 {
+ width: 100%;
+ }
+ .col-md-11 {
+ width: 91.66666667%;
+ }
+ .col-md-10 {
+ width: 83.33333333%;
+ }
+ .col-md-9 {
+ width: 75%;
+ }
+ .col-md-8 {
+ width: 66.66666667%;
+ }
+ .col-md-7 {
+ width: 58.33333333%;
+ }
+ .col-md-6 {
+ width: 50%;
+ }
+ .col-md-5 {
+ width: 41.66666667%;
+ }
+ .col-md-4 {
+ width: 33.33333333%;
+ }
+ .col-md-3 {
+ width: 25%;
+ }
+ .col-md-2 {
+ width: 16.66666667%;
+ }
+ .col-md-1 {
+ width: 8.33333333%;
+ }
+ .col-md-pull-12 {
+ right: 100%;
+ }
+ .col-md-pull-11 {
+ right: 91.66666667%;
+ }
+ .col-md-pull-10 {
+ right: 83.33333333%;
+ }
+ .col-md-pull-9 {
+ right: 75%;
+ }
+ .col-md-pull-8 {
+ right: 66.66666667%;
+ }
+ .col-md-pull-7 {
+ right: 58.33333333%;
+ }
+ .col-md-pull-6 {
+ right: 50%;
+ }
+ .col-md-pull-5 {
+ right: 41.66666667%;
+ }
+ .col-md-pull-4 {
+ right: 33.33333333%;
+ }
+ .col-md-pull-3 {
+ right: 25%;
+ }
+ .col-md-pull-2 {
+ right: 16.66666667%;
+ }
+ .col-md-pull-1 {
+ right: 8.33333333%;
+ }
+ .col-md-pull-0 {
+ right: 0;
+ }
+ .col-md-push-12 {
+ left: 100%;
+ }
+ .col-md-push-11 {
+ left: 91.66666667%;
+ }
+ .col-md-push-10 {
+ left: 83.33333333%;
+ }
+ .col-md-push-9 {
+ left: 75%;
+ }
+ .col-md-push-8 {
+ left: 66.66666667%;
+ }
+ .col-md-push-7 {
+ left: 58.33333333%;
+ }
+ .col-md-push-6 {
+ left: 50%;
+ }
+ .col-md-push-5 {
+ left: 41.66666667%;
+ }
+ .col-md-push-4 {
+ left: 33.33333333%;
+ }
+ .col-md-push-3 {
+ left: 25%;
+ }
+ .col-md-push-2 {
+ left: 16.66666667%;
+ }
+ .col-md-push-1 {
+ left: 8.33333333%;
+ }
+ .col-md-push-0 {
+ left: 0;
+ }
+ .col-md-offset-12 {
+ margin-left: 100%;
+ }
+ .col-md-offset-11 {
+ margin-left: 91.66666667%;
+ }
+ .col-md-offset-10 {
+ margin-left: 83.33333333%;
+ }
+ .col-md-offset-9 {
+ margin-left: 75%;
+ }
+ .col-md-offset-8 {
+ margin-left: 66.66666667%;
+ }
+ .col-md-offset-7 {
+ margin-left: 58.33333333%;
+ }
+ .col-md-offset-6 {
+ margin-left: 50%;
+ }
+ .col-md-offset-5 {
+ margin-left: 41.66666667%;
+ }
+ .col-md-offset-4 {
+ margin-left: 33.33333333%;
+ }
+ .col-md-offset-3 {
+ margin-left: 25%;
+ }
+ .col-md-offset-2 {
+ margin-left: 16.66666667%;
+ }
+ .col-md-offset-1 {
+ margin-left: 8.33333333%;
+ }
+ .col-md-offset-0 {
+ margin-left: 0;
+ }
+}
+@media (min-width: 1200px) {
+ .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12 {
+ float: left;
+ }
+ .col-lg-12 {
+ width: 100%;
+ }
+ .col-lg-11 {
+ width: 91.66666667%;
+ }
+ .col-lg-10 {
+ width: 83.33333333%;
+ }
+ .col-lg-9 {
+ width: 75%;
+ }
+ .col-lg-8 {
+ width: 66.66666667%;
+ }
+ .col-lg-7 {
+ width: 58.33333333%;
+ }
+ .col-lg-6 {
+ width: 50%;
+ }
+ .col-lg-5 {
+ width: 41.66666667%;
+ }
+ .col-lg-4 {
+ width: 33.33333333%;
+ }
+ .col-lg-3 {
+ width: 25%;
+ }
+ .col-lg-2 {
+ width: 16.66666667%;
+ }
+ .col-lg-1 {
+ width: 8.33333333%;
+ }
+ .col-lg-pull-12 {
+ right: 100%;
+ }
+ .col-lg-pull-11 {
+ right: 91.66666667%;
+ }
+ .col-lg-pull-10 {
+ right: 83.33333333%;
+ }
+ .col-lg-pull-9 {
+ right: 75%;
+ }
+ .col-lg-pull-8 {
+ right: 66.66666667%;
+ }
+ .col-lg-pull-7 {
+ right: 58.33333333%;
+ }
+ .col-lg-pull-6 {
+ right: 50%;
+ }
+ .col-lg-pull-5 {
+ right: 41.66666667%;
+ }
+ .col-lg-pull-4 {
+ right: 33.33333333%;
+ }
+ .col-lg-pull-3 {
+ right: 25%;
+ }
+ .col-lg-pull-2 {
+ right: 16.66666667%;
+ }
+ .col-lg-pull-1 {
+ right: 8.33333333%;
+ }
+ .col-lg-pull-0 {
+ right: 0;
+ }
+ .col-lg-push-12 {
+ left: 100%;
+ }
+ .col-lg-push-11 {
+ left: 91.66666667%;
+ }
+ .col-lg-push-10 {
+ left: 83.33333333%;
+ }
+ .col-lg-push-9 {
+ left: 75%;
+ }
+ .col-lg-push-8 {
+ left: 66.66666667%;
+ }
+ .col-lg-push-7 {
+ left: 58.33333333%;
+ }
+ .col-lg-push-6 {
+ left: 50%;
+ }
+ .col-lg-push-5 {
+ left: 41.66666667%;
+ }
+ .col-lg-push-4 {
+ left: 33.33333333%;
+ }
+ .col-lg-push-3 {
+ left: 25%;
+ }
+ .col-lg-push-2 {
+ left: 16.66666667%;
+ }
+ .col-lg-push-1 {
+ left: 8.33333333%;
+ }
+ .col-lg-push-0 {
+ left: 0;
+ }
+ .col-lg-offset-12 {
+ margin-left: 100%;
+ }
+ .col-lg-offset-11 {
+ margin-left: 91.66666667%;
+ }
+ .col-lg-offset-10 {
+ margin-left: 83.33333333%;
+ }
+ .col-lg-offset-9 {
+ margin-left: 75%;
+ }
+ .col-lg-offset-8 {
+ margin-left: 66.66666667%;
+ }
+ .col-lg-offset-7 {
+ margin-left: 58.33333333%;
+ }
+ .col-lg-offset-6 {
+ margin-left: 50%;
+ }
+ .col-lg-offset-5 {
+ margin-left: 41.66666667%;
+ }
+ .col-lg-offset-4 {
+ margin-left: 33.33333333%;
+ }
+ .col-lg-offset-3 {
+ margin-left: 25%;
+ }
+ .col-lg-offset-2 {
+ margin-left: 16.66666667%;
+ }
+ .col-lg-offset-1 {
+ margin-left: 8.33333333%;
+ }
+ .col-lg-offset-0 {
+ margin-left: 0;
+ }
+}
+table {
+ max-width: 100%;
+ background-color: transparent;
+}
+th {
+ text-align: left;
+}
+.table {
+ width: 100%;
+ margin-bottom: 20px;
+}
+.table > thead > tr > th,
+.table > tbody > tr > th,
+.table > tfoot > tr > th,
+.table > thead > tr > td,
+.table > tbody > tr > td,
+.table > tfoot > tr > td {
+ padding: 8px;
+ line-height: 1.42857143;
+ vertical-align: top;
+ border-top: 1px solid #ddd;
+}
+.table > thead > tr > th {
+ vertical-align: bottom;
+ border-bottom: 2px solid #ddd;
+}
+.table > caption + thead > tr:first-child > th,
+.table > colgroup + thead > tr:first-child > th,
+.table > thead:first-child > tr:first-child > th,
+.table > caption + thead > tr:first-child > td,
+.table > colgroup + thead > tr:first-child > td,
+.table > thead:first-child > tr:first-child > td {
+ border-top: 0;
+}
+.table > tbody + tbody {
+ border-top: 2px solid #ddd;
+}
+.table .table {
+ background-color: #fff;
+}
+.table-condensed > thead > tr > th,
+.table-condensed > tbody > tr > th,
+.table-condensed > tfoot > tr > th,
+.table-condensed > thead > tr > td,
+.table-condensed > tbody > tr > td,
+.table-condensed > tfoot > tr > td {
+ padding: 5px;
+}
+.table-bordered {
+ border: 1px solid #ddd;
+}
+.table-bordered > thead > tr > th,
+.table-bordered > tbody > tr > th,
+.table-bordered > tfoot > tr > th,
+.table-bordered > thead > tr > td,
+.table-bordered > tbody > tr > td,
+.table-bordered > tfoot > tr > td {
+ border: 1px solid #ddd;
+}
+.table-bordered > thead > tr > th,
+.table-bordered > thead > tr > td {
+ border-bottom-width: 2px;
+}
+.table-striped > tbody > tr:nth-child(odd) > td,
+.table-striped > tbody > tr:nth-child(odd) > th {
+ background-color: #f9f9f9;
+}
+.table-hover > tbody > tr:hover > td,
+.table-hover > tbody > tr:hover > th {
+ background-color: #f5f5f5;
+}
+table col[class*="col-"] {
+ position: static;
+ display: table-column;
+ float: none;
+}
+table td[class*="col-"],
+table th[class*="col-"] {
+ position: static;
+ display: table-cell;
+ float: none;
+}
+.table > thead > tr > td.active,
+.table > tbody > tr > td.active,
+.table > tfoot > tr > td.active,
+.table > thead > tr > th.active,
+.table > tbody > tr > th.active,
+.table > tfoot > tr > th.active,
+.table > thead > tr.active > td,
+.table > tbody > tr.active > td,
+.table > tfoot > tr.active > td,
+.table > thead > tr.active > th,
+.table > tbody > tr.active > th,
+.table > tfoot > tr.active > th {
+ background-color: #f5f5f5;
+}
+.table-hover > tbody > tr > td.active:hover,
+.table-hover > tbody > tr > th.active:hover,
+.table-hover > tbody > tr.active:hover > td,
+.table-hover > tbody > tr.active:hover > th {
+ background-color: #e8e8e8;
+}
+.table > thead > tr > td.success,
+.table > tbody > tr > td.success,
+.table > tfoot > tr > td.success,
+.table > thead > tr > th.success,
+.table > tbody > tr > th.success,
+.table > tfoot > tr > th.success,
+.table > thead > tr.success > td,
+.table > tbody > tr.success > td,
+.table > tfoot > tr.success > td,
+.table > thead > tr.success > th,
+.table > tbody > tr.success > th,
+.table > tfoot > tr.success > th {
+ background-color: #dff0d8;
+}
+.table-hover > tbody > tr > td.success:hover,
+.table-hover > tbody > tr > th.success:hover,
+.table-hover > tbody > tr.success:hover > td,
+.table-hover > tbody > tr.success:hover > th {
+ background-color: #d0e9c6;
+}
+.table > thead > tr > td.info,
+.table > tbody > tr > td.info,
+.table > tfoot > tr > td.info,
+.table > thead > tr > th.info,
+.table > tbody > tr > th.info,
+.table > tfoot > tr > th.info,
+.table > thead > tr.info > td,
+.table > tbody > tr.info > td,
+.table > tfoot > tr.info > td,
+.table > thead > tr.info > th,
+.table > tbody > tr.info > th,
+.table > tfoot > tr.info > th {
+ background-color: #d9edf7;
+}
+.table-hover > tbody > tr > td.info:hover,
+.table-hover > tbody > tr > th.info:hover,
+.table-hover > tbody > tr.info:hover > td,
+.table-hover > tbody > tr.info:hover > th {
+ background-color: #c4e3f3;
+}
+.table > thead > tr > td.warning,
+.table > tbody > tr > td.warning,
+.table > tfoot > tr > td.warning,
+.table > thead > tr > th.warning,
+.table > tbody > tr > th.warning,
+.table > tfoot > tr > th.warning,
+.table > thead > tr.warning > td,
+.table > tbody > tr.warning > td,
+.table > tfoot > tr.warning > td,
+.table > thead > tr.warning > th,
+.table > tbody > tr.warning > th,
+.table > tfoot > tr.warning > th {
+ background-color: #fcf8e3;
+}
+.table-hover > tbody > tr > td.warning:hover,
+.table-hover > tbody > tr > th.warning:hover,
+.table-hover > tbody > tr.warning:hover > td,
+.table-hover > tbody > tr.warning:hover > th {
+ background-color: #faf2cc;
+}
+.table > thead > tr > td.danger,
+.table > tbody > tr > td.danger,
+.table > tfoot > tr > td.danger,
+.table > thead > tr > th.danger,
+.table > tbody > tr > th.danger,
+.table > tfoot > tr > th.danger,
+.table > thead > tr.danger > td,
+.table > tbody > tr.danger > td,
+.table > tfoot > tr.danger > td,
+.table > thead > tr.danger > th,
+.table > tbody > tr.danger > th,
+.table > tfoot > tr.danger > th {
+ background-color: #f2dede;
+}
+.table-hover > tbody > tr > td.danger:hover,
+.table-hover > tbody > tr > th.danger:hover,
+.table-hover > tbody > tr.danger:hover > td,
+.table-hover > tbody > tr.danger:hover > th {
+ background-color: #ebcccc;
+}
+@media (max-width: 767px) {
+ .table-responsive {
+ width: 100%;
+ margin-bottom: 15px;
+ overflow-x: scroll;
+ overflow-y: hidden;
+ -webkit-overflow-scrolling: touch;
+ -ms-overflow-style: -ms-autohiding-scrollbar;
+ border: 1px solid #ddd;
+ }
+ .table-responsive > .table {
+ margin-bottom: 0;
+ }
+ .table-responsive > .table > thead > tr > th,
+ .table-responsive > .table > tbody > tr > th,
+ .table-responsive > .table > tfoot > tr > th,
+ .table-responsive > .table > thead > tr > td,
+ .table-responsive > .table > tbody > tr > td,
+ .table-responsive > .table > tfoot > tr > td {
+ white-space: nowrap;
+ }
+ .table-responsive > .table-bordered {
+ border: 0;
+ }
+ .table-responsive > .table-bordered > thead > tr > th:first-child,
+ .table-responsive > .table-bordered > tbody > tr > th:first-child,
+ .table-responsive > .table-bordered > tfoot > tr > th:first-child,
+ .table-responsive > .table-bordered > thead > tr > td:first-child,
+ .table-responsive > .table-bordered > tbody > tr > td:first-child,
+ .table-responsive > .table-bordered > tfoot > tr > td:first-child {
+ border-left: 0;
+ }
+ .table-responsive > .table-bordered > thead > tr > th:last-child,
+ .table-responsive > .table-bordered > tbody > tr > th:last-child,
+ .table-responsive > .table-bordered > tfoot > tr > th:last-child,
+ .table-responsive > .table-bordered > thead > tr > td:last-child,
+ .table-responsive > .table-bordered > tbody > tr > td:last-child,
+ .table-responsive > .table-bordered > tfoot > tr > td:last-child {
+ border-right: 0;
+ }
+ .table-responsive > .table-bordered > tbody > tr:last-child > th,
+ .table-responsive > .table-bordered > tfoot > tr:last-child > th,
+ .table-responsive > .table-bordered > tbody > tr:last-child > td,
+ .table-responsive > .table-bordered > tfoot > tr:last-child > td {
+ border-bottom: 0;
+ }
+}
+fieldset {
+ min-width: 0;
+ padding: 0;
+ margin: 0;
+ border: 0;
+}
+legend {
+ display: block;
+ width: 100%;
+ padding: 0;
+ margin-bottom: 20px;
+ font-size: 21px;
+ line-height: inherit;
+ color: #333;
+ border: 0;
+ border-bottom: 1px solid #e5e5e5;
+}
+label {
+ display: inline-block;
+ margin-bottom: 5px;
+ font-weight: bold;
+}
+input[type="search"] {
+ -webkit-box-sizing: border-box;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+}
+input[type="radio"],
+input[type="checkbox"] {
+ margin: 4px 0 0;
+ margin-top: 1px \9;
+ /* IE8-9 */
+ line-height: normal;
+}
+input[type="file"] {
+ display: block;
+}
+input[type="range"] {
+ display: block;
+ width: 100%;
+}
+select[multiple],
+select[size] {
+ height: auto;
+}
+input[type="file"]:focus,
+input[type="radio"]:focus,
+input[type="checkbox"]:focus {
+ outline: thin dotted;
+ outline: 5px auto -webkit-focus-ring-color;
+ outline-offset: -2px;
+}
+output {
+ display: block;
+ padding-top: 7px;
+ font-size: 14px;
+ line-height: 1.42857143;
+ color: #555;
+}
+.form-control {
+ display: block;
+ width: 100%;
+ height: 34px;
+ padding: 6px 12px;
+ font-size: 14px;
+ line-height: 1.42857143;
+ color: #555;
+ background-color: #fff;
+ background-image: none;
+ border: 1px solid #ccc;
+ border-radius: 4px;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
+ -webkit-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
+ transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
+}
+.form-control:focus {
+ border-color: #66afe9;
+ outline: 0;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102, 175, 233, .6);
+ box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102, 175, 233, .6);
+}
+.form-control::-moz-placeholder {
+ color: #999;
+ opacity: 1;
+}
+.form-control:-ms-input-placeholder {
+ color: #999;
+}
+.form-control::-webkit-input-placeholder {
+ color: #999;
+}
+.form-control[disabled],
+.form-control[readonly],
+fieldset[disabled] .form-control {
+ cursor: not-allowed;
+ background-color: #eee;
+ opacity: 1;
+}
+textarea.form-control {
+ height: auto;
+}
+input[type="search"] {
+ -webkit-appearance: none;
+}
+input[type="date"] {
+ line-height: 34px;
+}
+.form-group {
+ margin-bottom: 15px;
+}
+.radio,
+.checkbox {
+ display: block;
+ min-height: 20px;
+ padding-left: 20px;
+ margin-top: 10px;
+ margin-bottom: 10px;
+}
+.radio label,
+.checkbox label {
+ display: inline;
+ font-weight: normal;
+ cursor: pointer;
+}
+.radio input[type="radio"],
+.radio-inline input[type="radio"],
+.checkbox input[type="checkbox"],
+.checkbox-inline input[type="checkbox"] {
+ float: left;
+ margin-left: -20px;
+}
+.radio + .radio,
+.checkbox + .checkbox {
+ margin-top: -5px;
+}
+.radio-inline,
+.checkbox-inline {
+ display: inline-block;
+ padding-left: 20px;
+ margin-bottom: 0;
+ font-weight: normal;
+ vertical-align: middle;
+ cursor: pointer;
+}
+.radio-inline + .radio-inline,
+.checkbox-inline + .checkbox-inline {
+ margin-top: 0;
+ margin-left: 10px;
+}
+input[type="radio"][disabled],
+input[type="checkbox"][disabled],
+.radio[disabled],
+.radio-inline[disabled],
+.checkbox[disabled],
+.checkbox-inline[disabled],
+fieldset[disabled] input[type="radio"],
+fieldset[disabled] input[type="checkbox"],
+fieldset[disabled] .radio,
+fieldset[disabled] .radio-inline,
+fieldset[disabled] .checkbox,
+fieldset[disabled] .checkbox-inline {
+ cursor: not-allowed;
+}
+.input-sm {
+ height: 30px;
+ padding: 5px 10px;
+ font-size: 12px;
+ line-height: 1.5;
+ border-radius: 3px;
+}
+select.input-sm {
+ height: 30px;
+ line-height: 30px;
+}
+textarea.input-sm,
+select[multiple].input-sm {
+ height: auto;
+}
+.input-lg {
+ height: 46px;
+ padding: 10px 16px;
+ font-size: 18px;
+ line-height: 1.33;
+ border-radius: 6px;
+}
+select.input-lg {
+ height: 46px;
+ line-height: 46px;
+}
+textarea.input-lg,
+select[multiple].input-lg {
+ height: auto;
+}
+.has-feedback {
+ position: relative;
+}
+.has-feedback .form-control {
+ padding-right: 42.5px;
+}
+.has-feedback .form-control-feedback {
+ position: absolute;
+ top: 25px;
+ right: 0;
+ display: block;
+ width: 34px;
+ height: 34px;
+ line-height: 34px;
+ text-align: center;
+}
+.has-success .help-block,
+.has-success .control-label,
+.has-success .radio,
+.has-success .checkbox,
+.has-success .radio-inline,
+.has-success .checkbox-inline {
+ color: #3c763d;
+}
+.has-success .form-control {
+ border-color: #3c763d;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
+}
+.has-success .form-control:focus {
+ border-color: #2b542c;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075), 0 0 6px #67b168;
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075), 0 0 6px #67b168;
+}
+.has-success .input-group-addon {
+ color: #3c763d;
+ background-color: #dff0d8;
+ border-color: #3c763d;
+}
+.has-success .form-control-feedback {
+ color: #3c763d;
+}
+.has-warning .help-block,
+.has-warning .control-label,
+.has-warning .radio,
+.has-warning .checkbox,
+.has-warning .radio-inline,
+.has-warning .checkbox-inline {
+ color: #8a6d3b;
+}
+.has-warning .form-control {
+ border-color: #8a6d3b;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
+}
+.has-warning .form-control:focus {
+ border-color: #66512c;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075), 0 0 6px #c0a16b;
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075), 0 0 6px #c0a16b;
+}
+.has-warning .input-group-addon {
+ color: #8a6d3b;
+ background-color: #fcf8e3;
+ border-color: #8a6d3b;
+}
+.has-warning .form-control-feedback {
+ color: #8a6d3b;
+}
+.has-error .help-block,
+.has-error .control-label,
+.has-error .radio,
+.has-error .checkbox,
+.has-error .radio-inline,
+.has-error .checkbox-inline {
+ color: #a94442;
+}
+.has-error .form-control {
+ border-color: #a94442;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
+}
+.has-error .form-control:focus {
+ border-color: #843534;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075), 0 0 6px #ce8483;
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075), 0 0 6px #ce8483;
+}
+.has-error .input-group-addon {
+ color: #a94442;
+ background-color: #f2dede;
+ border-color: #a94442;
+}
+.has-error .form-control-feedback {
+ color: #a94442;
+}
+.form-control-static {
+ margin-bottom: 0;
+}
+.help-block {
+ display: block;
+ margin-top: 5px;
+ margin-bottom: 10px;
+ color: #737373;
+}
+@media (min-width: 768px) {
+ .form-inline .form-group {
+ display: inline-block;
+ margin-bottom: 0;
+ vertical-align: middle;
+ }
+ .form-inline .form-control {
+ display: inline-block;
+ width: auto;
+ vertical-align: middle;
+ }
+ .form-inline .input-group > .form-control {
+ width: 100%;
+ }
+ .form-inline .control-label {
+ margin-bottom: 0;
+ vertical-align: middle;
+ }
+ .form-inline .radio,
+ .form-inline .checkbox {
+ display: inline-block;
+ padding-left: 0;
+ margin-top: 0;
+ margin-bottom: 0;
+ vertical-align: middle;
+ }
+ .form-inline .radio input[type="radio"],
+ .form-inline .checkbox input[type="checkbox"] {
+ float: none;
+ margin-left: 0;
+ }
+ .form-inline .has-feedback .form-control-feedback {
+ top: 0;
+ }
+}
+.form-horizontal .control-label,
+.form-horizontal .radio,
+.form-horizontal .checkbox,
+.form-horizontal .radio-inline,
+.form-horizontal .checkbox-inline {
+ padding-top: 7px;
+ margin-top: 0;
+ margin-bottom: 0;
+}
+.form-horizontal .radio,
+.form-horizontal .checkbox {
+ min-height: 27px;
+}
+.form-horizontal .form-group {
+ margin-right: -15px;
+ margin-left: -15px;
+}
+.form-horizontal .form-control-static {
+ padding-top: 7px;
+}
+@media (min-width: 768px) {
+ .form-horizontal .control-label {
+ text-align: right;
+ }
+}
+.form-horizontal .has-feedback .form-control-feedback {
+ top: 0;
+ right: 15px;
+}
+.btn {
+ display: inline-block;
+ padding: 6px 12px;
+ margin-bottom: 0;
+ font-size: 14px;
+ font-weight: normal;
+ line-height: 1.42857143;
+ text-align: center;
+ white-space: nowrap;
+ vertical-align: middle;
+ cursor: pointer;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+ background-image: none;
+ border: 1px solid transparent;
+ border-radius: 4px;
+}
+.btn:focus,
+.btn:active:focus,
+.btn.active:focus {
+ outline: thin dotted;
+ outline: 5px auto -webkit-focus-ring-color;
+ outline-offset: -2px;
+}
+.btn:hover,
+.btn:focus {
+ color: #333;
+ text-decoration: none;
+}
+.btn:active,
+.btn.active {
+ background-image: none;
+ outline: 0;
+ /*-webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, .125);
+ box-shadow: inset 0 3px 5px rgba(0, 0, 0, .125);*/
+}
+.btn.disabled,
+.btn[disabled],
+fieldset[disabled] .btn {
+ pointer-events: none;
+ cursor: not-allowed;
+ filter: alpha(opacity=65);
+ -webkit-box-shadow: none;
+ box-shadow: none;
+ opacity: .65;
+}
+.btn-default {
+ color: #333;
+ background-color: #fff;
+ border-color: #ccc;
+}
+.btn-default:hover,
+.btn-default:focus,
+.btn-default:active,
+.btn-default.active,
+.open .dropdown-toggle.btn-default {
+ color: #333;
+ background-color: #ebebeb;
+ border-color: #adadad;
+}
+.btn-default:active,
+.btn-default.active,
+.open .dropdown-toggle.btn-default {
+ background-image: none;
+}
+.btn-default.disabled,
+.btn-default[disabled],
+fieldset[disabled] .btn-default,
+.btn-default.disabled:hover,
+.btn-default[disabled]:hover,
+fieldset[disabled] .btn-default:hover,
+.btn-default.disabled:focus,
+.btn-default[disabled]:focus,
+fieldset[disabled] .btn-default:focus,
+.btn-default.disabled:active,
+.btn-default[disabled]:active,
+fieldset[disabled] .btn-default:active,
+.btn-default.disabled.active,
+.btn-default[disabled].active,
+fieldset[disabled] .btn-default.active {
+ background-color: #fff;
+ border-color: #ccc;
+}
+.btn-default .badge {
+ color: #fff;
+ background-color: #333;
+}
+.btn-primary {
+ color: #fff;
+ background-color: #428bca;
+ border-color: #357ebd;
+}
+.btn-primary:hover,
+.btn-primary:focus,
+.btn-primary:active,
+.btn-primary.active,
+.open .dropdown-toggle.btn-primary {
+ color: #fff;
+ background-color: #3276b1;
+ border-color: #285e8e;
+}
+.btn-primary:active,
+.btn-primary.active,
+.open .dropdown-toggle.btn-primary {
+ background-image: none;
+}
+.btn-primary.disabled,
+.btn-primary[disabled],
+fieldset[disabled] .btn-primary,
+.btn-primary.disabled:hover,
+.btn-primary[disabled]:hover,
+fieldset[disabled] .btn-primary:hover,
+.btn-primary.disabled:focus,
+.btn-primary[disabled]:focus,
+fieldset[disabled] .btn-primary:focus,
+.btn-primary.disabled:active,
+.btn-primary[disabled]:active,
+fieldset[disabled] .btn-primary:active,
+.btn-primary.disabled.active,
+.btn-primary[disabled].active,
+fieldset[disabled] .btn-primary.active {
+ background-color: #428bca;
+ border-color: #357ebd;
+}
+.btn-primary .badge {
+ color: #428bca;
+ background-color: #fff;
+}
+.btn-success {
+ color: #fff;
+ background-color: #5cb85c;
+ border-color: #4cae4c;
+}
+.btn-success:hover,
+.btn-success:focus,
+.btn-success:active,
+.btn-success.active,
+.open .dropdown-toggle.btn-success {
+ color: #fff;
+ background-color: #47a447;
+ border-color: #398439;
+}
+.btn-success:active,
+.btn-success.active,
+.open .dropdown-toggle.btn-success {
+ background-image: none;
+}
+.btn-success.disabled,
+.btn-success[disabled],
+fieldset[disabled] .btn-success,
+.btn-success.disabled:hover,
+.btn-success[disabled]:hover,
+fieldset[disabled] .btn-success:hover,
+.btn-success.disabled:focus,
+.btn-success[disabled]:focus,
+fieldset[disabled] .btn-success:focus,
+.btn-success.disabled:active,
+.btn-success[disabled]:active,
+fieldset[disabled] .btn-success:active,
+.btn-success.disabled.active,
+.btn-success[disabled].active,
+fieldset[disabled] .btn-success.active {
+ background-color: #5cb85c;
+ border-color: #4cae4c;
+}
+.btn-success .badge {
+ color: #5cb85c;
+ background-color: #fff;
+}
+.btn-info {
+ color: #fff;
+ background-color: #5bc0de;
+ border-color: #46b8da;
+}
+.btn-info:hover,
+.btn-info:focus,
+.btn-info:active,
+.btn-info.active,
+.open .dropdown-toggle.btn-info {
+ color: #fff;
+ background-color: #39b3d7;
+ border-color: #269abc;
+}
+.btn-info:active,
+.btn-info.active,
+.open .dropdown-toggle.btn-info {
+ background-image: none;
+}
+.btn-info.disabled,
+.btn-info[disabled],
+fieldset[disabled] .btn-info,
+.btn-info.disabled:hover,
+.btn-info[disabled]:hover,
+fieldset[disabled] .btn-info:hover,
+.btn-info.disabled:focus,
+.btn-info[disabled]:focus,
+fieldset[disabled] .btn-info:focus,
+.btn-info.disabled:active,
+.btn-info[disabled]:active,
+fieldset[disabled] .btn-info:active,
+.btn-info.disabled.active,
+.btn-info[disabled].active,
+fieldset[disabled] .btn-info.active {
+ background-color: #5bc0de;
+ border-color: #46b8da;
+}
+.btn-info .badge {
+ color: #5bc0de;
+ background-color: #fff;
+}
+.btn-warning {
+ color: #fff;
+ background-color: #f0ad4e;
+ border-color: #eea236;
+}
+.btn-warning:hover,
+.btn-warning:focus,
+.btn-warning:active,
+.btn-warning.active,
+.open .dropdown-toggle.btn-warning {
+ color: #fff;
+ background-color: #ed9c28;
+ border-color: #d58512;
+}
+.btn-warning:active,
+.btn-warning.active,
+.open .dropdown-toggle.btn-warning {
+ background-image: none;
+}
+.btn-warning.disabled,
+.btn-warning[disabled],
+fieldset[disabled] .btn-warning,
+.btn-warning.disabled:hover,
+.btn-warning[disabled]:hover,
+fieldset[disabled] .btn-warning:hover,
+.btn-warning.disabled:focus,
+.btn-warning[disabled]:focus,
+fieldset[disabled] .btn-warning:focus,
+.btn-warning.disabled:active,
+.btn-warning[disabled]:active,
+fieldset[disabled] .btn-warning:active,
+.btn-warning.disabled.active,
+.btn-warning[disabled].active,
+fieldset[disabled] .btn-warning.active {
+ background-color: #f0ad4e;
+ border-color: #eea236;
+}
+.btn-warning .badge {
+ color: #f0ad4e;
+ background-color: #fff;
+}
+.btn-danger {
+ color: #fff;
+ background-color: #d9534f;
+ border-color: #d43f3a;
+}
+.btn-danger:hover,
+.btn-danger:focus,
+.btn-danger:active,
+.btn-danger.active,
+.open .dropdown-toggle.btn-danger {
+ color: #fff;
+ background-color: #d2322d;
+ border-color: #ac2925;
+}
+.btn-danger:active,
+.btn-danger.active,
+.open .dropdown-toggle.btn-danger {
+ background-image: none;
+}
+.btn-danger.disabled,
+.btn-danger[disabled],
+fieldset[disabled] .btn-danger,
+.btn-danger.disabled:hover,
+.btn-danger[disabled]:hover,
+fieldset[disabled] .btn-danger:hover,
+.btn-danger.disabled:focus,
+.btn-danger[disabled]:focus,
+fieldset[disabled] .btn-danger:focus,
+.btn-danger.disabled:active,
+.btn-danger[disabled]:active,
+fieldset[disabled] .btn-danger:active,
+.btn-danger.disabled.active,
+.btn-danger[disabled].active,
+fieldset[disabled] .btn-danger.active {
+ background-color: #d9534f;
+ border-color: #d43f3a;
+}
+.btn-danger .badge {
+ color: #d9534f;
+ background-color: #fff;
+}
+.btn-link {
+ font-weight: normal;
+ color: #428bca;
+ cursor: pointer;
+ border-radius: 0;
+}
+.btn-link,
+.btn-link:active,
+.btn-link[disabled],
+fieldset[disabled] .btn-link {
+ background-color: transparent;
+ -webkit-box-shadow: none;
+ box-shadow: none;
+}
+.btn-link,
+.btn-link:hover,
+.btn-link:focus,
+.btn-link:active {
+ border-color: transparent;
+}
+.btn-link:hover,
+.btn-link:focus {
+ color: #2a6496;
+ text-decoration: underline;
+ background-color: transparent;
+}
+.btn-link[disabled]:hover,
+fieldset[disabled] .btn-link:hover,
+.btn-link[disabled]:focus,
+fieldset[disabled] .btn-link:focus {
+ color: #999;
+ text-decoration: none;
+}
+.btn-lg,
+.btn-group-lg > .btn {
+ padding: 10px 16px;
+ font-size: 18px;
+ line-height: 1.33;
+ border-radius: 6px;
+}
+.btn-sm,
+.btn-group-sm > .btn {
+ padding: 5px 10px;
+ font-size: 12px;
+ line-height: 1.5;
+ border-radius: 3px;
+}
+.btn-xs,
+.btn-group-xs > .btn {
+ padding: 1px 5px;
+ font-size: 12px;
+ line-height: 1.5;
+ border-radius: 3px;
+}
+.btn-block {
+ display: block;
+ width: 100%;
+ padding-right: 0;
+ padding-left: 0;
+}
+.btn-block + .btn-block {
+ margin-top: 5px;
+}
+input[type="submit"].btn-block,
+input[type="reset"].btn-block,
+input[type="button"].btn-block {
+ width: 100%;
+}
+.fade {
+ opacity: 0;
+ -webkit-transition: opacity .15s linear;
+ transition: opacity .15s linear;
+}
+.fade.in {
+ opacity: 1;
+}
+.collapse {
+ display: none;
+}
+.collapse.in {
+ display: block;
+}
+.collapsing {
+ position: relative;
+ height: 0;
+ overflow: hidden;
+ -webkit-transition: height .35s ease;
+ transition: height .35s ease;
+}
+@font-face {
+ font-family: 'Glyphicons Halflings';
+
+ src: url('../fonts/glyphicons-halflings-regular.eot');
+ src: url('../fonts/glyphicons-halflings-regular.eot?#iefix') format('embedded-opentype'), url('../fonts/glyphicons-halflings-regular.woff') format('woff'), url('../fonts/glyphicons-halflings-regular.ttf') format('truetype'), url('../fonts/glyphicons-halflings-regular.svg#glyphicons_halflingsregular') format('svg');
+}
+.glyphicon {
+ position: relative;
+ top: 1px;
+ display: inline-block;
+ font-family: 'Glyphicons Halflings';
+ font-style: normal;
+ font-weight: normal;
+ line-height: 1;
+
+ -webkit-font-smoothing: antialiased;
+ -moz-osx-font-smoothing: grayscale;
+}
+.glyphicon-asterisk:before {
+ content: "\2a";
+}
+.glyphicon-plus:before {
+ content: "\2b";
+}
+.glyphicon-euro:before {
+ content: "\20ac";
+}
+.glyphicon-minus:before {
+ content: "\2212";
+}
+.glyphicon-cloud:before {
+ content: "\2601";
+}
+.glyphicon-envelope:before {
+ content: "\2709";
+}
+.glyphicon-pencil:before {
+ content: "\270f";
+}
+.glyphicon-glass:before {
+ content: "\e001";
+}
+.glyphicon-music:before {
+ content: "\e002";
+}
+.glyphicon-search:before {
+ content: "\e003";
+}
+.glyphicon-heart:before {
+ content: "\e005";
+}
+.glyphicon-star:before {
+ content: "\e006";
+}
+.glyphicon-star-empty:before {
+ content: "\e007";
+}
+.glyphicon-user:before {
+ content: "\e008";
+}
+.glyphicon-film:before {
+ content: "\e009";
+}
+.glyphicon-th-large:before {
+ content: "\e010";
+}
+.glyphicon-th:before {
+ content: "\e011";
+}
+.glyphicon-th-list:before {
+ content: "\e012";
+}
+.glyphicon-ok:before {
+ content: "\e013";
+}
+.glyphicon-remove:before {
+ content: "\e014";
+}
+.glyphicon-zoom-in:before {
+ content: "\e015";
+}
+.glyphicon-zoom-out:before {
+ content: "\e016";
+}
+.glyphicon-off:before {
+ content: "\e017";
+}
+.glyphicon-signal:before {
+ content: "\e018";
+}
+.glyphicon-cog:before {
+ content: "\e019";
+}
+.glyphicon-trash:before {
+ content: "\e020";
+}
+.glyphicon-home:before {
+ content: "\e021";
+}
+.glyphicon-file:before {
+ content: "\e022";
+}
+.glyphicon-time:before {
+ content: "\e023";
+}
+.glyphicon-road:before {
+ content: "\e024";
+}
+.glyphicon-download-alt:before {
+ content: "\e025";
+}
+.glyphicon-download:before {
+ content: "\e026";
+}
+.glyphicon-upload:before {
+ content: "\e027";
+}
+.glyphicon-inbox:before {
+ content: "\e028";
+}
+.glyphicon-play-circle:before {
+ content: "\e029";
+}
+.glyphicon-repeat:before {
+ content: "\e030";
+}
+.glyphicon-refresh:before {
+ content: "\e031";
+}
+.glyphicon-list-alt:before {
+ content: "\e032";
+}
+.glyphicon-lock:before {
+ content: "\e033";
+}
+.glyphicon-flag:before {
+ content: "\e034";
+}
+.glyphicon-headphones:before {
+ content: "\e035";
+}
+.glyphicon-volume-off:before {
+ content: "\e036";
+}
+.glyphicon-volume-down:before {
+ content: "\e037";
+}
+.glyphicon-volume-up:before {
+ content: "\e038";
+}
+.glyphicon-qrcode:before {
+ content: "\e039";
+}
+.glyphicon-barcode:before {
+ content: "\e040";
+}
+.glyphicon-tag:before {
+ content: "\e041";
+}
+.glyphicon-tags:before {
+ content: "\e042";
+}
+.glyphicon-book:before {
+ content: "\e043";
+}
+.glyphicon-bookmark:before {
+ content: "\e044";
+}
+.glyphicon-print:before {
+ content: "\e045";
+}
+.glyphicon-camera:before {
+ content: "\e046";
+}
+.glyphicon-font:before {
+ content: "\e047";
+}
+.glyphicon-bold:before {
+ content: "\e048";
+}
+.glyphicon-italic:before {
+ content: "\e049";
+}
+.glyphicon-text-height:before {
+ content: "\e050";
+}
+.glyphicon-text-width:before {
+ content: "\e051";
+}
+.glyphicon-align-left:before {
+ content: "\e052";
+}
+.glyphicon-align-center:before {
+ content: "\e053";
+}
+.glyphicon-align-right:before {
+ content: "\e054";
+}
+.glyphicon-align-justify:before {
+ content: "\e055";
+}
+.glyphicon-list:before {
+ content: "\e056";
+}
+.glyphicon-indent-left:before {
+ content: "\e057";
+}
+.glyphicon-indent-right:before {
+ content: "\e058";
+}
+.glyphicon-facetime-video:before {
+ content: "\e059";
+}
+.glyphicon-picture:before {
+ content: "\e060";
+}
+.glyphicon-map-marker:before {
+ content: "\e062";
+}
+.glyphicon-adjust:before {
+ content: "\e063";
+}
+.glyphicon-tint:before {
+ content: "\e064";
+}
+.glyphicon-edit:before {
+ content: "\e065";
+}
+.glyphicon-share:before {
+ content: "\e066";
+}
+.glyphicon-check:before {
+ content: "\e067";
+}
+.glyphicon-move:before {
+ content: "\e068";
+}
+.glyphicon-step-backward:before {
+ content: "\e069";
+}
+.glyphicon-fast-backward:before {
+ content: "\e070";
+}
+.glyphicon-backward:before {
+ content: "\e071";
+}
+.glyphicon-play:before {
+ content: "\e072";
+}
+.glyphicon-pause:before {
+ content: "\e073";
+}
+.glyphicon-stop:before {
+ content: "\e074";
+}
+.glyphicon-forward:before {
+ content: "\e075";
+}
+.glyphicon-fast-forward:before {
+ content: "\e076";
+}
+.glyphicon-step-forward:before {
+ content: "\e077";
+}
+.glyphicon-eject:before {
+ content: "\e078";
+}
+.glyphicon-chevron-left:before {
+ content: "\e079";
+}
+.glyphicon-chevron-right:before {
+ content: "\e080";
+}
+.glyphicon-plus-sign:before {
+ content: "\e081";
+}
+.glyphicon-minus-sign:before {
+ content: "\e082";
+}
+.glyphicon-remove-sign:before {
+ content: "\e083";
+}
+.glyphicon-ok-sign:before {
+ content: "\e084";
+}
+.glyphicon-question-sign:before {
+ content: "\e085";
+}
+.glyphicon-info-sign:before {
+ content: "\e086";
+}
+.glyphicon-screenshot:before {
+ content: "\e087";
+}
+.glyphicon-remove-circle:before {
+ content: "\e088";
+}
+.glyphicon-ok-circle:before {
+ content: "\e089";
+}
+.glyphicon-ban-circle:before {
+ content: "\e090";
+}
+.glyphicon-arrow-left:before {
+ content: "\e091";
+}
+.glyphicon-arrow-right:before {
+ content: "\e092";
+}
+.glyphicon-arrow-up:before {
+ content: "\e093";
+}
+.glyphicon-arrow-down:before {
+ content: "\e094";
+}
+.glyphicon-share-alt:before {
+ content: "\e095";
+}
+.glyphicon-resize-full:before {
+ content: "\e096";
+}
+.glyphicon-resize-small:before {
+ content: "\e097";
+}
+.glyphicon-exclamation-sign:before {
+ content: "\e101";
+}
+.glyphicon-gift:before {
+ content: "\e102";
+}
+.glyphicon-leaf:before {
+ content: "\e103";
+}
+.glyphicon-fire:before {
+ content: "\e104";
+}
+.glyphicon-eye-open:before {
+ content: "\e105";
+}
+.glyphicon-eye-close:before {
+ content: "\e106";
+}
+.glyphicon-warning-sign:before {
+ content: "\e107";
+}
+.glyphicon-plane:before {
+ content: "\e108";
+}
+.glyphicon-calendar:before {
+ content: "\e109";
+}
+.glyphicon-random:before {
+ content: "\e110";
+}
+.glyphicon-comment:before {
+ content: "\e111";
+}
+.glyphicon-magnet:before {
+ content: "\e112";
+}
+.glyphicon-chevron-up:before {
+ content: "\e113";
+}
+.glyphicon-chevron-down:before {
+ content: "\e114";
+}
+.glyphicon-retweet:before {
+ content: "\e115";
+}
+.glyphicon-shopping-cart:before {
+ content: "\e116";
+}
+.glyphicon-folder-close:before {
+ content: "\e117";
+}
+.glyphicon-folder-open:before {
+ content: "\e118";
+}
+.glyphicon-resize-vertical:before {
+ content: "\e119";
+}
+.glyphicon-resize-horizontal:before {
+ content: "\e120";
+}
+.glyphicon-hdd:before {
+ content: "\e121";
+}
+.glyphicon-bullhorn:before {
+ content: "\e122";
+}
+.glyphicon-bell:before {
+ content: "\e123";
+}
+.glyphicon-certificate:before {
+ content: "\e124";
+}
+.glyphicon-thumbs-up:before {
+ content: "\e125";
+}
+.glyphicon-thumbs-down:before {
+ content: "\e126";
+}
+.glyphicon-hand-right:before {
+ content: "\e127";
+}
+.glyphicon-hand-left:before {
+ content: "\e128";
+}
+.glyphicon-hand-up:before {
+ content: "\e129";
+}
+.glyphicon-hand-down:before {
+ content: "\e130";
+}
+.glyphicon-circle-arrow-right:before {
+ content: "\e131";
+}
+.glyphicon-circle-arrow-left:before {
+ content: "\e132";
+}
+.glyphicon-circle-arrow-up:before {
+ content: "\e133";
+}
+.glyphicon-circle-arrow-down:before {
+ content: "\e134";
+}
+.glyphicon-globe:before {
+ content: "\e135";
+}
+.glyphicon-wrench:before {
+ content: "\e136";
+}
+.glyphicon-tasks:before {
+ content: "\e137";
+}
+.glyphicon-filter:before {
+ content: "\e138";
+}
+.glyphicon-briefcase:before {
+ content: "\e139";
+}
+.glyphicon-fullscreen:before {
+ content: "\e140";
+}
+.glyphicon-dashboard:before {
+ content: "\e141";
+}
+.glyphicon-paperclip:before {
+ content: "\e142";
+}
+.glyphicon-heart-empty:before {
+ content: "\e143";
+}
+.glyphicon-link:before {
+ content: "\e144";
+}
+.glyphicon-phone:before {
+ content: "\e145";
+}
+.glyphicon-pushpin:before {
+ content: "\e146";
+}
+.glyphicon-usd:before {
+ content: "\e148";
+}
+.glyphicon-gbp:before {
+ content: "\e149";
+}
+.glyphicon-sort:before {
+ content: "\e150";
+}
+.glyphicon-sort-by-alphabet:before {
+ content: "\e151";
+}
+.glyphicon-sort-by-alphabet-alt:before {
+ content: "\e152";
+}
+.glyphicon-sort-by-order:before {
+ content: "\e153";
+}
+.glyphicon-sort-by-order-alt:before {
+ content: "\e154";
+}
+.glyphicon-sort-by-attributes:before {
+ content: "\e155";
+}
+.glyphicon-sort-by-attributes-alt:before {
+ content: "\e156";
+}
+.glyphicon-unchecked:before {
+ content: "\e157";
+}
+.glyphicon-expand:before {
+ content: "\e158";
+}
+.glyphicon-collapse-down:before {
+ content: "\e159";
+}
+.glyphicon-collapse-up:before {
+ content: "\e160";
+}
+.glyphicon-log-in:before {
+ content: "\e161";
+}
+.glyphicon-flash:before {
+ content: "\e162";
+}
+.glyphicon-log-out:before {
+ content: "\e163";
+}
+.glyphicon-new-window:before {
+ content: "\e164";
+}
+.glyphicon-record:before {
+ content: "\e165";
+}
+.glyphicon-save:before {
+ content: "\e166";
+}
+.glyphicon-open:before {
+ content: "\e167";
+}
+.glyphicon-saved:before {
+ content: "\e168";
+}
+.glyphicon-import:before {
+ content: "\e169";
+}
+.glyphicon-export:before {
+ content: "\e170";
+}
+.glyphicon-send:before {
+ content: "\e171";
+}
+.glyphicon-floppy-disk:before {
+ content: "\e172";
+}
+.glyphicon-floppy-saved:before {
+ content: "\e173";
+}
+.glyphicon-floppy-remove:before {
+ content: "\e174";
+}
+.glyphicon-floppy-save:before {
+ content: "\e175";
+}
+.glyphicon-floppy-open:before {
+ content: "\e176";
+}
+.glyphicon-credit-card:before {
+ content: "\e177";
+}
+.glyphicon-transfer:before {
+ content: "\e178";
+}
+.glyphicon-cutlery:before {
+ content: "\e179";
+}
+.glyphicon-header:before {
+ content: "\e180";
+}
+.glyphicon-compressed:before {
+ content: "\e181";
+}
+.glyphicon-earphone:before {
+ content: "\e182";
+}
+.glyphicon-phone-alt:before {
+ content: "\e183";
+}
+.glyphicon-tower:before {
+ content: "\e184";
+}
+.glyphicon-stats:before {
+ content: "\e185";
+}
+.glyphicon-sd-video:before {
+ content: "\e186";
+}
+.glyphicon-hd-video:before {
+ content: "\e187";
+}
+.glyphicon-subtitles:before {
+ content: "\e188";
+}
+.glyphicon-sound-stereo:before {
+ content: "\e189";
+}
+.glyphicon-sound-dolby:before {
+ content: "\e190";
+}
+.glyphicon-sound-5-1:before {
+ content: "\e191";
+}
+.glyphicon-sound-6-1:before {
+ content: "\e192";
+}
+.glyphicon-sound-7-1:before {
+ content: "\e193";
+}
+.glyphicon-copyright-mark:before {
+ content: "\e194";
+}
+.glyphicon-registration-mark:before {
+ content: "\e195";
+}
+.glyphicon-cloud-download:before {
+ content: "\e197";
+}
+.glyphicon-cloud-upload:before {
+ content: "\e198";
+}
+.glyphicon-tree-conifer:before {
+ content: "\e199";
+}
+.glyphicon-tree-deciduous:before {
+ content: "\e200";
+}
+.caret {
+ display: inline-block;
+ width: 0;
+ height: 0;
+ margin-left: 2px;
+ vertical-align: middle;
+ border-top: 4px solid;
+ border-right: 4px solid transparent;
+ border-left: 4px solid transparent;
+}
+.dropdown {
+ position: relative;
+}
+.dropdown-toggle:focus {
+ outline: 0;
+}
+.dropdown-menu {
+ position: absolute;
+ top: 100%;
+ left: 0;
+ z-index: 1000;
+ display: none;
+ float: left;
+ min-width: 160px;
+ padding: 5px 0;
+ margin: 2px 0 0;
+ font-size: 14px;
+ list-style: none;
+ background-color: #fff;
+ background-clip: padding-box;
+ border: 1px solid #ccc;
+ border: 1px solid rgba(0, 0, 0, .15);
+ border-radius: 4px;
+ -webkit-box-shadow: 0 6px 12px rgba(0, 0, 0, .175);
+ box-shadow: 0 6px 12px rgba(0, 0, 0, .175);
+}
+.dropdown-menu.pull-right {
+ right: 0;
+ left: auto;
+}
+.dropdown-menu .divider {
+ height: 1px;
+ margin: 9px 0;
+ overflow: hidden;
+ background-color: #e5e5e5;
+}
+.dropdown-menu > li > a {
+ display: block;
+ padding: 3px 20px;
+ clear: both;
+ font-weight: normal;
+ line-height: 1.42857143;
+ color: #333;
+ white-space: nowrap;
+}
+.dropdown-menu > li > a:hover,
+.dropdown-menu > li > a:focus {
+ color: #262626;
+ text-decoration: none;
+ background-color: #f5f5f5;
+}
+.dropdown-menu > .active > a,
+.dropdown-menu > .active > a:hover,
+.dropdown-menu > .active > a:focus {
+ color: #fff;
+ text-decoration: none;
+ background-color: #428bca;
+ outline: 0;
+}
+.dropdown-menu > .disabled > a,
+.dropdown-menu > .disabled > a:hover,
+.dropdown-menu > .disabled > a:focus {
+ color: #999;
+}
+.dropdown-menu > .disabled > a:hover,
+.dropdown-menu > .disabled > a:focus {
+ text-decoration: none;
+ cursor: not-allowed;
+ background-color: transparent;
+ background-image: none;
+ filter: progid:DXImageTransform.Microsoft.gradient(enabled = false);
+}
+.open > .dropdown-menu {
+ display: block;
+}
+.open > a {
+ outline: 0;
+}
+.dropdown-menu-right {
+ right: 0;
+ left: auto;
+}
+.dropdown-menu-left {
+ right: auto;
+ left: 0;
+}
+.dropdown-header {
+ display: block;
+ padding: 3px 20px;
+ font-size: 12px;
+ line-height: 1.42857143;
+ color: #999;
+}
+.dropdown-backdrop {
+ position: fixed;
+ top: 0;
+ right: 0;
+ bottom: 0;
+ left: 0;
+ z-index: 990;
+}
+.pull-right > .dropdown-menu {
+ right: 0;
+ left: auto;
+}
+.dropup .caret,
+.navbar-fixed-bottom .dropdown .caret {
+ content: "";
+ border-top: 0;
+ border-bottom: 4px solid;
+}
+.dropup .dropdown-menu,
+.navbar-fixed-bottom .dropdown .dropdown-menu {
+ top: auto;
+ bottom: 100%;
+ margin-bottom: 1px;
+}
+@media (min-width: 768px) {
+ .navbar-right .dropdown-menu {
+ right: 0;
+ left: auto;
+ }
+ .navbar-right .dropdown-menu-left {
+ right: auto;
+ left: 0;
+ }
+}
+.btn-group,
+.btn-group-vertical {
+ position: relative;
+ display: inline-block;
+ vertical-align: middle;
+}
+.btn-group > .btn,
+.btn-group-vertical > .btn {
+ position: relative;
+ float: left;
+}
+.btn-group > .btn:hover,
+.btn-group-vertical > .btn:hover,
+.btn-group > .btn:focus,
+.btn-group-vertical > .btn:focus,
+.btn-group > .btn:active,
+.btn-group-vertical > .btn:active,
+.btn-group > .btn.active,
+.btn-group-vertical > .btn.active {
+ z-index: 2;
+}
+.btn-group > .btn:focus,
+.btn-group-vertical > .btn:focus {
+ outline: none;
+}
+.btn-group .btn + .btn,
+.btn-group .btn + .btn-group,
+.btn-group .btn-group + .btn,
+.btn-group .btn-group + .btn-group {
+ margin-left: -1px;
+}
+.btn-toolbar {
+ margin-left: -5px;
+}
+.btn-toolbar .btn-group,
+.btn-toolbar .input-group {
+ float: left;
+}
+.btn-toolbar > .btn,
+.btn-toolbar > .btn-group,
+.btn-toolbar > .input-group {
+ margin-left: 5px;
+}
+.btn-group > .btn:not(:first-child):not(:last-child):not(.dropdown-toggle) {
+ border-radius: 0;
+}
+.btn-group > .btn:first-child {
+ margin-left: 0;
+}
+.btn-group > .btn:first-child:not(:last-child):not(.dropdown-toggle) {
+ border-top-right-radius: 0;
+ border-bottom-right-radius: 0;
+}
+.btn-group > .btn:last-child:not(:first-child),
+.btn-group > .dropdown-toggle:not(:first-child) {
+ border-top-left-radius: 0;
+ border-bottom-left-radius: 0;
+}
+.btn-group > .btn-group {
+ float: left;
+}
+.btn-group > .btn-group:not(:first-child):not(:last-child) > .btn {
+ border-radius: 0;
+}
+.btn-group > .btn-group:first-child > .btn:last-child,
+.btn-group > .btn-group:first-child > .dropdown-toggle {
+ border-top-right-radius: 0;
+ border-bottom-right-radius: 0;
+}
+.btn-group > .btn-group:last-child > .btn:first-child {
+ border-top-left-radius: 0;
+ border-bottom-left-radius: 0;
+}
+.btn-group .dropdown-toggle:active,
+.btn-group.open .dropdown-toggle {
+ outline: 0;
+}
+.btn-group > .btn + .dropdown-toggle {
+ padding-right: 8px;
+ padding-left: 8px;
+}
+.btn-group > .btn-lg + .dropdown-toggle {
+ padding-right: 12px;
+ padding-left: 12px;
+}
+.btn-group.open .dropdown-toggle {
+ -webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, .125);
+ box-shadow: inset 0 3px 5px rgba(0, 0, 0, .125);
+}
+.btn-group.open .dropdown-toggle.btn-link {
+ -webkit-box-shadow: none;
+ box-shadow: none;
+}
+.btn .caret {
+ margin-left: 0;
+}
+.btn-lg .caret {
+ border-width: 5px 5px 0;
+ border-bottom-width: 0;
+}
+.dropup .btn-lg .caret {
+ border-width: 0 5px 5px;
+}
+.btn-group-vertical > .btn,
+.btn-group-vertical > .btn-group,
+.btn-group-vertical > .btn-group > .btn {
+ display: block;
+ float: none;
+ width: 100%;
+ max-width: 100%;
+}
+.btn-group-vertical > .btn-group > .btn {
+ float: none;
+}
+.btn-group-vertical > .btn + .btn,
+.btn-group-vertical > .btn + .btn-group,
+.btn-group-vertical > .btn-group + .btn,
+.btn-group-vertical > .btn-group + .btn-group {
+ margin-top: -1px;
+ margin-left: 0;
+}
+.btn-group-vertical > .btn:not(:first-child):not(:last-child) {
+ border-radius: 0;
+}
+.btn-group-vertical > .btn:first-child:not(:last-child) {
+ border-top-right-radius: 4px;
+ border-bottom-right-radius: 0;
+ border-bottom-left-radius: 0;
+}
+.btn-group-vertical > .btn:last-child:not(:first-child) {
+ border-top-left-radius: 0;
+ border-top-right-radius: 0;
+ border-bottom-left-radius: 4px;
+}
+.btn-group-vertical > .btn-group:not(:first-child):not(:last-child) > .btn {
+ border-radius: 0;
+}
+.btn-group-vertical > .btn-group:first-child:not(:last-child) > .btn:last-child,
+.btn-group-vertical > .btn-group:first-child:not(:last-child) > .dropdown-toggle {
+ border-bottom-right-radius: 0;
+ border-bottom-left-radius: 0;
+}
+.btn-group-vertical > .btn-group:last-child:not(:first-child) > .btn:first-child {
+ border-top-left-radius: 0;
+ border-top-right-radius: 0;
+}
+.btn-group-justified {
+ display: table;
+ width: 100%;
+ table-layout: fixed;
+ border-collapse: separate;
+}
+.btn-group-justified > .btn,
+.btn-group-justified > .btn-group {
+ display: table-cell;
+ float: none;
+ width: 1%;
+}
+.btn-group-justified > .btn-group .btn {
+ width: 100%;
+}
+[data-toggle="buttons"] > .btn > input[type="radio"],
+[data-toggle="buttons"] > .btn > input[type="checkbox"] {
+ display: none;
+}
+.input-group {
+ position: relative;
+ display: table;
+ border-collapse: separate;
+}
+.input-group[class*="col-"] {
+ float: none;
+ padding-right: 0;
+ padding-left: 0;
+}
+.input-group .form-control {
+ position: relative;
+ z-index: 2;
+ float: left;
+ width: 100%;
+ margin-bottom: 0;
+}
+.input-group-lg > .form-control,
+.input-group-lg > .input-group-addon,
+.input-group-lg > .input-group-btn > .btn {
+ height: 46px;
+ padding: 10px 16px;
+ font-size: 18px;
+ line-height: 1.33;
+ border-radius: 6px;
+}
+select.input-group-lg > .form-control,
+select.input-group-lg > .input-group-addon,
+select.input-group-lg > .input-group-btn > .btn {
+ height: 46px;
+ line-height: 46px;
+}
+textarea.input-group-lg > .form-control,
+textarea.input-group-lg > .input-group-addon,
+textarea.input-group-lg > .input-group-btn > .btn,
+select[multiple].input-group-lg > .form-control,
+select[multiple].input-group-lg > .input-group-addon,
+select[multiple].input-group-lg > .input-group-btn > .btn {
+ height: auto;
+}
+.input-group-sm > .form-control,
+.input-group-sm > .input-group-addon,
+.input-group-sm > .input-group-btn > .btn {
+ height: 30px;
+ padding: 5px 10px;
+ font-size: 12px;
+ line-height: 1.5;
+ border-radius: 3px;
+}
+select.input-group-sm > .form-control,
+select.input-group-sm > .input-group-addon,
+select.input-group-sm > .input-group-btn > .btn {
+ height: 30px;
+ line-height: 30px;
+}
+textarea.input-group-sm > .form-control,
+textarea.input-group-sm > .input-group-addon,
+textarea.input-group-sm > .input-group-btn > .btn,
+select[multiple].input-group-sm > .form-control,
+select[multiple].input-group-sm > .input-group-addon,
+select[multiple].input-group-sm > .input-group-btn > .btn {
+ height: auto;
+}
+.input-group-addon,
+.input-group-btn,
+.input-group .form-control {
+ display: table-cell;
+}
+.input-group-addon:not(:first-child):not(:last-child),
+.input-group-btn:not(:first-child):not(:last-child),
+.input-group .form-control:not(:first-child):not(:last-child) {
+ border-radius: 0;
+}
+.input-group-addon,
+.input-group-btn {
+ width: 1%;
+ white-space: nowrap;
+ vertical-align: middle;
+}
+.input-group-addon {
+ padding: 6px 12px;
+ font-size: 14px;
+ font-weight: normal;
+ line-height: 1;
+ color: #555;
+ text-align: center;
+ background-color: #eee;
+ border: 1px solid #ccc;
+ border-radius: 4px;
+}
+.input-group-addon.input-sm {
+ padding: 5px 10px;
+ font-size: 12px;
+ border-radius: 3px;
+}
+.input-group-addon.input-lg {
+ padding: 10px 16px;
+ font-size: 18px;
+ border-radius: 6px;
+}
+.input-group-addon input[type="radio"],
+.input-group-addon input[type="checkbox"] {
+ margin-top: 0;
+}
+.input-group .form-control:first-child,
+.input-group-addon:first-child,
+.input-group-btn:first-child > .btn,
+.input-group-btn:first-child > .btn-group > .btn,
+.input-group-btn:first-child > .dropdown-toggle,
+.input-group-btn:last-child > .btn:not(:last-child):not(.dropdown-toggle),
+.input-group-btn:last-child > .btn-group:not(:last-child) > .btn {
+ border-top-right-radius: 0;
+ border-bottom-right-radius: 0;
+}
+.input-group-addon:first-child {
+ border-right: 0;
+}
+.input-group .form-control:last-child,
+.input-group-addon:last-child,
+.input-group-btn:last-child > .btn,
+.input-group-btn:last-child > .btn-group > .btn,
+.input-group-btn:last-child > .dropdown-toggle,
+.input-group-btn:first-child > .btn:not(:first-child),
+.input-group-btn:first-child > .btn-group:not(:first-child) > .btn {
+ border-top-left-radius: 0;
+ border-bottom-left-radius: 0;
+}
+.input-group-addon:last-child {
+ border-left: 0;
+}
+.input-group-btn {
+ position: relative;
+ font-size: 0;
+ white-space: nowrap;
+}
+.input-group-btn > .btn {
+ position: relative;
+}
+.input-group-btn > .btn + .btn {
+ margin-left: -1px;
+}
+.input-group-btn > .btn:hover,
+.input-group-btn > .btn:focus,
+.input-group-btn > .btn:active {
+ z-index: 2;
+}
+.input-group-btn:first-child > .btn,
+.input-group-btn:first-child > .btn-group {
+ margin-right: -1px;
+}
+.input-group-btn:last-child > .btn,
+.input-group-btn:last-child > .btn-group {
+ margin-left: -1px;
+}
+.nav {
+ padding-left: 0;
+ margin-bottom: 0;
+ list-style: none;
+}
+.nav > li {
+ position: relative;
+ display: block;
+}
+.nav > li > a {
+ position: relative;
+ display: block;
+ padding: 10px 15px;
+}
+.nav > li > a:hover,
+.nav > li > a:focus {
+ text-decoration: none;
+ background-color: #eee;
+}
+.nav > li.disabled > a {
+ color: #999;
+}
+.nav > li.disabled > a:hover,
+.nav > li.disabled > a:focus {
+ color: #999;
+ text-decoration: none;
+ cursor: not-allowed;
+ background-color: transparent;
+}
+.nav .open > a,
+.nav .open > a:hover,
+.nav .open > a:focus {
+ background-color: #eee;
+ border-color: #428bca;
+}
+.nav .nav-divider {
+ height: 1px;
+ margin: 9px 0;
+ overflow: hidden;
+ background-color: #e5e5e5;
+}
+.nav > li > a > img {
+ max-width: none;
+}
+.nav-tabs {
+ border-bottom: 1px solid #ddd;
+}
+.nav-tabs > li {
+ float: left;
+ margin-bottom: -1px;
+}
+.nav-tabs > li > a {
+ margin-right: 2px;
+ line-height: 1.42857143;
+ border: 1px solid transparent;
+ border-radius: 4px 4px 0 0;
+}
+.nav-tabs > li > a:hover {
+ border-color: #eee #eee #ddd;
+}
+.nav-tabs > li.active > a,
+.nav-tabs > li.active > a:hover,
+.nav-tabs > li.active > a:focus {
+ color: #555;
+ cursor: default;
+ background-color: #fff;
+ border: 1px solid #ddd;
+ border-bottom-color: transparent;
+}
+.nav-tabs.nav-justified {
+ width: 100%;
+ border-bottom: 0;
+}
+.nav-tabs.nav-justified > li {
+ float: none;
+}
+.nav-tabs.nav-justified > li > a {
+ margin-bottom: 5px;
+ text-align: center;
+}
+.nav-tabs.nav-justified > .dropdown .dropdown-menu {
+ top: auto;
+ left: auto;
+}
+@media (min-width: 768px) {
+ .nav-tabs.nav-justified > li {
+ display: table-cell;
+ width: 1%;
+ }
+ .nav-tabs.nav-justified > li > a {
+ margin-bottom: 0;
+ }
+}
+.nav-tabs.nav-justified > li > a {
+ margin-right: 0;
+ border-radius: 4px;
+}
+.nav-tabs.nav-justified > .active > a,
+.nav-tabs.nav-justified > .active > a:hover,
+.nav-tabs.nav-justified > .active > a:focus {
+ border: 1px solid #ddd;
+}
+@media (min-width: 768px) {
+ .nav-tabs.nav-justified > li > a {
+ border-bottom: 1px solid #ddd;
+ border-radius: 4px 4px 0 0;
+ }
+ .nav-tabs.nav-justified > .active > a,
+ .nav-tabs.nav-justified > .active > a:hover,
+ .nav-tabs.nav-justified > .active > a:focus {
+ border-bottom-color: #fff;
+ }
+}
+.nav-pills > li {
+ float: left;
+}
+.nav-pills > li > a {
+ border-radius: 4px;
+}
+.nav-pills > li + li {
+ margin-left: 2px;
+}
+.nav-pills > li.active > a,
+.nav-pills > li.active > a:hover,
+.nav-pills > li.active > a:focus {
+ color: #fff;
+ background-color: #428bca;
+}
+.nav-stacked > li {
+ float: none;
+}
+.nav-stacked > li + li {
+ margin-top: 2px;
+ margin-left: 0;
+}
+.nav-justified {
+ width: 100%;
+}
+.nav-justified > li {
+ float: none;
+}
+.nav-justified > li > a {
+ margin-bottom: 5px;
+ text-align: center;
+}
+.nav-justified > .dropdown .dropdown-menu {
+ top: auto;
+ left: auto;
+}
+@media (min-width: 768px) {
+ .nav-justified > li {
+ display: table-cell;
+ width: 1%;
+ }
+ .nav-justified > li > a {
+ margin-bottom: 0;
+ }
+}
+.nav-tabs-justified {
+ border-bottom: 0;
+}
+.nav-tabs-justified > li > a {
+ margin-right: 0;
+ border-radius: 4px;
+}
+.nav-tabs-justified > .active > a,
+.nav-tabs-justified > .active > a:hover,
+.nav-tabs-justified > .active > a:focus {
+ border: 1px solid #ddd;
+}
+@media (min-width: 768px) {
+ .nav-tabs-justified > li > a {
+ border-bottom: 1px solid #ddd;
+ border-radius: 4px 4px 0 0;
+ }
+ .nav-tabs-justified > .active > a,
+ .nav-tabs-justified > .active > a:hover,
+ .nav-tabs-justified > .active > a:focus {
+ border-bottom-color: #fff;
+ }
+}
+.tab-content > .tab-pane {
+ display: none;
+}
+.tab-content > .active {
+ display: block;
+}
+.nav-tabs .dropdown-menu {
+ margin-top: -1px;
+ border-top-left-radius: 0;
+ border-top-right-radius: 0;
+}
+.navbar {
+ position: relative;
+ min-height: 50px;
+ margin-bottom: 20px;
+ border: 1px solid transparent;
+}
+@media (min-width: 768px) {
+ .navbar {
+ border-radius: 4px;
+ }
+}
+@media (min-width: 768px) {
+ .navbar-header {
+ float: left;
+ }
+}
+.navbar-collapse {
+ max-height: 340px;
+ padding-right: 15px;
+ padding-left: 15px;
+ overflow-x: visible;
+ -webkit-overflow-scrolling: touch;
+ border-top: 1px solid transparent;
+ box-shadow: inset 0 1px 0 rgba(255, 255, 255, .1);
+}
+.navbar-collapse.in {
+ overflow-y: auto;
+}
+@media (min-width: 768px) {
+ .navbar-collapse {
+ width: auto;
+ border-top: 0;
+ box-shadow: none;
+ }
+ .navbar-collapse.collapse {
+ display: block !important;
+ height: auto !important;
+ padding-bottom: 0;
+ overflow: visible !important;
+ }
+ .navbar-collapse.in {
+ overflow-y: visible;
+ }
+ .navbar-fixed-top .navbar-collapse,
+ .navbar-static-top .navbar-collapse,
+ .navbar-fixed-bottom .navbar-collapse {
+ padding-right: 0;
+ padding-left: 0;
+ }
+}
+.container > .navbar-header,
+.container-fluid > .navbar-header,
+.container > .navbar-collapse,
+.container-fluid > .navbar-collapse {
+ margin-right: -15px;
+ margin-left: -15px;
+}
+@media (min-width: 768px) {
+ .container > .navbar-header,
+ .container-fluid > .navbar-header,
+ .container > .navbar-collapse,
+ .container-fluid > .navbar-collapse {
+ margin-right: 0;
+ margin-left: 0;
+ }
+}
+.navbar-static-top {
+ z-index: 1000;
+ border-width: 0 0 1px;
+}
+@media (min-width: 768px) {
+ .navbar-static-top {
+ border-radius: 0;
+ }
+}
+.navbar-fixed-top,
+.navbar-fixed-bottom {
+ position: fixed;
+ right: 0;
+ left: 0;
+ z-index: 1030;
+}
+@media (min-width: 768px) {
+ .navbar-fixed-top,
+ .navbar-fixed-bottom {
+ border-radius: 0;
+ }
+}
+.navbar-fixed-top {
+ top: 0;
+ border-width: 0 0 1px;
+}
+.navbar-fixed-bottom {
+ bottom: 0;
+ margin-bottom: 0;
+ border-width: 1px 0 0;
+}
+.navbar-brand {
+ float: left;
+ height: 50px;
+ padding: 15px 15px;
+ font-size: 18px;
+ line-height: 20px;
+}
+.navbar-brand:hover,
+.navbar-brand:focus {
+ text-decoration: none;
+}
+@media (min-width: 768px) {
+ .navbar > .container .navbar-brand,
+ .navbar > .container-fluid .navbar-brand {
+ margin-left: -15px;
+ }
+}
+.navbar-toggle {
+ position: relative;
+ float: right;
+ padding: 9px 10px;
+ margin-top: 8px;
+ margin-right: 15px;
+ margin-bottom: 8px;
+ background-color: transparent;
+ background-image: none;
+ border: 1px solid transparent;
+ border-radius: 4px;
+}
+.navbar-toggle:focus {
+ outline: none;
+}
+.navbar-toggle .icon-bar {
+ display: block;
+ width: 22px;
+ height: 2px;
+ border-radius: 1px;
+}
+.navbar-toggle .icon-bar + .icon-bar {
+ margin-top: 4px;
+}
+@media (min-width: 768px) {
+ .navbar-toggle {
+ display: none;
+ }
+}
+.navbar-nav {
+ margin: 7.5px -15px;
+}
+.navbar-nav > li > a {
+ padding-top: 10px;
+ padding-bottom: 10px;
+ line-height: 20px;
+}
+@media (max-width: 767px) {
+ .navbar-nav .open .dropdown-menu {
+ position: static;
+ float: none;
+ width: auto;
+ margin-top: 0;
+ background-color: transparent;
+ border: 0;
+ box-shadow: none;
+ }
+ .navbar-nav .open .dropdown-menu > li > a,
+ .navbar-nav .open .dropdown-menu .dropdown-header {
+ padding: 5px 15px 5px 25px;
+ }
+ .navbar-nav .open .dropdown-menu > li > a {
+ line-height: 20px;
+ }
+ .navbar-nav .open .dropdown-menu > li > a:hover,
+ .navbar-nav .open .dropdown-menu > li > a:focus {
+ background-image: none;
+ }
+}
+@media (min-width: 768px) {
+ .navbar-nav {
+ float: left;
+ margin: 0;
+ }
+ .navbar-nav > li {
+ float: left;
+ }
+ .navbar-nav > li > a {
+ padding-top: 15px;
+ padding-bottom: 15px;
+ }
+ .navbar-nav.navbar-right:last-child {
+ margin-right: -15px;
+ }
+}
+@media (min-width: 768px) {
+ .navbar-left {
+ float: left !important;
+ }
+ .navbar-right {
+ float: right !important;
+ }
+}
+.navbar-form {
+ padding: 10px 15px;
+ margin-top: 8px;
+ margin-right: -15px;
+ margin-bottom: 8px;
+ margin-left: -15px;
+ border-top: 1px solid transparent;
+ border-bottom: 1px solid transparent;
+ -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, .1), 0 1px 0 rgba(255, 255, 255, .1);
+ box-shadow: inset 0 1px 0 rgba(255, 255, 255, .1), 0 1px 0 rgba(255, 255, 255, .1);
+}
+@media (min-width: 768px) {
+ .navbar-form .form-group {
+ display: inline-block;
+ margin-bottom: 0;
+ vertical-align: middle;
+ }
+ .navbar-form .form-control {
+ display: inline-block;
+ width: auto;
+ vertical-align: middle;
+ }
+ .navbar-form .input-group > .form-control {
+ width: 100%;
+ }
+ .navbar-form .control-label {
+ margin-bottom: 0;
+ vertical-align: middle;
+ }
+ .navbar-form .radio,
+ .navbar-form .checkbox {
+ display: inline-block;
+ padding-left: 0;
+ margin-top: 0;
+ margin-bottom: 0;
+ vertical-align: middle;
+ }
+ .navbar-form .radio input[type="radio"],
+ .navbar-form .checkbox input[type="checkbox"] {
+ float: none;
+ margin-left: 0;
+ }
+ .navbar-form .has-feedback .form-control-feedback {
+ top: 0;
+ }
+}
+@media (max-width: 767px) {
+ .navbar-form .form-group {
+ margin-bottom: 5px;
+ }
+}
+@media (min-width: 768px) {
+ .navbar-form {
+ width: auto;
+ padding-top: 0;
+ padding-bottom: 0;
+ margin-right: 0;
+ margin-left: 0;
+ border: 0;
+ -webkit-box-shadow: none;
+ box-shadow: none;
+ }
+ .navbar-form.navbar-right:last-child {
+ margin-right: -15px;
+ }
+}
+.navbar-nav > li > .dropdown-menu {
+ margin-top: 0;
+ border-top-left-radius: 0;
+ border-top-right-radius: 0;
+}
+.navbar-fixed-bottom .navbar-nav > li > .dropdown-menu {
+ border-bottom-right-radius: 0;
+ border-bottom-left-radius: 0;
+}
+.navbar-btn {
+ margin-top: 8px;
+ margin-bottom: 8px;
+}
+.navbar-btn.btn-sm {
+ margin-top: 10px;
+ margin-bottom: 10px;
+}
+.navbar-btn.btn-xs {
+ margin-top: 14px;
+ margin-bottom: 14px;
+}
+.navbar-text {
+ margin-top: 15px;
+ margin-bottom: 15px;
+}
+@media (min-width: 768px) {
+ .navbar-text {
+ float: left;
+ margin-right: 15px;
+ margin-left: 15px;
+ }
+ .navbar-text.navbar-right:last-child {
+ margin-right: 0;
+ }
+}
+.navbar-default {
+ background-color: #f8f8f8;
+ border-color: #e7e7e7;
+}
+.navbar-default .navbar-brand {
+ color: #777;
+}
+.navbar-default .navbar-brand:hover,
+.navbar-default .navbar-brand:focus {
+ color: #5e5e5e;
+ background-color: transparent;
+}
+.navbar-default .navbar-text {
+ color: #777;
+}
+.navbar-default .navbar-nav > li > a {
+ color: #777;
+}
+.navbar-default .navbar-nav > li > a:hover,
+.navbar-default .navbar-nav > li > a:focus {
+ color: #333;
+ background-color: transparent;
+}
+.navbar-default .navbar-nav > .active > a,
+.navbar-default .navbar-nav > .active > a:hover,
+.navbar-default .navbar-nav > .active > a:focus {
+ color: #555;
+ background-color: #e7e7e7;
+}
+.navbar-default .navbar-nav > .disabled > a,
+.navbar-default .navbar-nav > .disabled > a:hover,
+.navbar-default .navbar-nav > .disabled > a:focus {
+ color: #ccc;
+ background-color: transparent;
+}
+.navbar-default .navbar-toggle {
+ border-color: #ddd;
+}
+.navbar-default .navbar-toggle:hover,
+.navbar-default .navbar-toggle:focus {
+ background-color: #ddd;
+}
+.navbar-default .navbar-toggle .icon-bar {
+ background-color: #888;
+}
+.navbar-default .navbar-collapse,
+.navbar-default .navbar-form {
+ border-color: #e7e7e7;
+}
+.navbar-default .navbar-nav > .open > a,
+.navbar-default .navbar-nav > .open > a:hover,
+.navbar-default .navbar-nav > .open > a:focus {
+ color: #555;
+ background-color: #e7e7e7;
+}
+@media (max-width: 767px) {
+ .navbar-default .navbar-nav .open .dropdown-menu > li > a {
+ color: #777;
+ }
+ .navbar-default .navbar-nav .open .dropdown-menu > li > a:hover,
+ .navbar-default .navbar-nav .open .dropdown-menu > li > a:focus {
+ color: #333;
+ background-color: transparent;
+ }
+ .navbar-default .navbar-nav .open .dropdown-menu > .active > a,
+ .navbar-default .navbar-nav .open .dropdown-menu > .active > a:hover,
+ .navbar-default .navbar-nav .open .dropdown-menu > .active > a:focus {
+ color: #555;
+ background-color: #e7e7e7;
+ }
+ .navbar-default .navbar-nav .open .dropdown-menu > .disabled > a,
+ .navbar-default .navbar-nav .open .dropdown-menu > .disabled > a:hover,
+ .navbar-default .navbar-nav .open .dropdown-menu > .disabled > a:focus {
+ color: #ccc;
+ background-color: transparent;
+ }
+}
+.navbar-default .navbar-link {
+ color: #777;
+}
+.navbar-default .navbar-link:hover {
+ color: #333;
+}
+.navbar-inverse {
+ background-color: #222;
+ border-color: #080808;
+}
+.navbar-inverse .navbar-brand {
+ color: #999;
+}
+.navbar-inverse .navbar-brand:hover,
+.navbar-inverse .navbar-brand:focus {
+ color: #fff;
+ background-color: transparent;
+}
+.navbar-inverse .navbar-text {
+ color: #999;
+}
+.navbar-inverse .navbar-nav > li > a {
+ color: #999;
+}
+.navbar-inverse .navbar-nav > li > a:hover,
+.navbar-inverse .navbar-nav > li > a:focus {
+ color: #fff;
+ background-color: transparent;
+}
+.navbar-inverse .navbar-nav > .active > a,
+.navbar-inverse .navbar-nav > .active > a:hover,
+.navbar-inverse .navbar-nav > .active > a:focus {
+ color: #fff;
+ background-color: #080808;
+}
+.navbar-inverse .navbar-nav > .disabled > a,
+.navbar-inverse .navbar-nav > .disabled > a:hover,
+.navbar-inverse .navbar-nav > .disabled > a:focus {
+ color: #444;
+ background-color: transparent;
+}
+.navbar-inverse .navbar-toggle {
+ border-color: #333;
+}
+.navbar-inverse .navbar-toggle:hover,
+.navbar-inverse .navbar-toggle:focus {
+ background-color: #333;
+}
+.navbar-inverse .navbar-toggle .icon-bar {
+ background-color: #fff;
+}
+.navbar-inverse .navbar-collapse,
+.navbar-inverse .navbar-form {
+ border-color: #101010;
+}
+.navbar-inverse .navbar-nav > .open > a,
+.navbar-inverse .navbar-nav > .open > a:hover,
+.navbar-inverse .navbar-nav > .open > a:focus {
+ color: #fff;
+ background-color: #080808;
+}
+@media (max-width: 767px) {
+ .navbar-inverse .navbar-nav .open .dropdown-menu > .dropdown-header {
+ border-color: #080808;
+ }
+ .navbar-inverse .navbar-nav .open .dropdown-menu .divider {
+ background-color: #080808;
+ }
+ .navbar-inverse .navbar-nav .open .dropdown-menu > li > a {
+ color: #999;
+ }
+ .navbar-inverse .navbar-nav .open .dropdown-menu > li > a:hover,
+ .navbar-inverse .navbar-nav .open .dropdown-menu > li > a:focus {
+ color: #fff;
+ background-color: transparent;
+ }
+ .navbar-inverse .navbar-nav .open .dropdown-menu > .active > a,
+ .navbar-inverse .navbar-nav .open .dropdown-menu > .active > a:hover,
+ .navbar-inverse .navbar-nav .open .dropdown-menu > .active > a:focus {
+ color: #fff;
+ background-color: #080808;
+ }
+ .navbar-inverse .navbar-nav .open .dropdown-menu > .disabled > a,
+ .navbar-inverse .navbar-nav .open .dropdown-menu > .disabled > a:hover,
+ .navbar-inverse .navbar-nav .open .dropdown-menu > .disabled > a:focus {
+ color: #444;
+ background-color: transparent;
+ }
+}
+.navbar-inverse .navbar-link {
+ color: #999;
+}
+.navbar-inverse .navbar-link:hover {
+ color: #fff;
+}
+.breadcrumb {
+ padding: 8px 15px;
+ margin-bottom: 20px;
+ list-style: none;
+ background-color: #f5f5f5;
+ border-radius: 4px;
+}
+.breadcrumb > li {
+ display: inline-block;
+}
+.breadcrumb > li + li:before {
+ padding: 0 5px;
+ color: #ccc;
+ content: "/\00a0";
+}
+.breadcrumb > .active {
+ color: #999;
+}
+.pagination {
+ display: inline-block;
+ padding-left: 0;
+ margin: 20px 0;
+ border-radius: 4px;
+}
+.pagination > li {
+ display: inline;
+}
+.pagination > li > a,
+.pagination > li > span {
+ position: relative;
+ float: left;
+ padding: 6px 12px;
+ margin-left: -1px;
+ line-height: 1.42857143;
+ color: #428bca;
+ text-decoration: none;
+ background-color: #fff;
+ border: 1px solid #ddd;
+}
+.pagination > li:first-child > a,
+.pagination > li:first-child > span {
+ margin-left: 0;
+ border-top-left-radius: 4px;
+ border-bottom-left-radius: 4px;
+}
+.pagination > li:last-child > a,
+.pagination > li:last-child > span {
+ border-top-right-radius: 4px;
+ border-bottom-right-radius: 4px;
+}
+.pagination > li > a:hover,
+.pagination > li > span:hover,
+.pagination > li > a:focus,
+.pagination > li > span:focus {
+ color: #2a6496;
+ background-color: #eee;
+ border-color: #ddd;
+}
+.pagination > .active > a,
+.pagination > .active > span,
+.pagination > .active > a:hover,
+.pagination > .active > span:hover,
+.pagination > .active > a:focus,
+.pagination > .active > span:focus {
+ z-index: 2;
+ color: #fff;
+ cursor: default;
+ background-color: #428bca;
+ border-color: #428bca;
+}
+.pagination > .disabled > span,
+.pagination > .disabled > span:hover,
+.pagination > .disabled > span:focus,
+.pagination > .disabled > a,
+.pagination > .disabled > a:hover,
+.pagination > .disabled > a:focus {
+ color: #999;
+ cursor: not-allowed;
+ background-color: #fff;
+ border-color: #ddd;
+}
+.pagination-lg > li > a,
+.pagination-lg > li > span {
+ padding: 10px 16px;
+ font-size: 18px;
+}
+.pagination-lg > li:first-child > a,
+.pagination-lg > li:first-child > span {
+ border-top-left-radius: 6px;
+ border-bottom-left-radius: 6px;
+}
+.pagination-lg > li:last-child > a,
+.pagination-lg > li:last-child > span {
+ border-top-right-radius: 6px;
+ border-bottom-right-radius: 6px;
+}
+.pagination-sm > li > a,
+.pagination-sm > li > span {
+ padding: 5px 10px;
+ font-size: 12px;
+}
+.pagination-sm > li:first-child > a,
+.pagination-sm > li:first-child > span {
+ border-top-left-radius: 3px;
+ border-bottom-left-radius: 3px;
+}
+.pagination-sm > li:last-child > a,
+.pagination-sm > li:last-child > span {
+ border-top-right-radius: 3px;
+ border-bottom-right-radius: 3px;
+}
+.pager {
+ padding-left: 0;
+ margin: 20px 0;
+ text-align: center;
+ list-style: none;
+}
+.pager li {
+ display: inline;
+}
+.pager li > a,
+.pager li > span {
+ display: inline-block;
+ padding: 5px 14px;
+ background-color: #fff;
+ border: 1px solid #ddd;
+ border-radius: 15px;
+}
+.pager li > a:hover,
+.pager li > a:focus {
+ text-decoration: none;
+ background-color: #eee;
+}
+.pager .next > a,
+.pager .next > span {
+ float: right;
+}
+.pager .previous > a,
+.pager .previous > span {
+ float: left;
+}
+.pager .disabled > a,
+.pager .disabled > a:hover,
+.pager .disabled > a:focus,
+.pager .disabled > span {
+ color: #999;
+ cursor: not-allowed;
+ background-color: #fff;
+}
+.label {
+ display: inline;
+ padding: .2em .6em .3em;
+ font-size: 75%;
+ font-weight: bold;
+ line-height: 1;
+ color: #fff;
+ text-align: center;
+ white-space: nowrap;
+ vertical-align: baseline;
+ border-radius: .25em;
+}
+.label[href]:hover,
+.label[href]:focus {
+ color: #fff;
+ text-decoration: none;
+ cursor: pointer;
+}
+.label:empty {
+ display: none;
+}
+.btn .label {
+ position: relative;
+ top: -1px;
+}
+.label-default {
+ background-color: #999;
+}
+.label-default[href]:hover,
+.label-default[href]:focus {
+ background-color: #808080;
+}
+.label-primary {
+ background-color: #428bca;
+}
+.label-primary[href]:hover,
+.label-primary[href]:focus {
+ background-color: #3071a9;
+}
+.label-success {
+ background-color: #5cb85c;
+}
+.label-success[href]:hover,
+.label-success[href]:focus {
+ background-color: #449d44;
+}
+.label-info {
+ background-color: #5bc0de;
+}
+.label-info[href]:hover,
+.label-info[href]:focus {
+ background-color: #31b0d5;
+}
+.label-warning {
+ background-color: #f0ad4e;
+}
+.label-warning[href]:hover,
+.label-warning[href]:focus {
+ background-color: #ec971f;
+}
+.label-danger {
+ background-color: #d9534f;
+}
+.label-danger[href]:hover,
+.label-danger[href]:focus {
+ background-color: #c9302c;
+}
+.badge {
+ display: inline-block;
+ min-width: 10px;
+ padding: 3px 7px;
+ font-size: 12px;
+ font-weight: bold;
+ line-height: 1;
+ color: #fff;
+ text-align: center;
+ white-space: nowrap;
+ vertical-align: baseline;
+ background-color: #999;
+ border-radius: 10px;
+}
+.badge:empty {
+ display: none;
+}
+.btn .badge {
+ position: relative;
+ top: -1px;
+}
+.btn-xs .badge {
+ top: 0;
+ padding: 1px 5px;
+}
+a.badge:hover,
+a.badge:focus {
+ color: #fff;
+ text-decoration: none;
+ cursor: pointer;
+}
+a.list-group-item.active > .badge,
+.nav-pills > .active > a > .badge {
+ color: #428bca;
+ background-color: #fff;
+}
+.nav-pills > li > a > .badge {
+ margin-left: 3px;
+}
+.jumbotron {
+ padding: 30px;
+ margin-bottom: 30px;
+ color: inherit;
+ background-color: #eee;
+}
+.jumbotron h1,
+.jumbotron .h1 {
+ color: inherit;
+}
+.jumbotron p {
+ margin-bottom: 15px;
+ font-size: 21px;
+ font-weight: 200;
+}
+.container .jumbotron {
+ border-radius: 6px;
+}
+.jumbotron .container {
+ max-width: 100%;
+}
+@media screen and (min-width: 768px) {
+ .jumbotron {
+ padding-top: 48px;
+ padding-bottom: 48px;
+ }
+ .container .jumbotron {
+ padding-right: 60px;
+ padding-left: 60px;
+ }
+ .jumbotron h1,
+ .jumbotron .h1 {
+ font-size: 63px;
+ }
+}
+.thumbnail {
+ display: block;
+ padding: 4px;
+ margin-bottom: 20px;
+ line-height: 1.42857143;
+ background-color: #fff;
+ border: 1px solid #ddd;
+ border-radius: 4px;
+ -webkit-transition: all .2s ease-in-out;
+ transition: all .2s ease-in-out;
+}
+.thumbnail > img,
+.thumbnail a > img {
+ margin-right: auto;
+ margin-left: auto;
+}
+a.thumbnail:hover,
+a.thumbnail:focus,
+a.thumbnail.active {
+ border-color: #428bca;
+}
+.thumbnail .caption {
+ padding: 9px;
+ color: #333;
+}
+.alert {
+ padding: 15px;
+ margin-bottom: 20px;
+ border: 1px solid transparent;
+ border-radius: 4px;
+}
+.alert h4 {
+ margin-top: 0;
+ color: inherit;
+}
+.alert .alert-link {
+ font-weight: bold;
+}
+.alert > p,
+.alert > ul {
+ margin-bottom: 0;
+}
+.alert > p + p {
+ margin-top: 5px;
+}
+.alert-dismissable {
+ padding-right: 35px;
+}
+.alert-dismissable .close {
+ position: relative;
+ top: -2px;
+ right: -21px;
+ color: inherit;
+}
+.alert-success {
+ color: #3c763d;
+ background-color: #dff0d8;
+ border-color: #d6e9c6;
+}
+.alert-success hr {
+ border-top-color: #c9e2b3;
+}
+.alert-success .alert-link {
+ color: #2b542c;
+}
+.alert-info {
+ color: #31708f;
+ background-color: #d9edf7;
+ border-color: #bce8f1;
+}
+.alert-info hr {
+ border-top-color: #a6e1ec;
+}
+.alert-info .alert-link {
+ color: #245269;
+}
+.alert-warning {
+ color: #8a6d3b;
+ background-color: #fcf8e3;
+ border-color: #faebcc;
+}
+.alert-warning hr {
+ border-top-color: #f7e1b5;
+}
+.alert-warning .alert-link {
+ color: #66512c;
+}
+.alert-danger {
+ color: #a94442;
+ background-color: #f2dede;
+ border-color: #ebccd1;
+}
+.alert-danger hr {
+ border-top-color: #e4b9c0;
+}
+.alert-danger .alert-link {
+ color: #843534;
+}
+@-webkit-keyframes progress-bar-stripes {
+ from {
+ background-position: 40px 0;
+ }
+ to {
+ background-position: 0 0;
+ }
+}
+@keyframes progress-bar-stripes {
+ from {
+ background-position: 40px 0;
+ }
+ to {
+ background-position: 0 0;
+ }
+}
+.progress {
+ height: 20px;
+ margin-bottom: 20px;
+ overflow: hidden;
+ background-color: #f5f5f5;
+ border-radius: 4px;
+ -webkit-box-shadow: inset 0 1px 2px rgba(0, 0, 0, .1);
+ box-shadow: inset 0 1px 2px rgba(0, 0, 0, .1);
+}
+.progress-bar {
+ float: left;
+ width: 0;
+ height: 100%;
+ font-size: 12px;
+ line-height: 20px;
+ color: #fff;
+ text-align: center;
+ background-color: #428bca;
+ -webkit-box-shadow: inset 0 -1px 0 rgba(0, 0, 0, .15);
+ box-shadow: inset 0 -1px 0 rgba(0, 0, 0, .15);
+ -webkit-transition: width .6s ease;
+ transition: width .6s ease;
+}
+.progress-striped .progress-bar {
+ background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
+ background-image: linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
+ background-size: 40px 40px;
+}
+.progress.active .progress-bar {
+ -webkit-animation: progress-bar-stripes 2s linear infinite;
+ animation: progress-bar-stripes 2s linear infinite;
+}
+.progress-bar-success {
+ background-color: #5cb85c;
+}
+.progress-striped .progress-bar-success {
+ background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
+ background-image: linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
+}
+.progress-bar-info {
+ background-color: #5bc0de;
+}
+.progress-striped .progress-bar-info {
+ background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
+ background-image: linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
+}
+.progress-bar-warning {
+ background-color: #f0ad4e;
+}
+.progress-striped .progress-bar-warning {
+ background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
+ background-image: linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
+}
+.progress-bar-danger {
+ background-color: #d9534f;
+}
+.progress-striped .progress-bar-danger {
+ background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
+ background-image: linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
+}
+.media,
+.media-body {
+ overflow: hidden;
+ zoom: 1;
+}
+.media,
+.media .media {
+ margin-top: 15px;
+}
+.media:first-child {
+ margin-top: 0;
+}
+.media-object {
+ display: block;
+}
+.media-heading {
+ margin: 0 0 5px;
+}
+.media > .pull-left {
+ margin-right: 10px;
+}
+.media > .pull-right {
+ margin-left: 10px;
+}
+.media-list {
+ padding-left: 0;
+ list-style: none;
+}
+.list-group {
+ padding-left: 0;
+ margin-bottom: 20px;
+}
+.list-group-item {
+ position: relative;
+ display: block;
+ padding: 10px 15px;
+ margin-bottom: -1px;
+ background-color: #fff;
+ border: 1px solid #ddd;
+}
+.list-group-item:first-child {
+ border-top-left-radius: 4px;
+ border-top-right-radius: 4px;
+}
+.list-group-item:last-child {
+ margin-bottom: 0;
+ border-bottom-right-radius: 4px;
+ border-bottom-left-radius: 4px;
+}
+.list-group-item > .badge {
+ float: right;
+}
+.list-group-item > .badge + .badge {
+ margin-right: 5px;
+}
+a.list-group-item {
+ color: #555;
+}
+a.list-group-item .list-group-item-heading {
+ color: #333;
+}
+a.list-group-item:hover,
+a.list-group-item:focus {
+ text-decoration: none;
+ background-color: #f5f5f5;
+}
+a.list-group-item.active,
+a.list-group-item.active:hover,
+a.list-group-item.active:focus {
+ z-index: 2;
+ color: #fff;
+ background-color: #428bca;
+ border-color: #428bca;
+}
+a.list-group-item.active .list-group-item-heading,
+a.list-group-item.active:hover .list-group-item-heading,
+a.list-group-item.active:focus .list-group-item-heading {
+ color: inherit;
+}
+a.list-group-item.active .list-group-item-text,
+a.list-group-item.active:hover .list-group-item-text,
+a.list-group-item.active:focus .list-group-item-text {
+ color: #e1edf7;
+}
+.list-group-item-success {
+ color: #3c763d;
+ background-color: #dff0d8;
+}
+a.list-group-item-success {
+ color: #3c763d;
+}
+a.list-group-item-success .list-group-item-heading {
+ color: inherit;
+}
+a.list-group-item-success:hover,
+a.list-group-item-success:focus {
+ color: #3c763d;
+ background-color: #d0e9c6;
+}
+a.list-group-item-success.active,
+a.list-group-item-success.active:hover,
+a.list-group-item-success.active:focus {
+ color: #fff;
+ background-color: #3c763d;
+ border-color: #3c763d;
+}
+.list-group-item-info {
+ color: #31708f;
+ background-color: #d9edf7;
+}
+a.list-group-item-info {
+ color: #31708f;
+}
+a.list-group-item-info .list-group-item-heading {
+ color: inherit;
+}
+a.list-group-item-info:hover,
+a.list-group-item-info:focus {
+ color: #31708f;
+ background-color: #c4e3f3;
+}
+a.list-group-item-info.active,
+a.list-group-item-info.active:hover,
+a.list-group-item-info.active:focus {
+ color: #fff;
+ background-color: #31708f;
+ border-color: #31708f;
+}
+.list-group-item-warning {
+ color: #8a6d3b;
+ background-color: #fcf8e3;
+}
+a.list-group-item-warning {
+ color: #8a6d3b;
+}
+a.list-group-item-warning .list-group-item-heading {
+ color: inherit;
+}
+a.list-group-item-warning:hover,
+a.list-group-item-warning:focus {
+ color: #8a6d3b;
+ background-color: #faf2cc;
+}
+a.list-group-item-warning.active,
+a.list-group-item-warning.active:hover,
+a.list-group-item-warning.active:focus {
+ color: #fff;
+ background-color: #8a6d3b;
+ border-color: #8a6d3b;
+}
+.list-group-item-danger {
+ color: #a94442;
+ background-color: #f2dede;
+}
+a.list-group-item-danger {
+ color: #a94442;
+}
+a.list-group-item-danger .list-group-item-heading {
+ color: inherit;
+}
+a.list-group-item-danger:hover,
+a.list-group-item-danger:focus {
+ color: #a94442;
+ background-color: #ebcccc;
+}
+a.list-group-item-danger.active,
+a.list-group-item-danger.active:hover,
+a.list-group-item-danger.active:focus {
+ color: #fff;
+ background-color: #a94442;
+ border-color: #a94442;
+}
+.list-group-item-heading {
+ margin-top: 0;
+ margin-bottom: 5px;
+}
+.list-group-item-text {
+ margin-bottom: 0;
+ line-height: 1.3;
+}
+.panel {
+ margin-bottom: 20px;
+ background-color: #fff;
+ border: 1px solid transparent;
+ border-radius: 4px;
+ -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, .05);
+ box-shadow: 0 1px 1px rgba(0, 0, 0, .05);
+}
+.panel-body {
+ padding: 15px;
+}
+.panel-heading {
+ padding: 10px 15px;
+ border-bottom: 1px solid transparent;
+ border-top-left-radius: 3px;
+ border-top-right-radius: 3px;
+}
+.panel-heading > .dropdown .dropdown-toggle {
+ color: inherit;
+}
+.panel-title {
+ margin-top: 0;
+ margin-bottom: 0;
+ font-size: 16px;
+ color: inherit;
+}
+.panel-title > a {
+ color: inherit;
+}
+.panel-footer {
+ padding: 10px 15px;
+ background-color: #f5f5f5;
+ border-top: 1px solid #ddd;
+ border-bottom-right-radius: 3px;
+ border-bottom-left-radius: 3px;
+}
+.panel > .list-group {
+ margin-bottom: 0;
+}
+.panel > .list-group .list-group-item {
+ border-width: 1px 0;
+ border-radius: 0;
+}
+.panel > .list-group:first-child .list-group-item:first-child {
+ border-top: 0;
+ border-top-left-radius: 3px;
+ border-top-right-radius: 3px;
+}
+.panel > .list-group:last-child .list-group-item:last-child {
+ border-bottom: 0;
+ border-bottom-right-radius: 3px;
+ border-bottom-left-radius: 3px;
+}
+.panel-heading + .list-group .list-group-item:first-child {
+ border-top-width: 0;
+}
+.panel > .table,
+.panel > .table-responsive > .table {
+ margin-bottom: 0;
+}
+.panel > .table:first-child,
+.panel > .table-responsive:first-child > .table:first-child {
+ border-top-left-radius: 3px;
+ border-top-right-radius: 3px;
+}
+.panel > .table:first-child > thead:first-child > tr:first-child td:first-child,
+.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child td:first-child,
+.panel > .table:first-child > tbody:first-child > tr:first-child td:first-child,
+.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child td:first-child,
+.panel > .table:first-child > thead:first-child > tr:first-child th:first-child,
+.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child th:first-child,
+.panel > .table:first-child > tbody:first-child > tr:first-child th:first-child,
+.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child th:first-child {
+ border-top-left-radius: 3px;
+}
+.panel > .table:first-child > thead:first-child > tr:first-child td:last-child,
+.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child td:last-child,
+.panel > .table:first-child > tbody:first-child > tr:first-child td:last-child,
+.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child td:last-child,
+.panel > .table:first-child > thead:first-child > tr:first-child th:last-child,
+.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child th:last-child,
+.panel > .table:first-child > tbody:first-child > tr:first-child th:last-child,
+.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child th:last-child {
+ border-top-right-radius: 3px;
+}
+.panel > .table:last-child,
+.panel > .table-responsive:last-child > .table:last-child {
+ border-bottom-right-radius: 3px;
+ border-bottom-left-radius: 3px;
+}
+.panel > .table:last-child > tbody:last-child > tr:last-child td:first-child,
+.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child td:first-child,
+.panel > .table:last-child > tfoot:last-child > tr:last-child td:first-child,
+.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child td:first-child,
+.panel > .table:last-child > tbody:last-child > tr:last-child th:first-child,
+.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child th:first-child,
+.panel > .table:last-child > tfoot:last-child > tr:last-child th:first-child,
+.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child th:first-child {
+ border-bottom-left-radius: 3px;
+}
+.panel > .table:last-child > tbody:last-child > tr:last-child td:last-child,
+.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child td:last-child,
+.panel > .table:last-child > tfoot:last-child > tr:last-child td:last-child,
+.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child td:last-child,
+.panel > .table:last-child > tbody:last-child > tr:last-child th:last-child,
+.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child th:last-child,
+.panel > .table:last-child > tfoot:last-child > tr:last-child th:last-child,
+.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child th:last-child {
+ border-bottom-right-radius: 3px;
+}
+.panel > .panel-body + .table,
+.panel > .panel-body + .table-responsive {
+ border-top: 1px solid #ddd;
+}
+.panel > .table > tbody:first-child > tr:first-child th,
+.panel > .table > tbody:first-child > tr:first-child td {
+ border-top: 0;
+}
+.panel > .table-bordered,
+.panel > .table-responsive > .table-bordered {
+ border: 0;
+}
+.panel > .table-bordered > thead > tr > th:first-child,
+.panel > .table-responsive > .table-bordered > thead > tr > th:first-child,
+.panel > .table-bordered > tbody > tr > th:first-child,
+.panel > .table-responsive > .table-bordered > tbody > tr > th:first-child,
+.panel > .table-bordered > tfoot > tr > th:first-child,
+.panel > .table-responsive > .table-bordered > tfoot > tr > th:first-child,
+.panel > .table-bordered > thead > tr > td:first-child,
+.panel > .table-responsive > .table-bordered > thead > tr > td:first-child,
+.panel > .table-bordered > tbody > tr > td:first-child,
+.panel > .table-responsive > .table-bordered > tbody > tr > td:first-child,
+.panel > .table-bordered > tfoot > tr > td:first-child,
+.panel > .table-responsive > .table-bordered > tfoot > tr > td:first-child {
+ border-left: 0;
+}
+.panel > .table-bordered > thead > tr > th:last-child,
+.panel > .table-responsive > .table-bordered > thead > tr > th:last-child,
+.panel > .table-bordered > tbody > tr > th:last-child,
+.panel > .table-responsive > .table-bordered > tbody > tr > th:last-child,
+.panel > .table-bordered > tfoot > tr > th:last-child,
+.panel > .table-responsive > .table-bordered > tfoot > tr > th:last-child,
+.panel > .table-bordered > thead > tr > td:last-child,
+.panel > .table-responsive > .table-bordered > thead > tr > td:last-child,
+.panel > .table-bordered > tbody > tr > td:last-child,
+.panel > .table-responsive > .table-bordered > tbody > tr > td:last-child,
+.panel > .table-bordered > tfoot > tr > td:last-child,
+.panel > .table-responsive > .table-bordered > tfoot > tr > td:last-child {
+ border-right: 0;
+}
+.panel > .table-bordered > thead > tr:first-child > td,
+.panel > .table-responsive > .table-bordered > thead > tr:first-child > td,
+.panel > .table-bordered > tbody > tr:first-child > td,
+.panel > .table-responsive > .table-bordered > tbody > tr:first-child > td,
+.panel > .table-bordered > thead > tr:first-child > th,
+.panel > .table-responsive > .table-bordered > thead > tr:first-child > th,
+.panel > .table-bordered > tbody > tr:first-child > th,
+.panel > .table-responsive > .table-bordered > tbody > tr:first-child > th {
+ border-bottom: 0;
+}
+.panel > .table-bordered > tbody > tr:last-child > td,
+.panel > .table-responsive > .table-bordered > tbody > tr:last-child > td,
+.panel > .table-bordered > tfoot > tr:last-child > td,
+.panel > .table-responsive > .table-bordered > tfoot > tr:last-child > td,
+.panel > .table-bordered > tbody > tr:last-child > th,
+.panel > .table-responsive > .table-bordered > tbody > tr:last-child > th,
+.panel > .table-bordered > tfoot > tr:last-child > th,
+.panel > .table-responsive > .table-bordered > tfoot > tr:last-child > th {
+ border-bottom: 0;
+}
+.panel > .table-responsive {
+ margin-bottom: 0;
+ border: 0;
+}
+.panel-group {
+ margin-bottom: 20px;
+}
+.panel-group .panel {
+ margin-bottom: 0;
+ overflow: hidden;
+ border-radius: 4px;
+}
+.panel-group .panel + .panel {
+ margin-top: 5px;
+}
+.panel-group .panel-heading {
+ border-bottom: 0;
+}
+.panel-group .panel-heading + .panel-collapse .panel-body {
+ border-top: 1px solid #ddd;
+}
+.panel-group .panel-footer {
+ border-top: 0;
+}
+.panel-group .panel-footer + .panel-collapse .panel-body {
+ border-bottom: 1px solid #ddd;
+}
+.panel-default {
+ border-color: #ddd;
+}
+.panel-default > .panel-heading {
+ color: #333;
+ background-color: #f5f5f5;
+ border-color: #ddd;
+}
+.panel-default > .panel-heading + .panel-collapse .panel-body {
+ border-top-color: #ddd;
+}
+.panel-default > .panel-footer + .panel-collapse .panel-body {
+ border-bottom-color: #ddd;
+}
+.panel-primary {
+ border-color: #428bca;
+}
+.panel-primary > .panel-heading {
+ color: #fff;
+ background-color: #428bca;
+ border-color: #428bca;
+}
+.panel-primary > .panel-heading + .panel-collapse .panel-body {
+ border-top-color: #428bca;
+}
+.panel-primary > .panel-footer + .panel-collapse .panel-body {
+ border-bottom-color: #428bca;
+}
+.panel-success {
+ border-color: #d6e9c6;
+}
+.panel-success > .panel-heading {
+ color: #3c763d;
+ background-color: #dff0d8;
+ border-color: #d6e9c6;
+}
+.panel-success > .panel-heading + .panel-collapse .panel-body {
+ border-top-color: #d6e9c6;
+}
+.panel-success > .panel-footer + .panel-collapse .panel-body {
+ border-bottom-color: #d6e9c6;
+}
+.panel-info {
+ border-color: #bce8f1;
+}
+.panel-info > .panel-heading {
+ color: #31708f;
+ background-color: #d9edf7;
+ border-color: #bce8f1;
+}
+.panel-info > .panel-heading + .panel-collapse .panel-body {
+ border-top-color: #bce8f1;
+}
+.panel-info > .panel-footer + .panel-collapse .panel-body {
+ border-bottom-color: #bce8f1;
+}
+.panel-warning {
+ border-color: #faebcc;
+}
+.panel-warning > .panel-heading {
+ color: #8a6d3b;
+ background-color: #fcf8e3;
+ border-color: #faebcc;
+}
+.panel-warning > .panel-heading + .panel-collapse .panel-body {
+ border-top-color: #faebcc;
+}
+.panel-warning > .panel-footer + .panel-collapse .panel-body {
+ border-bottom-color: #faebcc;
+}
+.panel-danger {
+ border-color: #ebccd1;
+}
+.panel-danger > .panel-heading {
+ color: #a94442;
+ background-color: #f2dede;
+ border-color: #ebccd1;
+}
+.panel-danger > .panel-heading + .panel-collapse .panel-body {
+ border-top-color: #ebccd1;
+}
+.panel-danger > .panel-footer + .panel-collapse .panel-body {
+ border-bottom-color: #ebccd1;
+}
+.well {
+ min-height: 20px;
+ padding: 19px;
+ margin-bottom: 20px;
+ background-color: #f5f5f5;
+ border: 1px solid #e3e3e3;
+ border-radius: 4px;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .05);
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, .05);
+}
+.well blockquote {
+ border-color: #ddd;
+ border-color: rgba(0, 0, 0, .15);
+}
+.well-lg {
+ padding: 24px;
+ border-radius: 6px;
+}
+.well-sm {
+ padding: 9px;
+ border-radius: 3px;
+}
+.close {
+ float: right;
+ font-size: 21px;
+ font-weight: bold;
+ line-height: 1;
+ color: #000;
+ text-shadow: 0 1px 0 #fff;
+ filter: alpha(opacity=20);
+ opacity: .2;
+}
+.close:hover,
+.close:focus {
+ color: #000;
+ text-decoration: none;
+ cursor: pointer;
+ filter: alpha(opacity=50);
+ opacity: .5;
+}
+button.close {
+ -webkit-appearance: none;
+ padding: 0;
+ cursor: pointer;
+ background: transparent;
+ border: 0;
+}
+.modal-open {
+ overflow: hidden;
+}
+.modal {
+ position: fixed;
+ top: 0;
+ right: 0;
+ bottom: 0;
+ left: 0;
+ z-index: 1050;
+ display: none;
+ overflow: auto;
+ overflow-y: scroll;
+ -webkit-overflow-scrolling: touch;
+ outline: 0;
+}
+.modal.fade .modal-dialog {
+ -webkit-transition: -webkit-transform .3s ease-out;
+ -moz-transition: -moz-transform .3s ease-out;
+ -o-transition: -o-transform .3s ease-out;
+ transition: transform .3s ease-out;
+ -webkit-transform: translate(0, -25%);
+ -ms-transform: translate(0, -25%);
+ transform: translate(0, -25%);
+}
+.modal.in .modal-dialog {
+ -webkit-transform: translate(0, 0);
+ -ms-transform: translate(0, 0);
+ transform: translate(0, 0);
+}
+.modal-dialog {
+ position: relative;
+ width: auto;
+ margin: 10px;
+}
+.modal-content {
+ position: relative;
+ background-color: #fff;
+ background-clip: padding-box;
+ border: 1px solid #fff;
+ border: 1px solid rgba(0, 0, 0, .2);
+ border-radius: 0px;
+ outline: none;
+
+}
+.modal-backdrop {
+ position: fixed;
+ top: 0;
+ right: 0;
+ bottom: 0;
+ left: 0;
+ z-index: 1040;
+ background-color: #000;
+}
+.modal-backdrop.fade {
+ filter: alpha(opacity=0);
+ opacity: 0;
+}
+.modal-backdrop.in {
+ filter: alpha(opacity=50);
+ opacity: .5;
+}
+.modal-header {
+ min-height: 16.42857143px;
+ padding: 15px;
+ border-bottom: 1px solid #e5e5e5;
+}
+.modal-header .close {
+ margin-top: -2px;
+}
+.modal-title {
+ margin: 0;
+ line-height: 1.42857143;
+}
+.modal-body {
+ position: relative;
+ padding: 20px;
+}
+.modal-footer {
+ padding: 19px 20px 20px;
+ margin-top: 15px;
+ text-align: right;
+ border-top: 1px solid #e5e5e5;
+}
+.modal-footer .btn + .btn {
+ margin-bottom: 0;
+ margin-left: 5px;
+}
+.modal-footer .btn-group .btn + .btn {
+ margin-left: -1px;
+}
+.modal-footer .btn-block + .btn-block {
+ margin-left: 0;
+}
+@media (min-width: 768px) {
+ .modal-dialog {
+ width: 600px;
+ margin: 30px auto;
+ }
+ .modal-content {
+/*
+ -webkit-box-shadow: 0 5px 15px rgba(0, 0, 0, .5);
+ box-shadow: 0 5px 15px rgba(0, 0, 0, .5);
+*/
+ }
+ .modal-sm {
+ width: 300px;
+ }
+}
+@media (min-width: 992px) {
+ .modal-lg {
+ width: 900px;
+ }
+}
+.tooltip {
+ position: absolute;
+ z-index: 1030;
+ display: block;
+ font-size: 12px;
+ line-height: 1.4;
+ visibility: visible;
+ filter: alpha(opacity=0);
+ opacity: 0;
+}
+.tooltip.in {
+ filter: alpha(opacity=90);
+ opacity: 1;
+}
+.tooltip.top {
+ padding: 5px 0;
+ margin-top: -3px;
+}
+.tooltip.right {
+ padding: 0 5px;
+ margin-left: 3px;
+}
+.tooltip.bottom {
+ padding: 5px 0;
+ margin-top: 3px;
+}
+.tooltip.left {
+ padding: 0 5px;
+ margin-left: -3px;
+}
+.tooltip-inner {
+ max-width: 200px;
+ padding: 3px 8px;
+ color: #fff;
+ text-align: center;
+ text-decoration: none;
+ background-color: #454545;
+ border-radius: 4px;
+}
+/*
+.tooltip-arrow {
+ position: absolute;
+ width: 0;
+ height: 0;
+ border-color: transparent;
+ border-style: solid;
+}
+.tooltip.top .tooltip-arrow {
+ bottom: 0;
+ left: 50%;
+ margin-left: -5px;
+ border-width: 5px 5px 0;
+ border-top-color: #000;
+}
+.tooltip.top-left .tooltip-arrow {
+ bottom: 0;
+ left: 5px;
+ border-width: 5px 5px 0;
+ border-top-color: #000;
+}
+.tooltip.top-right .tooltip-arrow {
+ right: 5px;
+ bottom: 0;
+ border-width: 5px 5px 0;
+ border-top-color: #000;
+}
+.tooltip.right .tooltip-arrow {
+ top: 50%;
+ left: 0;
+ margin-top: -5px;
+ border-width: 5px 5px 5px 0;
+ border-right-color: #000;
+}
+.tooltip.left .tooltip-arrow {
+ top: 50%;
+ right: 0;
+ margin-top: -5px;
+ border-width: 5px 0 5px 5px;
+ border-left-color: #000;
+}
+.tooltip.bottom .tooltip-arrow {
+ top: 0;
+ left: 50%;
+ margin-left: -5px;
+ border-width: 0 5px 5px;
+ border-bottom-color: #000;
+}
+.tooltip.bottom-left .tooltip-arrow {
+ top: 0;
+ left: 5px;
+ border-width: 0 5px 5px;
+ border-bottom-color: #000;
+}
+.tooltip.bottom-right .tooltip-arrow {
+ top: 0;
+ right: 5px;
+ border-width: 0 5px 5px;
+ border-bottom-color: #000;
+}
+*/
+.popover {
+ position: absolute;
+ top: 0;
+ left: 0;
+ z-index: 1010;
+ display: none;
+ max-width: 276px;
+ padding: 1px;
+ text-align: left;
+ white-space: normal;
+ background-color: #fff;
+ background-clip: padding-box;
+ border: 1px solid #ccc;
+ border: 1px solid rgba(0, 0, 0, .2);
+ border-radius: 6px;
+ -webkit-box-shadow: 0 5px 10px rgba(0, 0, 0, .2);
+ box-shadow: 0 5px 10px rgba(0, 0, 0, .2);
+}
+.popover.top {
+ margin-top: -10px;
+}
+.popover.right {
+ margin-left: 10px;
+}
+.popover.bottom {
+ margin-top: 10px;
+}
+.popover.left {
+ margin-left: -10px;
+}
+.popover-title {
+ padding: 8px 14px;
+ margin: 0;
+ font-size: 14px;
+ font-weight: normal;
+ line-height: 18px;
+ background-color: #f7f7f7;
+ border-bottom: 1px solid #ebebeb;
+ border-radius: 5px 5px 0 0;
+}
+.popover-content {
+ padding: 9px 14px;
+}
+.popover > .arrow,
+.popover > .arrow:after {
+ position: absolute;
+ display: block;
+ width: 0;
+ height: 0;
+ border-color: transparent;
+ border-style: solid;
+}
+.popover > .arrow {
+ border-width: 11px;
+}
+.popover > .arrow:after {
+ content: "";
+ border-width: 10px;
+}
+.popover.top > .arrow {
+ bottom: -11px;
+ left: 50%;
+ margin-left: -11px;
+ border-top-color: #999;
+ border-top-color: rgba(0, 0, 0, .25);
+ border-bottom-width: 0;
+}
+.popover.top > .arrow:after {
+ bottom: 1px;
+ margin-left: -10px;
+ content: " ";
+ border-top-color: #fff;
+ border-bottom-width: 0;
+}
+.popover.right > .arrow {
+ top: 50%;
+ left: -11px;
+ margin-top: -11px;
+ border-right-color: #999;
+ border-right-color: rgba(0, 0, 0, .25);
+ border-left-width: 0;
+}
+.popover.right > .arrow:after {
+ bottom: -10px;
+ left: 1px;
+ content: " ";
+ border-right-color: #fff;
+ border-left-width: 0;
+}
+.popover.bottom > .arrow {
+ top: -11px;
+ left: 50%;
+ margin-left: -11px;
+ border-top-width: 0;
+ border-bottom-color: #999;
+ border-bottom-color: rgba(0, 0, 0, .25);
+}
+.popover.bottom > .arrow:after {
+ top: 1px;
+ margin-left: -10px;
+ content: " ";
+ border-top-width: 0;
+ border-bottom-color: #fff;
+}
+.popover.left > .arrow {
+ top: 50%;
+ right: -11px;
+ margin-top: -11px;
+ border-right-width: 0;
+ border-left-color: #999;
+ border-left-color: rgba(0, 0, 0, .25);
+}
+.popover.left > .arrow:after {
+ right: 1px;
+ bottom: -10px;
+ content: " ";
+ border-right-width: 0;
+ border-left-color: #fff;
+}
+.carousel {
+ position: relative;
+}
+.carousel-inner {
+ position: relative;
+ width: 100%;
+ overflow: hidden;
+}
+.carousel-inner > .item {
+ position: relative;
+ display: none;
+ -webkit-transition: .6s ease-in-out left;
+ transition: .6s ease-in-out left;
+}
+.carousel-inner > .item > img,
+.carousel-inner > .item > a > img {
+ line-height: 1;
+}
+.carousel-inner > .active,
+.carousel-inner > .next,
+.carousel-inner > .prev {
+ display: block;
+}
+.carousel-inner > .active {
+ left: 0;
+}
+.carousel-inner > .next,
+.carousel-inner > .prev {
+ position: absolute;
+ top: 0;
+ width: 100%;
+}
+.carousel-inner > .next {
+ left: 100%;
+}
+.carousel-inner > .prev {
+ left: -100%;
+}
+.carousel-inner > .next.left,
+.carousel-inner > .prev.right {
+ left: 0;
+}
+.carousel-inner > .active.left {
+ left: -100%;
+}
+.carousel-inner > .active.right {
+ left: 100%;
+}
+.carousel-control {
+ position: absolute;
+ top: 0;
+ bottom: 0;
+ left: 0;
+ width: 15%;
+ font-size: 20px;
+ color: #fff;
+ text-align: center;
+ text-shadow: 0 1px 2px rgba(0, 0, 0, .6);
+ filter: alpha(opacity=50);
+ opacity: .5;
+}
+.carousel-control.left {
+ background-image: -webkit-linear-gradient(left, color-stop(rgba(0, 0, 0, .5) 0%), color-stop(rgba(0, 0, 0, .0001) 100%));
+ background-image: linear-gradient(to right, rgba(0, 0, 0, .5) 0%, rgba(0, 0, 0, .0001) 100%);
+ filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#80000000', endColorstr='#00000000', GradientType=1);
+ background-repeat: repeat-x;
+}
+.carousel-control.right {
+ right: 0;
+ left: auto;
+ background-image: -webkit-linear-gradient(left, color-stop(rgba(0, 0, 0, .0001) 0%), color-stop(rgba(0, 0, 0, .5) 100%));
+ background-image: linear-gradient(to right, rgba(0, 0, 0, .0001) 0%, rgba(0, 0, 0, .5) 100%);
+ filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#80000000', GradientType=1);
+ background-repeat: repeat-x;
+}
+.carousel-control:hover,
+.carousel-control:focus {
+ color: #fff;
+ text-decoration: none;
+ filter: alpha(opacity=90);
+ outline: none;
+ opacity: .9;
+}
+.carousel-control .icon-prev,
+.carousel-control .icon-next,
+.carousel-control .glyphicon-chevron-left,
+.carousel-control .glyphicon-chevron-right {
+ position: absolute;
+ top: 50%;
+ z-index: 5;
+ display: inline-block;
+}
+.carousel-control .icon-prev,
+.carousel-control .glyphicon-chevron-left {
+ left: 50%;
+}
+.carousel-control .icon-next,
+.carousel-control .glyphicon-chevron-right {
+ right: 50%;
+}
+.carousel-control .icon-prev,
+.carousel-control .icon-next {
+ width: 20px;
+ height: 20px;
+ margin-top: -10px;
+ margin-left: -10px;
+ font-family: serif;
+}
+.carousel-control .icon-prev:before {
+ content: '\2039';
+}
+.carousel-control .icon-next:before {
+ content: '\203a';
+}
+.carousel-indicators {
+ position: absolute;
+ bottom: 10px;
+ left: 50%;
+ z-index: 15;
+ width: 60%;
+ padding-left: 0;
+ margin-left: -30%;
+ text-align: center;
+ list-style: none;
+}
+.carousel-indicators li {
+ display: inline-block;
+ width: 10px;
+ height: 10px;
+ margin: 1px;
+ text-indent: -999px;
+ cursor: pointer;
+ background-color: #000 \9;
+ background-color: rgba(0, 0, 0, 0);
+ border: 1px solid #fff;
+ border-radius: 10px;
+}
+.carousel-indicators .active {
+ width: 12px;
+ height: 12px;
+ margin: 0;
+ background-color: #fff;
+}
+.carousel-caption {
+ position: absolute;
+ right: 15%;
+ bottom: 20px;
+ left: 15%;
+ z-index: 10;
+ padding-top: 20px;
+ padding-bottom: 20px;
+ color: #fff;
+ text-align: center;
+ text-shadow: 0 1px 2px rgba(0, 0, 0, .6);
+}
+.carousel-caption .btn {
+ text-shadow: none;
+}
+@media screen and (min-width: 768px) {
+ .carousel-control .glyphicon-chevron-left,
+ .carousel-control .glyphicon-chevron-right,
+ .carousel-control .icon-prev,
+ .carousel-control .icon-next {
+ width: 30px;
+ height: 30px;
+ margin-top: -15px;
+ margin-left: -15px;
+ font-size: 30px;
+ }
+ .carousel-caption {
+ right: 20%;
+ left: 20%;
+ padding-bottom: 30px;
+ }
+ .carousel-indicators {
+ bottom: 20px;
+ }
+}
+.clearfix:before,
+.clearfix:after,
+.container:before,
+.container:after,
+.container-fluid:before,
+.container-fluid:after,
+.row:before,
+.row:after,
+.form-horizontal .form-group:before,
+.form-horizontal .form-group:after,
+.btn-toolbar:before,
+.btn-toolbar:after,
+.btn-group-vertical > .btn-group:before,
+.btn-group-vertical > .btn-group:after,
+.nav:before,
+.nav:after,
+.navbar:before,
+.navbar:after,
+.navbar-header:before,
+.navbar-header:after,
+.navbar-collapse:before,
+.navbar-collapse:after,
+.pager:before,
+.pager:after,
+.panel-body:before,
+.panel-body:after,
+.modal-footer:before,
+.modal-footer:after {
+ display: table;
+ content: " ";
+}
+.clearfix:after,
+.container:after,
+.container-fluid:after,
+.row:after,
+.form-horizontal .form-group:after,
+.btn-toolbar:after,
+.btn-group-vertical > .btn-group:after,
+.nav:after,
+.navbar:after,
+.navbar-header:after,
+.navbar-collapse:after,
+.pager:after,
+.panel-body:after,
+.modal-footer:after {
+ clear: both;
+}
+.center-block {
+ display: block;
+ margin-right: auto;
+ margin-left: auto;
+}
+.pull-right {
+ float: right !important;
+}
+.pull-left {
+ float: left !important;
+}
+.hide {
+ display: none !important;
+}
+.show {
+ display: block !important;
+}
+.invisible {
+ visibility: hidden;
+}
+.text-hide {
+ font: 0/0 a;
+ color: transparent;
+ text-shadow: none;
+ background-color: transparent;
+ border: 0;
+}
+.hidden {
+ display: none !important;
+ visibility: hidden !important;
+}
+.affix {
+ position: fixed;
+}
+@-ms-viewport {
+ width: device-width;
+}
+.visible-xs,
+.visible-sm,
+.visible-md,
+.visible-lg {
+ display: none !important;
+}
+@media (max-width: 767px) {
+ .visible-xs {
+ display: block !important;
+ }
+ table.visible-xs {
+ display: table;
+ }
+ tr.visible-xs {
+ display: table-row !important;
+ }
+ th.visible-xs,
+ td.visible-xs {
+ display: table-cell !important;
+ }
+}
+@media (min-width: 768px) and (max-width: 991px) {
+ .visible-sm {
+ display: block !important;
+ }
+ table.visible-sm {
+ display: table;
+ }
+ tr.visible-sm {
+ display: table-row !important;
+ }
+ th.visible-sm,
+ td.visible-sm {
+ display: table-cell !important;
+ }
+}
+@media (min-width: 992px) and (max-width: 1199px) {
+ .visible-md {
+ display: block !important;
+ }
+ table.visible-md {
+ display: table;
+ }
+ tr.visible-md {
+ display: table-row !important;
+ }
+ th.visible-md,
+ td.visible-md {
+ display: table-cell !important;
+ }
+}
+@media (min-width: 1200px) {
+ .visible-lg {
+ display: block !important;
+ }
+ table.visible-lg {
+ display: table;
+ }
+ tr.visible-lg {
+ display: table-row !important;
+ }
+ th.visible-lg,
+ td.visible-lg {
+ display: table-cell !important;
+ }
+}
+@media (max-width: 767px) {
+ .hidden-xs {
+ display: none !important;
+ }
+}
+@media (min-width: 768px) and (max-width: 991px) {
+ .hidden-sm {
+ display: none !important;
+ }
+}
+@media (min-width: 992px) and (max-width: 1199px) {
+ .hidden-md {
+ display: none !important;
+ }
+}
+@media (min-width: 1200px) {
+ .hidden-lg {
+ display: none !important;
+ }
+}
+.visible-print {
+ display: none !important;
+}
+@media print {
+ .visible-print {
+ display: block !important;
+ }
+ table.visible-print {
+ display: table;
+ }
+ tr.visible-print {
+ display: table-row !important;
+ }
+ th.visible-print,
+ td.visible-print {
+ display: table-cell !important;
+ }
+}
+@media print {
+ .hidden-print {
+ display: none !important;
+ }
+}
+/*# sourceMappingURL=bootstrap.css.map */
diff --git a/pype/premiere/extensions/com.pond5.ppro/remote/index_files/build.js b/pype/premiere/extensions/com.pond5.ppro/remote/index_files/build.js
new file mode 100644
index 0000000000..180c65d29c
--- /dev/null
+++ b/pype/premiere/extensions/com.pond5.ppro/remote/index_files/build.js
@@ -0,0 +1,4862 @@
+var app = angular.module("Plugin", ["ui-rangeSlider", "ui.bootstrap"]);
+app.run(["$rootScope", "MainHelper", function($rootScope, MainHelper) {
+ MainHelper.init(BM_VIDEO, 15)
+}]), app.controller("ModalIntroController", function($scope, $uibModal, CreateOnFileSystemService, DestinationsService) {
+ $scope.items = [], $scope.obj = {
+ state: 1
+ }, $scope.$root.$on("intro requested", function(event) {
+ console.log("ModalIntroController event handler"), $scope.open("sm")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_INTRO_HTML,
+ backdrop: "static",
+ controller: ModalIntroInstanceCtrl,
+ windowClass: "modal-intro"
+ }).result.then(function() {
+ console.log("ModalIntroController OK"), CreateOnFileSystemService.createDestinationBaseFolder(), DestinationsService.saveItem()
+ }, function() {
+ console.log("ModalIntroController CANCELED")
+ })
+ }
+});
+
+var ModalIntroInstanceCtrl = function($scope, $uibModalInstance, BrowseDestinationService, AppModel) {
+ $scope.obj = {
+ state: 1,
+ title: "",
+ message: "",
+ labelLeft: [!1, "PREVIOUS"],
+ labelCenter: [!1, ""],
+ labelRight: [!0, "NEXT"],
+ stateImage: [!0, ""],
+ selectedFolder: AppModel.currentBaseFolder
+ }, $scope.onChange = function() {
+ switch (1 < $scope.obj.state && ($scope.obj.stateImage = [!0, STATE_IMG + $scope.obj.state + ".png"]), $scope.obj.state) {
+ case 1:
+ $scope.obj.stateName = "", $scope.obj.stateImage = [!1, ""], $scope.obj.labelLeft = [!1, "PREVIOUS"], $scope.obj.title = "Welcome!", $scope.obj.message = "Thanks for downloading the Pond5 Adobe Add-On. Click through this short tutorial to learn some of the basics.";
+ break;
+ case 2:
+ $scope.obj.labelLeft = [!0, "PREVIOUS"], $scope.obj.stateName = "search", $scope.obj.title = "", $scope.obj.message = "Start by searching our massive library of royalty-free video clips and easily add them to your working projects.";
+ break;
+ case 3:
+ $scope.obj.stateName = "filters", $scope.obj.labelLeft = [!0, "PREVIOUS"], $scope.obj.message = "Use the toolbar on the left to filter your search results, view your previews, and update your directory folder.";
+ break;
+ case 4:
+ $scope.obj.stateName = "collections", $scope.obj.message = "View and create new collections below. We've even added 50 free clips to get you started!";
+ break;
+ case 5:
+ $scope.obj.stateName = "login", $scope.obj.labelCenter = [!1, "SELECT"], $scope.obj.labelRight = [!0, "NEXT"], $scope.obj.message = "Log in to your Pond5 account here for easy checkout once you've found the perfect clips for your project.";
+ break;
+ case 6:
+ $scope.obj.stateName = "", $scope.obj.labelLeft = [!0, "PREVIOUS"], $scope.obj.labelCenter = [!0, "SELECT"], $scope.obj.labelRight = [!0, "FINISH"], $scope.obj.message = "Select your destination folder to get started. Pond5 media will be saved in this folder.", 0 < AppModel.currentBaseFolder.length && ($scope.obj.message = "Select your destination folder to get started. The default folder is " + AppModel.currentBaseFolder)
+ }
+ }, $scope.buttonLeftClicked = function() {
+ $scope.obj.state--, $scope.onChange(), getStateObject($scope.obj.stateName)
+ }, $scope.buttonCenterClicked = function() {
+ $scope.obj.selectedFolder = BrowseDestinationService.browse(), $scope.obj.message = "Your current destination folder is: " + $scope.obj.selectedFolder
+ }, $scope.buttonRightClicked = function() {
+ console.log("ModalIntroController buttonRightClicked"), $scope.obj.state < 6 ? ($scope.obj.state++, $scope.onChange(), getStateObject($scope.obj.stateName)) : (console.log("ModalIntroController buttonRightClicked", $scope.obj.selectedFolder), BrowseDestinationService.save($scope.obj.selectedFolder), $uibModalInstance.close())
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }, getStateObject = function(stateName) {
+ console.log("modalIntroController look for: ", stateName), INTRO_DATA.forEach(function(entry) {
+ var obj = {};
+ entry.stateName === stateName ? (console.log("modalIntroController found stateName: ", entry), obj.stateName = entry.stateName, obj.arrowClass = entry.arrowClass, obj.posX = entry.posX, obj.posY = entry.posY, console.log("modalIntroController found obj: ", obj)) : (obj.stateName = stateName, obj.arrowClass = ""), $scope.$root.$emit("intro asset requested", obj)
+ })
+ }, $scope.onChange()
+};
+PLUGIN_VERSION = "", HOST_NAME = "PPRO", THIRD_PARTY = "", MEDIA_TYPES = ["Footage", "Music", "SFX"], BUTTON_REPLACE_LABEL = "REPLACE WITH HI-RES CLIPS", BUTTON_REPLACE_TOOLTIP = "Replace lo-res with paid items", MODAL_REPLACE_HEADER = "Replace With Hi-Res Clips", MODAL_REPLACE_CONTENT = "The selected items below will be replaced by full resolution versions after you complete checkout. Items already in your account history will also be downloaded.", MODAL_REPLACE_RES_TITLE = "RESOLUTION", MODAL_INTRO_SEARCH = "Start by searching our massive library of royalty-free video clips and easily add them to your working projects.", MODAL_INTRO_COLLECTIONS = "View and create new collections below. We've even added 50 free clips to get you started!", MODAL_INTRO_LOGIN = "Log in to your Pond5 account here for easy checkout once you've found the perfect clips for your project.", INTRO_DATA = [{
+ state: 7,
+ stateName: "downloads",
+ arrowClass: ".intro-asset-arrow-left",
+ posY: ["top", "96px"],
+ posX: ["left", "60px"]
+}, {
+ state: 3,
+ stateName: "filters",
+ arrowClass: ".intro-asset-arrow-left",
+ posY: ["top", "60px"],
+ posX: ["left", "55px"]
+}, {
+ state: 9,
+ stateName: "destination",
+ arrowClass: ".intro-asset-arrow-left",
+ posY: ["bottom", "55px"],
+ posX: ["left", "60px"]
+}, {
+ state: 4,
+ stateName: "collections",
+ arrowClass: ".intro-asset-arrow-down",
+ posY: ["bottom", "140px"],
+ posX: ["left", "260px"]
+}, {
+ state: 2,
+ stateName: "search",
+ arrowClass: ".intro-asset-arrow-up",
+ posY: ["top", "60px"],
+ posX: ["left", "165px"]
+}, {
+ state: 5,
+ stateName: "login",
+ arrowClass: ".intro-asset-arrow-up",
+ posY: ["top", "60px"],
+ posX: ["right", "75px"]
+}], app.service("ReplaceService", ["$rootScope", "ReplaceModel", "Service", "ReplaceServiceShared", function($rootScope, ReplaceModel, Service, ReplaceServiceShared) {
+ var call = {
+ onClipFSCollected: function() {
+ call.getSequences()
+ },
+ getSequences: function() {
+ csInterface.evalScript("getSequences()", function(result) {
+ var sequences = JSON.parse(result).sequences;
+ console.log("\nReplaceService sequences NEW", sequences.length, sequences), ReplaceModel.setSequences(sequences)
+ })
+ },
+ getMedia: function() {
+ var obj = ReplaceModel.sequences;
+ csInterface.evalScript("getSequenceItems(" + JSON.stringify(obj) + ")", function(result) {
+ var clipsInSequences = JSON.parse(result).data;
+ ReplaceModel.clipsInSequences = clipsInSequences, console.log("\nReplaceService clipsInSequences", ReplaceModel.clipsInSequences), csInterface.evalScript("getProjectItems()", function(result) {
+ call.getMissingItemIDs()
+ })
+ })
+ },
+ getClipsInSelectedSequences: function() {
+ for (var clipsInSequences = ReplaceModel.clipsInSequences, clipsInSelectedSequences = [], s = 0; s < ReplaceModel.sequences.length; s++)
+ for (var j = 0; j < clipsInSequences.length; j++)
+ if (ReplaceModel.sequences[s].sequenceID === clipsInSequences[j].sequenceID && ReplaceModel.sequences[s].checked)
+ for (var k = 0; k < clipsInSequences[j].clipNames.length; k++) clipsInSelectedSequences.push(clipsInSequences[j].clipNames[k]);
+ return clipsInSelectedSequences
+ },
+ getMissingItemIDs: function() {
+ var clipsInSelectedSequences = call.getClipsInSelectedSequences();
+ clipsInSelectedSequences = ReplaceServiceShared.removeDuplicates(clipsInSelectedSequences), console.log("\nReplaceService clipsInSelectedSequences after removing duplicates: ", clipsInSelectedSequences);
+ var previewNamesonFS = ReplaceServiceShared.getPreviewsOnFSNames();
+ clipsInSelectedSequences = ReplaceServiceShared.filterNonP5Clips(clipsInSelectedSequences, previewNamesonFS), console.log("\nReplaceService after filterNonP5Clips", clipsInSelectedSequences);
+ var previewIDs = ReplaceServiceShared.getPreviewsIDs(clipsInSelectedSequences);
+ console.log("\nReplaceService previewIDs: " + previewIDs), ReplaceServiceShared.setReplaceProp(previewIDs), console.log("\nReplaceService after set replace: " + ReplaceModel.hiresOnFS);
+ var hiresIDs = ReplaceServiceShared.getHiresIDsonFS();
+ console.log("\nReplaceService hiresIDs: " + hiresIDs);
+ var missingItemIDs = _(previewIDs).difference(hiresIDs),
+ missingIDsToString = missingItemIDs.join(",");
+ 0 < missingItemIDs.length ? Service.getMissingItems(missingIDsToString) : 0 < hiresIDs.length ? call.onPurchasedAndDownloaded() : 0 === clipsInSelectedSequences.length && (ReplaceModel.setState(DEFAULT), $rootScope.$emit("modal simple requested", ["", "There are are currently no Pond5 previews in the sequence(s) you've selected."]))
+ },
+ onPurchasedAndDownloaded: function() {
+ var hasReplaceCandidates = !1;
+ if (ReplaceModel.hiresOnFS.forEach(function(entry) {
+ entry.replace && (hasReplaceCandidates = !0)
+ }), !hasReplaceCandidates) return $rootScope.$emit("modal simple requested", ["", "Replacing previews by hi-res clips has been canceled"]), void ReplaceModel.setState(DEFAULT);
+ var obj = {
+ hiresOnFS: ReplaceModel.hiresOnFS
+ };
+ csInterface.evalScript("replaceClips(" + JSON.stringify(obj) + ")", function(result) {
+ $rootScope.$emit("modal simple requested", ["", "Your previews have been successfully replaced by your purchased clips. Right-click the clips and choose Scale to Frame Size to scale them correctly."]), ReplaceModel.setState(DEFAULT)
+ })
+ }
+ };
+ return call
+}]), app.controller("ModalAddDestinationController", function($scope, $uibModal, UserModel, AppModel, CreateOnFileSystemService, DestinationsService) {
+ $scope.obj = {}, $scope.$root.$on("modal add destination requested", function() {
+ console.log("ModalAddDestinationController event handler", UserModel.getFirstTimeUser()), $scope.obj.title = "Add a destination folder", $scope.obj.content = "Please select a new folder to store your previews and purchased items.", $scope.obj.okButtonLabel = "APPLY", $scope.obj.selectedFolderPrefix = "Current folder: ", $scope.obj.selectedFolder = AppModel.currentBaseFolder, $scope.open("lg")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_ADD_DESTINATION_HTML,
+ controller: ModalAddDestinatonInstanceCtrl,
+ size: size,
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ }
+ }).result.then(function() {
+ console.log("ModalAddDestinationController OK", AppModel.currentBaseFolder), $scope.onClicked()
+ }, function() {
+ console.log("ModalAddDestinationController CANCEL", AppModel.currentBaseFolder), $scope.onClicked()
+ })
+ }, $scope.onClicked = function() {
+ console.log("ModalAddDestinationController onClicked"), UserModel.getFirstTimeUser() && $scope.$root.$emit("modal freebies"), CreateOnFileSystemService.createDestinationBaseFolder(), DestinationsService.saveItem()
+ }
+});
+var ModalAddDestinatonInstanceCtrl = function($scope, $uibModalInstance, obj, BrowseDestinationService) {
+ $scope.obj = {}, $scope.obj.showTitle = obj.showTitle, $scope.obj.title = obj.title, $scope.obj.content = obj.content, $scope.obj.selectedFolder = obj.selectedFolder, $scope.obj.selectedFolderPrefix = obj.selectedFolderPrefix, $scope.obj.okButtonLabel = obj.okButtonLabel, $scope.browse = function() {
+ console.log("ModalAddDestinatonInstanceCtrl browse"), $scope.obj.selectedFolder = BrowseDestinationService.browse()
+ }, $scope.ok = function() {
+ BrowseDestinationService.save($scope.obj.selectedFolder), $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalSelectSequencesController", function($scope, $uibModal, ReplaceModel, ReplaceService) {
+ $scope.items = [], $scope.$root.$on("modal select sequences", function(event, data) {
+ $scope.items = data, $scope.open("lg")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_SELECT_SEQUENCES_HTML,
+ controller: ModalSelectSequencesInstanceCtrl,
+ size: size,
+ resolve: {
+ items: function() {
+ return $scope.items
+ }
+ }
+ }).result.then(function() {
+ console.log("ModalSelectSequencesController OK: ", $scope.items);
+ for (var i = 0; i < $scope.items.length; i++) $scope.items[i].selected && (ReplaceModel.sequences[i].checked = !0);
+ ReplaceService.getMedia()
+ }, function() {
+ ReplaceModel.setState(DEFAULT)
+ })
+ }
+});
+var ModalSelectSequencesInstanceCtrl = function($scope, $uibModalInstance, items) {
+ $scope.items = items, $scope.obj = {
+ showWarning: !1
+ }, $scope.ok = function() {
+ for (var checked = !1, i = 0; i < $scope.items.length; i++) $scope.items[i].selected && (checked = !0);
+ checked ? $uibModalInstance.close() : $scope.obj.showWarning = !0
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.factory("MainHelper", ["$rootScope", "AppModel", "StartUpService", "SearchModel", function($rootScope, AppModel, StartUpService, SearchModel) {
+ var result = {
+ init: function(mediaType, sumOfBitmasks) {
+ csInterface = new CSInterface, csInterface.addEventListener("LogEvent", function(evt) {
+ console.log("JSX : " + evt.data)
+ });
+ var rootFolderPath = csInterface.getSystemPath(SystemPath.EXTENSION);
+ AppModel.rootFolderPath = rootFolderPath, fs = require("fs"), os = require("os"), path = require("path"), url = require("url"), https = require("https"), xml2js = require(rootFolderPath + "/node_modules/xml2js/lib/xml2js.js"), walk = require(rootFolderPath + "/node_modules/walk/lib/walk.js"), junk = require(rootFolderPath + "/node_modules/junk/index.js"), rimraf = require(rootFolderPath + "/node_modules/rimraf/rimraf.js"), opn = require(rootFolderPath + "/node_modules/opn/index.js"), DecompressZip = require(rootFolderPath + "/node_modules/decompress-zip/lib/decompress-zip.js"), $("#logo").click(function() {
+ location.reload()
+ }), result.readManifestXML(), SearchModel.sumOfBitmasks = sumOfBitmasks, $rootScope.$emit("media filter change", mediaType), setTimeout(function() {
+ AppModel.setEnv()
+ }, 2e3)
+ },
+ readManifestXML: function() {
+ var file = AppModel.rootFolderPath + "/CSXS/manifest.xml";
+ fs.readFile(file, "utf8", function(err, data) {
+ if (err) throw err;
+ result.parseXML(data)
+ })
+ },
+ parseXML: function(xml) {
+ var parser = new xml2js.Parser;
+ parser.addListener("end", function(res) {
+ PLUGIN_VERSION = res.ExtensionManifest.$.ExtensionBundleVersion, console.log("mainHelper parsed manifest xml, version:", PLUGIN_VERSION), result.loadJSX()
+ }), parser.parseString(xml)
+ },
+ loadJSX: function(fileName) {
+ var jsxPath = AppModel.rootFolderPath + "/jsx/json2.js";
+ console.log("mainHelper loadJSX:", jsxPath), csInterface.evalScript('$.evalFile("' + jsxPath + '")', function(result) {})
+ }
+ };
+ return result
+}]), app.service("BrowseDestinationService", ["AppModel", function(AppModel) {
+ this.browse = function() {
+ var result = window.cep.fs.showOpenDialog(!1, !0, "Select a folder for your previews and hi-res downloads.", ""),
+ selectedFolder = AppModel.currentBaseFolder;
+ return console.log("BrowseDestinationService folder chosen, result.err: ", result.err), 0 == result.err ? (console.log("BrowseDestinationService folder chosen: ", result.data[0]), result.data[0] && (selectedFolder = result.data[0])) : selectedFolder = "This folder cannot be selected. Please choose another folder.", console.log("BrowseDestinationService return folder: ", selectedFolder), selectedFolder
+ }, this.save = function(selectedFolder) {
+ console.log("BrowseDestinationService save", AppModel.getOS(), "win" === AppModel.getOS()), "win" === AppModel.getOS() ? AppModel.currentBaseFolder = selectedFolder.replace(/\//g, "\\") : AppModel.currentBaseFolder = selectedFolder
+ }
+}]), app.service("CreateFileCompleteService", ["ImportedPreviewsService", "DestinationsService", "UserService", function(ImportedPreviewsService, DestinationsService, UserService) {
+ return {
+ onFileReady: function(file) {
+ -1 != file.indexOf("imported_previews.xml") && ImportedPreviewsService.readXML(), -1 != file.indexOf("destinations.xml") && DestinationsService.readXML(), -1 != file.indexOf("user.xml") && UserService.readXML()
+ }
+ }
+}]), app.factory("DestinationsService", ["$rootScope", "AppModel", "UserModel", function($rootScope, AppModel, UserModel) {
+ var result = {
+ xmlVersion: "",
+ readXML: function() {
+ result.file = AppModel.getDestinationsXML(), console.log("DestinationsService file: ", result.file), fs.readFile(result.file, "utf8", function(err, data) {
+ if (err) throw err;
+ result.xml = data, console.log("DestinationsService, xml:", result.xml), result.parseXML()
+ })
+ },
+ saveItem: function() {
+ var node = ' ';
+ result.xml = result.xml.insert(result.xml.indexOf("destinations") + 13, node), result.writeToDisk()
+ },
+ deleteItem: function() {},
+ parseXML: function() {
+ var parser = new xml2js.Parser;
+ parser.addListener("end", function(res) {
+ var i;
+ result.parsedXML = res, AppModel.baseFolders = [], UserModel.setFirstTimeUser(!1), res.root.$[HOST_NAME] ? result.xmlVersion = res.root.$[HOST_NAME] : res.root.$.version ? result.xmlVersion = res.root.$.version : res.root.$.PPRO && (result.xmlVersion = res.root.$.PPRO), UserModel.setUID(res.root.$.id), PLUGIN_VERSION != result.xmlVersion && (console.log("DestinationsService other or no version number in xml, first time user: ", result.xmlVersion), UserModel.setFirstTimeUser(!0));
+ var destinations = res.root.destinations[0].destination;
+ if (console.log("DestinationsService destinations: ", destinations), destinations) {
+ for (i = 0; i < destinations.length; i++) - 1 == AppModel.baseFolders.indexOf(destinations[i].$.destination) && fs.existsSync(destinations[i].$.destination + path.sep + "pond5") && AppModel.baseFolders.push(destinations[i].$.destination);
+ fs.stat(AppModel.baseFolders[0] + path.sep + "pond5", function(err, stats) {
+ err ? setTimeout(function() {
+ $rootScope.$emit("modal add destination requested")
+ }, 3e3) : AppModel.currentBaseFolder = AppModel.baseFolders[0]
+ }), console.log("DestinationsService AppModel.baseFolders : ", AppModel.baseFolders), console.log("DestinationsService currentBaseFolder : ", AppModel.currentBaseFolder)
+ }
+ if (UserModel.getFirstTimeUser()) {
+ var newVersion = HOST_NAME + '="' + PLUGIN_VERSION + '"';
+ result.parsedXML.root.$[HOST_NAME] ? result.xml = result.xml.replace(HOST_NAME + '="' + result.xmlVersion + '"', newVersion) : result.parsedXML.root.$.version && "PPRO" === HOST_NAME ? result.xml = result.xml.replace('version="' + result.xmlVersion + '"', newVersion) : result.parsedXML.root.$.version && "PPRO" != HOST_NAME ? result.xml = result.xml.replace('version="' + result.xmlVersion + '"', 'version="' + result.xmlVersion + '" ' + newVersion) : result.parsedXML.root.$.PPRO && !result.parsedXML.root.$[HOST_NAME] && (result.xml = result.xml.replace('PPRO="' + result.xmlVersion + '"', 'PPRO="' + result.xmlVersion + '" ' + newVersion)), console.log("DestinationsService result.xml replaced: ", result.xml), console.log("DestinationsService getFirstTimeUser is true, show intro"), setTimeout(function() {
+ $rootScope.$emit("intro requested")
+ }, 3e3)
+ }
+ }), parser.parseString(result.xml)
+ },
+ writeToDisk: function() {
+ fs.writeFile(result.file, result.xml, function(err) {
+ if (err) throw err;
+ result.readXML()
+ })
+ }
+ };
+ return result
+}]), app.service("ImportService", ["$rootScope", function($rootScope) {
+ this.importClips = function(items) {
+ var i, importPaths = [];
+ for (i = 0; i < items.length; i++) console.log("ImportService item.canceled:", items[i].canceled), items[i].canceled || items[i].imported || (items[i].imported = !0, importPaths.push(items[i].downloadDestination + items[i].fileName));
+ console.log("ImportService importPath:", importPaths);
+ var obj = {
+ paths: importPaths
+ };
+ csInterface.evalScript("importClips(" + JSON.stringify(obj) + ")", function(result) {
+ console.log("ImportService result: ", result), $rootScope.$emit("on importing bin complete")
+ })
+ }
+}]), app.service("OpenURLService", [function() {
+ this.openURL = function(url) {
+ csInterface.openURLInDefaultBrowser(url)
+ }
+}]), app.controller("AdvancedSearchController", function($scope, ViewStateModel, SearchModel, ViewStateService) {
+ $scope.obj = {
+ show: !1,
+ fpsItems: [{
+ fps: "23.98"
+ }, {
+ fps: "24"
+ }, {
+ fps: "25"
+ }, {
+ fps: "29.97"
+ }, {
+ fps: "30"
+ }, {
+ fps: "60"
+ }, {
+ fps: "60+"
+ }],
+ resItems: [{
+ res: "4K+",
+ param: "8K"
+ }, {
+ res: "4K",
+ param: "4K"
+ }, {
+ res: "2K",
+ param: "2K"
+ }, {
+ res: "HD (1080)",
+ param: "HD1080"
+ }, {
+ res: "HD (720)",
+ param: "HD720"
+ }, {
+ res: "SD",
+ param: "SD"
+ }, {
+ res: "Web",
+ param: "WEB"
+ }],
+ showCbFilters: !0,
+ _minPrice: 0,
+ _maxPrice: 500,
+ minPrice: function(newValue) {
+ return arguments.length ? $scope.obj._minPrice = newValue : $scope.obj._minPrice
+ },
+ maxPrice: function(newValue) {
+ return 500 == $scope.obj._maxPrice ? $scope.obj.maxPriceValue = "$500+" : $scope.obj.maxPriceValue = "$" + $scope.obj._maxPrice, arguments.length ? $scope.obj._maxPrice = newValue : $scope.obj._maxPrice
+ },
+ _minTime: 0,
+ _maxTime: 120,
+ minTime: function(newValue) {
+ return arguments.length ? $scope.obj._minTime = newValue : $scope.obj._minTime
+ },
+ maxTime: function(newValue) {
+ return 120 == $scope.obj._maxTime ? $scope.obj.showTimePlusSign = !0 : $scope.obj.showTimePlusSign = !1, arguments.length ? $scope.obj._maxTime = newValue : $scope.obj._maxTime
+ }
+ }, $scope.oneAtATime = !0, $scope.reset = function() {
+ for ($scope.obj._minPrice = 0, $scope.obj._maxPrice = 500, $scope.obj._minTime = 0, $scope.obj._maxTime = 120, SearchModel.fps = "", SearchModel.fpsgt = "", SearchModel.res = "", SearchModel.pricegt = "", SearchModel.pricelt = "", SearchModel.durationgt = "", SearchModel.durationlt = "", i = 0; i < $scope.obj.fpsItems.length; i++) $scope.obj.fpsItems[i].checked = !1;
+ for (i = 0; i < $scope.obj.resItems.length; i++) $scope.obj.resItems[i].checked = !1
+ }, $scope.reset(), $scope.$root.$on("filters button clicked", function(event, state) {
+ $scope.obj.show = state
+ }), $scope.$root.$on("media filter change", function(event, data) {
+ data == BM_VIDEO || data == BM_PUBLIC_DOMAIN ? $scope.obj.showCbFilters = !0 : ($scope.obj.showCbFilters = !1, $scope.reset()), data == BM_AFTER_EFFECTS ? $scope.obj.showDuration = !1 : $scope.obj.showDuration = !0
+ }), $scope.change = function() {
+ var fpsgt, fps = " fps",
+ res = " resolutions";
+ for (i = 0; i < $scope.obj.fpsItems.length - 1; i++) $scope.obj.fpsItems[i].checked && (fps += ":" + $scope.obj.fpsItems[i].fps);
+ for (fpsgt = $scope.obj.fpsItems[6].checked ? " fpsgt:60" : "", i = 0; i < $scope.obj.resItems.length; i++) $scope.obj.resItems[i].checked && (res += ":" + $scope.obj.resItems[i].param);
+ fps.length <= 5 ? fps = "" : fpsgt = "", res.length <= 13 && (res = ""), SearchModel.fps = fps, SearchModel.fpsgt = fpsgt, SearchModel.res = res, SearchModel.resultType = "replace", SearchModel.page = 0, ViewStateService.viewRequested("search")
+ }, $scope.onHideFiltersClicked = function() {
+ $scope.obj.show = !1, $scope.$root.$emit("filters button clicked", !1)
+ }, $scope.onResetFiltersClicked = function() {
+ $scope.reset(), $scope.change()
+ }, $scope.viewState = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewState, function() {
+ "cart" !== ViewStateModel.getState() && "downloads" !== ViewStateModel.getState() || ($scope.obj.show = !1)
+ }, !0), window.addEventListener("rangeSliderOff", function(e) {
+ "" == $scope.obj._minPrice ? SearchModel.pricegt = "" : SearchModel.pricegt = " pricegt:" + $scope.obj._minPrice, "500" == $scope.obj._maxPrice ? SearchModel.pricelt = "" : SearchModel.pricelt = " pricelt:" + $scope.obj._maxPrice, "" == $scope.obj._minTime ? SearchModel.durationgt = "" : SearchModel.durationgt = " durationgt:" + $scope.obj._minTime, "120" == $scope.obj._maxTime ? SearchModel.durationlt = "" : SearchModel.durationlt = " durationlt:" + $scope.obj._maxTime, $scope.change()
+ }, !1)
+}), app.controller("AlertController", function($scope) {
+ $scope.alerts = [], $scope.addAlert = function() {
+ console.log("AlertController add"), $scope.alerts.push({
+ msg: "Another alert!"
+ })
+ }, $scope.closeAlert = function(index) {
+ $scope.alerts.splice(index, 1)
+ }
+}), app.controller("BinsController", function($scope, BinsModel, Service, LoginModel, ViewStateModel, ViewStateService) {
+ $scope.obj = {}, $scope.obj.showImportAll = !1, $scope.obj.showSelect = !1, $scope.obj.direction = "dropup", $scope.loginModel = function() {
+ return LoginModel.loggedIn
+ }, $scope.viewStateModel = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.loginModel, function() {
+ LoginModel.loggedIn ? $scope.obj.showSelect = !0 : $scope.obj.showSelect = !1
+ }), $scope.$watch($scope.viewStateModel, function() {
+ "bins" != ViewStateModel.getState() && ($scope.obj.selectedNameFormatted = "Collection")
+ }), $scope.$root.$on("onBins", function(event) {
+ $scope.bins = BinsModel.bins
+ }), $scope.onClick = function() {
+ console.log("BinsController onClick"), $scope.$root.$emit("select clicked")
+ }, $scope.onChange = function(bin) {
+ console.log("onChange, bin: ", bin), 14 < bin.name.length ? $scope.obj.selectedNameFormatted = bin.name.substr(0, 14) + "..." : $scope.obj.selectedNameFormatted = bin.name, $scope.obj.open = !1, $scope.selected = bin, $scope.selected && (BinsModel.selectedBin = bin, $scope.$root.$emit("bin selected", bin.name), ViewStateService.viewRequested("bins"))
+ }, $scope.onDelete = function(bin) {
+ console.log("onDelete, bin: ", bin)
+ }, $scope.toggled = function(open) {
+ $scope.obj.direction = open ? "down" : "dropup"
+ }, $scope.onAddClicked = function() {
+ console.log("onAddClicked"), $scope.$root.$emit("modal add collection requested")
+ }, $scope.onRemoveClicked = function() {
+ console.log("onRemoveClicked"), $scope.$root.$emit("modal remove collection requested")
+ }
+}), app.controller("CartController", function($scope, Service, ViewStateService, CartModel, LoginModel, AnalyticsService) {
+ $scope.obj = {
+ numberOfItem: 0,
+ clearCartIcon: CLEAR_CART_TRASH_IMG,
+ imageUrl: CART_BUTTON_IMG,
+ cartButtonStyle: "button-cart-logged-out"
+ }, $scope.cartModel = function() {
+ return CartModel.cartVO
+ }, $scope.$watch($scope.cartModel, function() {
+ CartModel.cartVO.items && ($scope.obj.numberOfItems = CartModel.cartVO.items.length)
+ }), $scope.loginModel = function() {
+ return LoginModel
+ }, $scope.$watch($scope.loginModel, function() {
+ LoginModel.getLoggedIn() ? $scope.obj.cartButtonStyle = "button-cart-logged-in" : ($scope.obj.cartButtonStyle = "button-cart-logged-out", $scope.obj.numberOfItems = "")
+ }, !0), $scope.onCartButtonClicked = function() {
+ ViewStateService.viewRequested("cart");
+ var ga = {
+ ec: "cart"
+ };
+ AnalyticsService.sendData(ga)
+ }
+}), app.controller("CheckOutController", function($scope, Service, ViewStateModel, CheckOutService, CartModel) {
+ $scope.obj = {
+ show: !1,
+ disabled: !0,
+ info: "",
+ showInfo: !1,
+ subTotalText: "",
+ showVAT: !1,
+ lineStyle: "",
+ totalStyle: "",
+ remainingStyle: "",
+ cartInfoStyle: ""
+ }, $scope.CartModel = function() {
+ return CartModel.cartVO
+ }, $scope.$watch($scope.CartModel, function() {
+ CartModel.cartVO.items && 0 < CartModel.cartVO.items.length ? $scope.obj.disabled = !1 : $scope.obj.disabled = !0
+ }, !0), $scope.$root.$on("checkout complete", function() {
+ $scope.obj.disabled = !1
+ }), $scope.$root.$on("billing info canceled", function() {
+ $scope.obj.disabled = !1
+ }), $scope.viewState = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewState, function() {
+ "cart" === ViewStateModel.getState() ? $scope.obj.show = !0 : $scope.obj.show = !1
+ }, !0), $scope.onClick = function() {
+ $scope.obj.disabled = !0, $scope.$root.$emit("on modal choose billing info requested"), $scope.onOut()
+ }, $scope.onOver = function() {
+ $scope.obj.showInfo = !0, $scope.showData()
+ }, $scope.onOut = function() {
+ $scope.obj.showInfo = !1
+ }, $scope.showData = function() {
+ var data = CartModel.getCartTotal();
+ data && ($scope.obj.subTotalText = data.subtotals.beforeDiscounts, data.vatData.display ? $scope.obj.showVAT = !0 : $scope.obj.showVAT = !1, $scope.obj.showVAT ? ($scope.obj.cartInfoStyle = "cart-info-vat", $scope.obj.lineStyle = "cart-info-line-vat", $scope.obj.totalStyle = "cart-info-total-vat", $scope.obj.remainingStyle = "cart-info-remaining-vat", $scope.obj.vatPerc = data.vatData.percentage, $scope.obj.vat = data.vatData.amount) : ($scope.obj.cartInfoStyle = "cart-info-no-vat", $scope.obj.lineStyle = "cart-info-line-no-vat", $scope.obj.totalStyle = "cart-info-total-no-vat", $scope.obj.remainingStyle = "cart-info-remaining-no-vat"), $scope.obj.credits = data.creditsData.usedSum, $scope.obj.total = data.subtotals.final, $scope.obj.remaining = data.creditsData.remainingSum)
+ }, $scope.$root.$on("alreadyBought", function(event, data) {
+ CheckOutService.onCheckOutRequested(data)
+ }), $scope.$root.$on("ownClips", function(event, data) {
+ CheckOutService.onCheckOutRequested(data)
+ })
+}), app.controller("CollectionsController", function($scope, BinsModel, Service, LoginModel, ViewStateService) {
+ $scope.obj = {}, $scope.obj.showImportAll = !1, $scope.obj.showFooter = !1, $scope.obj.showList = !1, $scope.obj.showBin, $scope.obj.addToBin, $scope.obj.addToBinName = "Collections", $scope.obj.collectionsList = COLLECTIONS_LIST_HTML, $scope.loginModel = function() {
+ return LoginModel.loggedIn
+ }, $scope.$watch($scope.loginModel, function() {
+ LoginModel.loggedIn ? $scope.obj.showFooter = !0 : $scope.obj.showFooter = !1
+ }), $scope.$root.$on("onBins", function(event) {
+ $scope.bins = BinsModel.bins, 0 == BinsModel.bins.length && ($scope.obj.addToBinName = "Collections")
+ }), $scope.$root.$on("active bin changed", function(event) {
+ $scope.obj.addToBin = BinsModel.addToBin, BinsModel.addToBin && ($scope.obj.addToBinName = getAbbrName(BinsModel.addToBin.name, 10))
+ }), $scope.toggleList = function() {
+ $scope.obj.showList = !$scope.obj.showList
+ }, $scope.openList = function() {
+ $scope.obj.showList = !0
+ }, $scope.closeList = function() {
+ $scope.obj.showList = !1
+ }, $scope.deleteIconClicked = function(bin) {
+ $scope.$root.$emit("collection delete requested", [bin])
+ }, $scope.showCollectionIconClicked = function(bin) {
+ BinsModel.showBin = bin, $scope.$root.$emit("bin selected", bin.name), ViewStateService.viewRequested("bins"), $scope.closeList()
+ }, $scope.collectionNameClicked = function(bin) {
+ BinsModel.addToBin = bin, $scope.obj.addToBinName = getAbbrName(bin.name, 10), $scope.closeList(), Service.setActiveBin(BinsModel.addToBin.id)
+ }, $scope.freeItemsClicked = function() {
+ ViewStateService.viewRequested("freebies"), $scope.closeList()
+ }, $scope.onClick = function() {
+ $scope.$root.$emit("select clicked")
+ }, $scope.onAddClicked = function() {
+ $scope.$root.$emit("modal add collection requested")
+ }
+}), app.controller("DownloadAllController", function($scope, ViewStateModel, DownloadBatchService, PurchasesModel, AnalyticsService) {
+ function onStateChange() {
+ "downloads" === ViewStateModel.getState() && PurchasesModel.purchasesVO && PurchasesModel.purchasesVO.items ? $scope.obj.show = !0 : $scope.obj.show = !1
+ }
+ $scope.obj = {
+ show: !1,
+ isDownloading: !1
+ }, $scope.$root.$on("on downloading all purchases complete", function(event) {
+ $scope.$apply(function() {
+ $scope.obj.isDownloading = !1
+ })
+ }), $scope.$root.$on("cancel all requested", function(event) {
+ console.log("DownloadAllController cancel all requested"), $scope.obj.isDownloading = !1
+ }), $scope.$root.$on("on purchases vo", function() {
+ onStateChange()
+ }), $scope.viewState = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewState, onStateChange, !0), $scope.onDownloadAllClicked = function() {
+ console.log("DownloadAllController onDownloadAllClicked"), $scope.obj.isDownloading = !0, DownloadBatchService.onBatchRequested();
+ var ga = {
+ ec: "download%20all"
+ };
+ console.log("DownloadAllController ga", ga), AnalyticsService.sendData(ga)
+ }
+}), app.controller("DownloadProgressController", function($scope, $timeout, ProgressService, DownloadRequestService, DownloadCancelService, ViewStateModel, DownloadModel) {
+ $scope.obj = {
+ items: [],
+ isOpen: !1,
+ progressCloseIcon: PROGRESS_CLOSE_IMG
+ }, $scope.viewStateModel = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewStateModel, function() {
+ $scope.obj.view = ViewStateModel.getState()
+ }), $scope.$root.$on("select clicked", function(event) {
+ $scope.obj.isOpen = !1
+ }), $scope.$root.$on("import all clicked", function(event) {
+ $scope.obj.isOpen = !0
+ }), $scope.$root.$on("open progress", function(event) {
+ $scope.obj.isOpen || ($scope.obj.isOpen = !0)
+ }), $scope.$root.$on("clear progress", function(event) {
+ $scope.obj.items = DownloadModel.itemsDownloadList
+ }), $scope.$root.$on("added to progress", function(event, data) {
+ $scope.obj.items = DownloadModel.itemsDownloadList
+ }), $scope.onProgressIconClicked = function() {
+ $scope.$root.$emit("progress button clicked")
+ }, $scope.$root.$on("progress button clicked", function(event) {
+ $scope.obj.isOpen = !$scope.obj.isOpen
+ }), $scope.clearListClicked = function() {
+ $scope.$root.$emit("progress button clicked"), ProgressService.clearCompleteItems(), 0 < $scope.obj.items.length ? $scope.obj.isOpen = !0 : $scope.obj.isOpen = !1
+ }, $scope.showClear = function() {
+ var show = !1;
+ return $scope.obj.items.forEach(function(item) {
+ item.completed && (show = !0)
+ }), !ProgressService.getDownloadingStatus() && 0 < DownloadModel.itemsDownloadList.length && (show = !0), show
+ }, $scope.isDownloading = function() {
+ var isDownloading = !1;
+ return $scope.obj.items.forEach(function(item) {
+ item.downloading && (isDownloading = !0)
+ }), ProgressService.getDownloadingStatus() && (show = !0), isDownloading
+ }, $scope.showMenu = function() {
+ return 0 < $scope.obj.items.length
+ }, $scope.cancelAllClicked = function() {
+ DownloadCancelService.onCancelAll(), $scope.$root.$emit("cancel all requested")
+ }, $scope.closeClicked = function() {
+ $scope.$root.$emit("progress button clicked"), console.log("DownloadProgressController closeClicked", $scope.obj.isOpen), $scope.obj.isOpen = !1, console.log("DownloadProgressController closeClicked", $scope.obj.isOpen)
+ }, $scope.cancelSingleClicked = function(item) {
+ DownloadCancelService.onCancelSingle(item)
+ }, $scope.hideTooltip = function() {
+ $timeout(function() {
+ $("#clearListButton").trigger("hide")
+ }, 0)
+ }
+}), app.controller("FilterController", function($scope, Service, SearchModel, ViewStateModel, AnalyticsService) {
+ $scope.obj = {
+ filters: ["Best Match", "Popular", "Newest", "Price", "Duration"]
+ }, $scope.caret = {
+ direction: "down"
+ }, $scope.obj.selected = $scope.obj.filters[0], $scope.onChange = function(val) {
+ var sortID;
+ switch (console.log("FilterController changed: ", $scope.obj.selected), $scope.obj.selected = val || $scope.obj.selected, $scope.obj.open = !1, $scope.obj.selected) {
+ case "Best Match":
+ sortID = 1;
+ break;
+ case "ARTIST":
+ sortID = 2;
+ break;
+ case "Newest":
+ sortID = 6;
+ break;
+ case "Duration":
+ sortID = 5;
+ break;
+ case "Popular":
+ sortID = 8;
+ break;
+ case "PAGE VIEWS":
+ sortID = 10;
+ break;
+ case "Price":
+ sortID = 4
+ }
+ console.log("FilterController sortID: ", sortID), SearchModel.filter = sortID, SearchModel.resultType = "replace", SearchModel.page = "0", Service.search(), window.scrollTo(0, 0);
+ var ga = {};
+ ga.ec = "search%20filter%20" + $scope.obj.selected.replace(/ /g, "%20"), ga.label = SearchModel.query, AnalyticsService.sendData(ga)
+ }, $scope.setCurrent = function(val) {
+ $scope.obj.selected = val
+ }, $scope.toggled = function(open) {
+ $scope.obj.direction = open ? "dropup" : "down"
+ }
+}), app.controller("FooterLinksController", function($scope, ViewStateModel, CartModel) {
+ $scope.obj = {
+ show: !1
+ }, $scope.viewState = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewState, function() {
+ "cart" === ViewStateModel.getState() ? $scope.obj.show = !0 : $scope.obj.show = !1
+ }, !0), $scope.onPromoCodeClicked = function() {
+ $scope.$root.$emit("modal promo requested")
+ }
+});
+var FreebiesController = function($scope, ViewStateService, FreebiesModel, ViewStateModel, LoginModel, AnalyticsService) {
+ function onViewStateChange() {
+ console.log("FreebiesController onViewStateChange:", ViewStateModel.getState()), "freebies" === ViewStateModel.getState() && LoginModel.getLoggedIn() ? $scope.obj.show = !0 : $scope.obj.show = !1
+ }
+ $scope.obj = {
+ show: !1
+ }, $scope.viewState = function() {
+ return ViewStateModel.getState()
+ }, $scope.loggedIn = function() {
+ return LoginModel.getLoggedIn()
+ }, $scope.$watch($scope.viewState, onViewStateChange, !0), $scope.$watch($scope.loggedIn, onViewStateChange), $scope.onFreebiesButtonClicked = function() {
+ ViewStateService.viewRequested("freebies"), console.log("FreebiesController onFreebiesButtonClicked");
+ var ga = {
+ ec: "freebies"
+ };
+ console.log("FreebiesController ga", ga), AnalyticsService.sendData(ga)
+ }, $scope.onAddAllFreebiesToCartClicked = function() {
+ var ids = [];
+ FreebiesModel.freebiesVO.items.forEach(function(item) {
+ ids.push(item.id)
+ });
+ var apiObj = {
+ fn: "modifyCart",
+ args: [convertArrayToCommaSeperatedString(ids), ""]
+ };
+ $scope.$root.$emit("api call", apiObj), $scope.$root.$emit("modal add to cart")
+ }
+};
+FreebiesController.$inject = ["$scope", "ViewStateService", "FreebiesModel", "ViewStateModel", "LoginModel", "AnalyticsService"], app.controller("ImportCollectionsController", function($scope, DownloadModel, ViewStateModel, BinsModel) {
+ $scope.obj = {
+ show: !1,
+ isImporting: !1
+ }, $scope.$root.$on("on importing bin complete", function(event) {
+ console.log("ImportCollectionsController on importing bin complete"), $scope.$apply(function() {
+ $scope.obj.isImporting = !1
+ })
+ }), $scope.viewState = function() {
+ return ViewStateModel.getState()
+ }, $scope.binsModel = function() {
+ return BinsModel.binVO
+ }, $scope.$watch($scope.viewState, function() {
+ "bins" === ViewStateModel.getState() ? $scope.obj.show = !0 : $scope.obj.show = !1
+ }, !0), $scope.$watch($scope.binsModel, function() {
+ "bins" === ViewStateModel.getState() && ($scope.obj.show = !0, 0 < BinsModel.binVO.items.length ? $scope.obj.isImporting = !1 : $scope.obj.isImporting = !0)
+ }, !0), $scope.onImportAllClicked = function() {
+ $scope.obj.isImporting = !0, $scope.$root.$emit("download requested", BinsModel.binVO.items), $scope.$root.$emit("import all clicked")
+ }
+}), app.controller("IntroAssetsController", function($scope) {
+ $scope.obj = {
+ state: 0,
+ stateName: ""
+ }, $scope.$root.$on("intro asset requested", function(event, stateObj) {
+ $scope.obj.stateName = stateObj.stateName, console.log("IntroAssetsController stateName", $scope.obj.stateName);
+ var fromX, toX, fromY, toY, currArrow = stateObj.arrowClass;
+ switch (currArrow) {
+ case ".intro-asset-arrow-up":
+ fromY = 20, toY = 0;
+ break;
+ case ".intro-asset-arrow-left":
+ fromX = 20, toX = 0;
+ break;
+ case ".intro-asset-arrow-down":
+ fromY = 0, toY = 20
+ }
+ "" != currArrow && ($(currArrow).css("top", "").css("left", "").css("bottom", ""), $(currArrow).css(stateObj.posX[0], stateObj.posX[1]), $(currArrow).css(stateObj.posY[0], stateObj.posY[1]), $(".intro-asset-arrow").velocity("stop"), $scope.loop(currArrow, fromX, toX, fromY, toY))
+ }), $scope.loop = function(target, fromX, toX, fromY, toY) {
+ $(target).velocity({
+ translateX: [fromX, toX],
+ translateY: [fromY, toY]
+ }, {
+ duration: 1e3,
+ loop: !0
+ })
+ }
+}), app.controller("ListItemController", function($scope, VersionsModel, ViewStateModel) {
+ $scope.obj = {}, $scope.deleteIconClicked = function() {
+ var apiObj = {
+ fn: "modifyCart",
+ args: ["", $scope.item.id]
+ };
+ $scope.$root.$emit("api call", apiObj)
+ }, $scope.versionButtonClicked = function() {
+ VersionsModel.setVersions($scope.item.versions)
+ }, $scope.imageHovered = function(e) {
+ var item;
+ "cart" == ViewStateModel.getState() ? item = $scope.item : "downloads" == ViewStateModel.getState() && (item = $scope.item.versions[0]), $scope.$root.$emit("start preview", item)
+ }, $scope.imageLeft = function(item) {
+ $scope.$root.$emit("stop preview", item)
+ }
+}), app.controller("ListCartController", function($scope, CartModel) {
+ $scope.obj = {}, $scope.cartItems = function() {
+ return CartModel
+ }, $scope.$watchCollection($scope.cartItems, function() {
+ CartModel.cartVO && ($scope.obj.items = CartModel.cartVO.items)
+ })
+}), app.controller("ListDownloadsController", function($scope, PurchasesModel) {
+ $scope.obj = {}, $scope.purchasedItems = function() {
+ return PurchasesModel
+ }, $scope.$watchCollection($scope.purchasedItems, function() {
+ PurchasesModel.purchasesVO && (console.log("ListController onPurchasesModelChange: ", PurchasesModel.purchasesVO.items), $scope.obj.items = PurchasesModel.purchasesVO.items)
+ })
+}), app.controller("LoginController", function($scope, LoginModel, UserModel) {
+ $scope.obj = {
+ loggedIn: !1,
+ logo: LOGO_IMG,
+ logoStyle: "logo-reg"
+ }, $scope.loginModel = function() {
+ return LoginModel
+ }, $scope.userModel = function() {
+ return UserModel
+ }, $scope.$watch($scope.loginModel, function() {
+ void 0 === LoginModel.getLoggedIn() ? $scope.obj.loggedIn = $scope.obj.loggedIn : $scope.obj.loggedIn = LoginModel.getLoggedIn();
+ $scope.obj.loggedIn && ($scope.obj.avatarURL = UserModel.getAvatarURL());
+ !1 === LoginModel.getLoggedIn() || void 0 === LoginModel.getLoggedIn() ? $scope.obj.row_top_style = "row-top-loggedout" : $scope.obj.row_top_style = "row-top-loggedin"
+ }, !0), $scope.$watch($scope.userModel, function() {
+ $scope.obj.avatarURL = UserModel.getAvatarURL(), 0 < THIRD_PARTY.length && ($scope.obj.logo = BASE_URL + "pond5_shared/images/" + THIRD_PARTY + ".png", $scope.obj.logoStyle = "logo-tp")
+ }, !0), $scope.loginRequested = function() {
+ $scope.$root.$emit("modal login requested")
+ }, $scope.logoutClicked = function() {
+ $scope.$root.$emit("modal logout requested")
+ }
+}), app.controller("MainViewController", function($scope, ViewStateModel, SearchModel) {
+ $scope.obj = {
+ tilesClass: "main-content"
+ }, $scope.$root.$on("filters button clicked", function(event, state) {
+ $scope.obj.tilesClass = state ? (ViewStateModel.setState("search"), "main-content-advanced-search") : "main-content"
+ }), $scope.$root.$on("advanced search close requested", function(event) {
+ $scope.obj.tilesClass = "main-content"
+ }), $scope.viewState = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewState, function() {
+ "search" === ViewStateModel.getState() && "add" === SearchModel.resultType ? console.log("MainViewController, do not scroll to top") : window.scrollTo(0, 0);
+ "cart" !== ViewStateModel.getState() && "downloads" !== ViewStateModel.getState() || ($scope.obj.tilesClass = "main-content");
+ $scope.obj.state = ViewStateModel.getState()
+ }, !0)
+});
+var MenuController = function($scope, ViewStateService, AnalyticsService) {
+ $scope.states = ["default", "hover", "selected"], $scope.btn0 = {
+ state: $scope.states[2],
+ selected: !0
+ }, $scope.btn1 = {
+ state: $scope.states[0],
+ selected: !1
+ }, $scope.btn2 = {
+ state: $scope.states[0],
+ selected: !1
+ }, $scope.btn3 = {
+ state: $scope.states[0],
+ selected: !1
+ }, $scope.buttons = [$scope.btn0, $scope.btn1, $scope.btn2, $scope.btn3], $scope.click = function(button) {
+ console.log("MenuController clicked ", button), $scope.selected = button;
+ for (var i = 0; i < $scope.buttons.length - 1; i++) button === $scope.buttons[i] ? ($scope.buttons[i].selected = !0, $scope.buttons[i].state = $scope.states[2]) : button != $scope.buttons[3] && ($scope.buttons[i].selected = !1, $scope.buttons[i].state = $scope.states[0]);
+ var view;
+ switch (button) {
+ case $scope.buttons[0]:
+ view = "search";
+ break;
+ case $scope.buttons[1]:
+ view = "downloads";
+ break;
+ case $scope.buttons[2]:
+ view = "previews";
+ break;
+ case $scope.buttons[3]:
+ view = "settings"
+ }
+ console.log("MenuController clicked view ", view), $scope.requestView(view)
+ }, $scope.requestView = function(view) {
+ "settings" === view ? $scope.$root.$emit("modal add destination requested") : ViewStateService.viewRequested(view);
+ var ga = {};
+ ga.ec = view, console.log("MenuController ga", ga), AnalyticsService.sendData(ga)
+ }, $scope.over = function(button) {
+ console.log("MenuController over ", button), button.selected || (button.state = $scope.states[1])
+ }, $scope.out = function(button) {
+ console.log("MenuController over ", button), button.selected || (button.state = $scope.states[0])
+ }
+};
+MenuController.$inject = ["$scope", "ViewStateService", "AnalyticsService"], app.controller("MessageController", function($scope, ViewStateModel) {
+ $scope.obj = {
+ show: !1
+ }, $scope.$root.$on("message view requested", function(event, show, data, list, imgUrl) {
+ $scope.obj.title = null, $scope.obj.messageList = null, $scope.obj.message = null, $scope.obj.imgUrl = null, $scope.obj.showImg = !1, ($scope.obj.show = show) && ($scope.obj.title = data[0], list ? $scope.obj.messageList = data[1] : $scope.obj.message = data[1], 2 === data.length ? $scope.obj.label = "OK" : $scope.obj.label = data[2], imgUrl && ($scope.obj.imgUrl = imgUrl, $scope.obj.showImg = !0))
+ }), $scope.viewStateModel = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewStateModel, function() {
+ "search" !== ViewStateModel.getState() && ($scope.obj.show = !1)
+ })
+}), app.controller("ModalAddCollectionConfirmationController", function($scope, $uibModal, BinsModel) {
+ $scope.items = [], $scope.$root.$on("collection created", function(event, data) {
+ console.log("ModalAddCollectionConfirmationController event handler", data), $scope.open("sm")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_ADD_COLLECTION_CONFIRMATION_HTML,
+ controller: ModalAddCollectionConfirmationInstanceCtrl,
+ size: size,
+ resolve: {
+ items: function() {
+ return $scope
+ }
+ }
+ }).result.then(function() {
+ console.log("ModalAddCollectionConfirmationController OK")
+ }, function() {
+ console.log("ModalAddCollectionConfirmationController CANCELED")
+ })
+ }
+});
+var ModalAddCollectionConfirmationInstanceCtrl = function($scope, $uibModalInstance, items, BinsModel) {
+ $scope.obj = {
+ title: "Complete!",
+ messagePre: "Your collection '",
+ messagePost: "' was succesfully created",
+ newBinName: BinsModel.newBinName
+ }, $scope.ok = function() {
+ $uibModalInstance.dismiss("cancel")
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalAddCollectionController", function($scope, $uibModal, Service, UserModel, BinsModel) {
+ $scope.items = [], $scope.$root.$on("modal add collection requested", function(event) {
+ console.log("ModalAddCollectionController event handler"), $scope.open("sm")
+ }), $scope.open = function(size) {
+ var modalInstance = $uibModal.open({
+ templateUrl: MODAL_ADD_COLLECTION_HTML,
+ controller: ModalAddCollectionInstanceCtrl,
+ size: size,
+ windowClass: "modal-small",
+ resolve: {
+ items: function() {
+ return $scope
+ }
+ }
+ });
+ modalInstance.result.then(function() {
+ console.log("ModalAddCollectionController OK")
+ }, function() {
+ console.log("ModalAddCollectionController CANCELED")
+ }), modalInstance.result.then(function(result) {}, function(result) {})
+ }
+});
+var ModalAddCollectionInstanceCtrl = function($scope, $uibModalInstance, items, Service, BinsModel) {
+ $scope.obj = {
+ showMessage: !1
+ }, $scope.create = function() {
+ console.log("ModalAddCollectionInstanceCtrl bin name: ", document.getElementById("addCollectionInput").value);
+ var binName = document.getElementById("addCollectionInput").value;
+ 1 < binName.length && ($uibModalInstance.close(), BinsModel.newBinName = binName, Service.createBin(binName))
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalAddToCartController", function($scope, $uibModal, Service, ViewStateService) {
+ $scope.$root.$on("modal add to cart", function(event) {
+ console.log("ModalAddToCartController event handler"), $scope.open("sm")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_ADD_TO_CART_HTML,
+ controller: ModalAddToCartInstanceCtrl,
+ size: size
+ }).result.then(function() {
+ console.log("ModalAddToCartController proceed"), ViewStateService.viewRequested("cart")
+ }, function() {
+ console.log("ModalAddToCartController later")
+ })
+ }
+});
+var ModalAddToCartInstanceCtrl = function($scope, $uibModalInstance) {
+ $scope.onProceed = function() {
+ console.log("ModalAddToCartInstanceCtrl onProceed"), $uibModalInstance.close()
+ }, $scope.onCancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalBillingAddressController", function($scope, $uibModal) {
+ $scope.obj = {}, $scope.$root.$on("modal billing address requested", function(event) {
+ console.log("ModalBillingAddressController event handler"), $scope.open("lg")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_BILLING_ADDRESS_HTML,
+ controller: ModalBillingAddressInstanceCtrl,
+ size: size,
+ windowClass: "modal-billing-address",
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ }
+ }).result.then(function() {
+ console.log("ModalBillingAddressController OK")
+ }, function() {
+ console.log("ModalBillingAddressController CANCELED"), $scope.$root.$emit("billing info canceled")
+ })
+ }
+});
+var ModalBillingAddressInstanceCtrl = function($scope, $uibModalInstance, obj, Service) {
+ $scope.firstName = "", $scope.lastName = "", $scope.street1 = "", $scope.street2 = "", $scope.province = "", $scope.zipCode = "", $scope.city = "", $scope.state = "", $scope.country = "", $scope.error = !1, $scope.countries = COUNTRIES, $scope.states = STATES, $scope.submit = function(myForm) {
+ if (console.log("ModalBillingAddressInstanceCtrl ok: ", myForm.firstName.$modelValue, myForm.lastName.$modelValue), console.log("ModalBillingAddressInstanceCtrl form valid: ", myForm.$valid), myForm.$valid) {
+ var stateCode;
+ stateCode = "" == myForm.state.$modelValue ? "" : myForm.state.$modelValue.code;
+ var data = {
+ country: myForm.country.$modelValue.code,
+ firstName: myForm.firstName.$modelValue,
+ lastName: myForm.lastName.$modelValue,
+ organization: myForm.organization.$modelValue,
+ department: myForm.department.$modelValue,
+ companyID: myForm.companyID.$modelValue,
+ vatID: myForm.vatID.$modelValue,
+ street1: myForm.street1.$modelValue,
+ street2: myForm.street2.$modelValue,
+ province: myForm.province.$modelValue,
+ zipCode: myForm.zipCode.$modelValue,
+ city: myForm.city.$modelValue,
+ state: stateCode
+ };
+ console.log("ModalBillingAddressInstanceCtrl DATA", data);
+ var apiObj = {
+ fn: "setBillingAddress",
+ args: [data]
+ };
+ $scope.$root.$emit("api call", apiObj), $uibModalInstance.dismiss()
+ } else console.log("ModalBillingAddressInstanceCtrl form is not valid"), $scope.error = !0
+ }, $scope.close = function() {
+ $uibModalInstance.dismiss()
+ }, $scope.back = function() {
+ $uibModalInstance.dismiss(), $scope.$root.$emit("on modal choose billing info requested")
+ }
+};
+app.controller("ModalBuyCreditsController", function($scope, $uibModal, ViewStateModel) {
+ $scope.obj = {}, $scope.$root.$on("modal buy credits requested", function() {
+ console.log("ModalBuyCreditsController event handler"), $scope.obj.title = "", $scope.obj.message = "As a reminder, only credits purchased in $USD can be used in this Add-on.";
+ $scope.open("sm")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_BUY_CREDITS_HTML,
+ controller: ModalBuyCreditsInstanceCtrl,
+ size: size,
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ },
+ windowClass: "modal-small"
+ }).result.then(function() {
+ console.log("ModalBuyCreditsController OK"), ViewStateModel.allowPreviews = !0, opn("https://www.pond5.com/credit-packages")
+ }, function() {
+ console.log("ModalBuyCreditsController CANCELED")
+ })
+ }
+});
+var ModalBuyCreditsInstanceCtrl = function($scope, $uibModalInstance, obj) {
+ $scope.obj = {}, $scope.obj.message = obj.message, $scope.obj.title = obj.title, $scope.ok = function() {
+ console.log("ModalBuyCreditsInstanceCtrl OK"), $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel"), console.log("ModalBuyCreditsInstanceCtrl cancel")
+ }
+};
+app.controller("ModalChooseBillingInfoController", function($scope, $uibModal, BillingInfoModel, CheckOutService, Service) {
+ $scope.items = [], $scope.obj = {}, $scope.$root.$on("on modal choose billing info requested", function(event) {
+ console.log("ModalChooseBillingInfoController event handler: ", BillingInfoModel.getBillingInfo()), $scope.items = BillingInfoModel.getBillingInfo(), $scope.open("lg")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_CHOOSE_BILLING_INFO_HTML,
+ controller: ModalChooseBillingInfoInstanceCtrl,
+ windowClass: "modal-choose-billing",
+ size: size,
+ resolve: {
+ items: function() {
+ return $scope.items
+ }
+ }
+ }).result.then(function(item) {
+ console.log("ModalChooseBillingInfoController ok, selected: ", item.addressid), CheckOutService.onCheckOutRequested()
+ }, function() {
+ console.log("ModalChooseBillingInfoController dismissed"), $scope.$root.$emit("billing info canceled")
+ })
+ }
+});
+var ModalChooseBillingInfoInstanceCtrl = function($scope, $uibModalInstance, items, BillingInfoModel, Service) {
+ console.log("ModalChooseBillingInfoInstanceCtrl items", items), console.log("ModalChooseBillingInfoInstanceCtrl default", BillingInfoModel.getDefaultInfo()), $scope.items = items, $scope.selected = BillingInfoModel.getDefaultInfo(), $scope.adyenEncryption = "https://plugin.pond5.com/pond5_shared/images/adyen-encryption.png", $scope.onRbClicked = function(item) {
+ $scope.selected = item, console.log("ModalChooseBillingInfoInstanceCtrl rb > default", item), BillingInfoModel.setDefaultInfo(item), Service.getCartTotal()
+ }, $scope.onOKClicked = function() {
+ $uibModalInstance.close($scope.selected)
+ }, $scope.close = function() {
+ $uibModalInstance.dismiss()
+ }, $scope.addNewClicked = function() {
+ $uibModalInstance.dismiss(), $scope.$root.$emit("modal billing address requested")
+ }, $scope.readAgreement = function() {
+ console.log("ModalChooseBillingInfoInstanceCtrl readAgreement"), opn("https://www.pond5.com/legal/license")
+ }, $scope.helpCenter = function() {
+ opn("https://help.pond5.com/hc/en-us/")
+ }, $scope.callUs = function() {
+ opn("https://help.pond5.com/hc/en-us/requests/new")
+ }
+};
+app.controller("ModalChooseFormatController", function($scope, $uibModal) {
+ $scope.items = [], $scope.$root.$on("on add to cart clicked", function(event, formats) {
+ console.log("ModalChooseFormatController handler, formats: ", formats), $scope.items = [], $scope.items = formats, $scope.open("sm")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_CHOOSE_FORMAT_HTML,
+ controller: ModalChooseFormatInstanceCtrl,
+ size: size,
+ windowClass: "modal-small",
+ resolve: {
+ items: function() {
+ return $scope.items
+ }
+ }
+ }).result.then(function() {}, function() {
+ console.log("ModalChooseFormatController dismissed")
+ })
+ }
+});
+var ModalChooseFormatInstanceCtrl = function($scope, $uibModalInstance, items, Service) {
+ $scope.items = items, $scope.items[0].selected = !0, $scope.onRbClicked = function(item, index) {
+ console.log("ModalChooseFormatInstanceCtrl onRbClicked: " + item + "-" + index);
+ for (var i = 0; i < $scope.items.length; i++) $scope.items[i].selected = index === i
+ }, $scope.onAddToCartClicked = function() {
+ for (var i = 0; i < $scope.items.length; i++)
+ if ($scope.items[i].selected) {
+ var item = $scope.items[i],
+ apiObj = {
+ fn: "modifyCart",
+ args: [item.id + ":" + item.offset]
+ };
+ $scope.$root.$emit("api call", apiObj)
+ } $uibModalInstance.dismiss()
+ }
+};
+app.controller("ModalChooseVersionController", function($scope, $uibModal, Service, DownloadModel) {
+ $scope.items = [], $scope.$root.$on("on versions selected", function(event, versions) {
+ console.log("ModalChooseVersionController event handler: ", $scope.items, versions), $scope.items = [], $scope.items = versions, $scope.open("sm")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_CHOOSE_VERSION_HTML,
+ controller: ModalChooseVersionInstanceCtrl,
+ size: size,
+ resolve: {
+ items: function() {
+ return $scope.items
+ }
+ },
+ windowClass: "modal-small"
+ }).result.then(function(selectedIndex) {
+ var selectedItem = $scope.items[selectedIndex];
+ DownloadModel.selectedVersion = selectedIndex, Service.getPurchaseURL(selectedItem.id, selectedItem.transactionID, selectedItem.versionID, selectedItem.version)
+ }, function() {
+ console.log("ModalChooseVersionController dismissed")
+ })
+ }
+});
+var ModalChooseVersionInstanceCtrl = function($scope, $uibModalInstance, items) {
+ $scope.items = items, $scope.selected = $scope.items[0], $scope.selectedIndex = 0, $scope.onRbClicked = function(index) {
+ $scope.selected = $scope.items[index], $scope.selectedIndex = index
+ }, $scope.ok = function() {
+ $uibModalInstance.close($scope.selectedIndex)
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalClearCartConfirmationController", function($scope, $uibModal) {
+ $scope.obj = [], $scope.$root.$on("clear cart requested", function(event, data, size) {
+ console.log("ModalClearCartConfirmationController event handler", data), $scope.obj.title = "Clear My Cart", $scope.obj.message = "Are you sure you want to clear your cart?", $scope.obj.itemsToDelete = data[0], $scope.obj.label = "CLEAR", $scope.obj.showButtonLeft = !0, $scope.obj.labelLeft = "CANCEL", size = size || "sm", $scope.open(size)
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_SIMPLE_HTML,
+ controller: ModalClearCartConfirmationInstanceCtrl,
+ size: size,
+ windowClass: "modal-small",
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ }
+ }).result.then(function() {
+ console.log("ModalClearCartConfirmationController OK");
+ var apiObj = {
+ fn: "modifyCart",
+ args: ["", $scope.obj.itemsToDelete]
+ };
+ $scope.$root.$emit("api call", apiObj)
+ }, function() {
+ console.log("ModalClearCartConfirmationController CANCELED")
+ })
+ }
+});
+var ModalClearCartConfirmationInstanceCtrl = function($scope, $uibModalInstance, obj) {
+ $scope.obj = {}, $scope.obj.message = obj.message, $scope.obj.title = obj.title, $scope.obj.label = obj.label, $scope.obj.showButtonLeft = !0, $scope.obj.labelLeft = "CANCEL", $scope.ok = function() {
+ $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalDeleteCollectionConfirmationController", function($scope, $uibModal, Service, ViewStateModel, BinsModel, ViewStateService) {
+ $scope.obj = {}, $scope.$root.$on("collection delete requested", function(event, data, size) {
+ console.log("ModalDeleteCollectionConfirmationController event handler", data, data.length, size), $scope.obj.title = "Delete Collection", $scope.obj.message = "Are you sure you want to delete the collection " + data[0].name + " ?", $scope.obj.bin = data[0], $scope.obj.label = "DELETE", $scope.obj.showButtonLeft = !0, $scope.obj.labelLeft = "CANCEL", size = size || "sm", $scope.open(size)
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_SIMPLE_HTML,
+ controller: ModalDeleteCollectionConfirmationInstanceCtrl,
+ size: size,
+ windowClass: "modal-small",
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ }
+ }).result.then(function() {
+ BinsModel.selectedBin == $scope.obj.bin && ViewStateService.viewRequested("search"), Service.removeBin($scope.obj.bin.id), ViewStateModel.allowPreviews = !0
+ }, function() {})
+ }
+});
+var ModalDeleteCollectionConfirmationInstanceCtrl = function($scope, $uibModalInstance, obj) {
+ $scope.obj = {}, $scope.obj.message = obj.message, $scope.obj.title = obj.title, $scope.obj.label = obj.label, $scope.obj.showButtonLeft = !0, $scope.obj.labelLeft = "CANCEL", $scope.ok = function() {
+ $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalFreebiesController", function($scope, $uibModal, ViewStateService) {
+ $scope.$root.$on("modal freebies", function(event) {
+ console.log("ModalFreebiesController event handler"), $scope.open("lg")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_FREEBIES_HTML,
+ controller: ModalFreebiesInstanceCtrl,
+ size: size
+ }).result.then(function() {
+ console.log("ModalFreebiesController OK"), ViewStateService.viewRequested("freebies")
+ }, function() {
+ console.log("ModalFreebiesController dismissed")
+ })
+ }
+});
+var ModalFreebiesInstanceCtrl = function($scope, $uibModalInstance) {
+ $scope.ok = function() {
+ $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalLoginController", function($scope, $uibModal) {
+ $scope.obj = {}, $scope.$root.$on("modal login requested", function(event) {
+ console.log("ModalLoginController event handler"), $scope.open("lg")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_LOGIN_HTML,
+ controller: ModalLoginInstanceCtrl,
+ size: size,
+ windowClass: "modal-small",
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ }
+ }).result.then(function() {
+ console.log("ModalLoginController OK")
+ }, function() {
+ console.log("ModalLoginController CANCELED")
+ })
+ }
+});
+var ModalLoginInstanceCtrl = function($scope, $uibModalInstance, obj) {
+ $scope.obj = {}, $scope.obj.userName = obj.userName, $scope.obj.password = obj.password, $scope.obj.showTitle = !0, $scope.obj.showClose = !0, $scope.loginRequested = function() {
+ $uibModalInstance.close();
+ var apiObj = {
+ fn: "login",
+ args: [$scope.obj.userName, $scope.obj.password]
+ };
+ $scope.$root.$emit("api call", apiObj)
+ }, $scope.close = function() {
+ $uibModalInstance.dismiss("cancel")
+ }, $scope.signUp = function() {
+ opn("https://www.pond5.com/login")
+ }
+};
+app.controller("ModalLogoutConfirmationController", function($scope, $uibModal, Service, ViewStateModel) {
+ $scope.obj = {}, $scope.$root.$on("modal logout requested", function(event, data, size) {
+ console.log("ModalLogoutConfirmationController event handler"), $scope.obj.title = "Log out", $scope.obj.message = "Are you sure you want to log out?", $scope.obj.label = "YES", $scope.obj.showButtonLeft = !0, $scope.obj.labelLeft = "CANCEL", size = size || "sm", $scope.open(size)
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_SIMPLE_HTML,
+ controller: ModalLogoutConfirmationInstanceCtrl,
+ size: size,
+ windowClass: "modal-small",
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ }
+ }).result.then(function() {
+ Service.logout(), ViewStateModel.allowPreviews = !0
+ }, function() {})
+ }
+});
+var ModalLogoutConfirmationInstanceCtrl = function($scope, $uibModalInstance, obj) {
+ $scope.obj = {}, $scope.obj.message = obj.message, $scope.obj.title = obj.title, $scope.obj.label = obj.label, $scope.obj.showButtonLeft = !0, $scope.obj.labelLeft = "CANCEL", $scope.ok = function() {
+ $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalNotLoggedInController", function($scope, $uibModal) {
+ $scope.obj = {}, $scope.$root.$on("modal not logged in", function(event, data) {
+ $scope.obj.title = data[0], $scope.obj.message = "You're not logged in", $scope.open("lg")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_NOT_LOGGED_IN_HTML,
+ controller: ModalNotLoggedInInstanceCtrl,
+ size: size,
+ windowClass: "modal-small",
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ }
+ }).result.then(function() {
+ console.log("ModalNotLoggedInController OK")
+ }, function() {
+ console.log("ModalNotLoggedInController CANCELED")
+ })
+ }
+});
+var ModalNotLoggedInInstanceCtrl = function($scope, $uibModalInstance, obj) {
+ $scope.obj = {}, $scope.obj.message = obj.message, $scope.obj.title = obj.title, $scope.loginRequested = function() {
+ $uibModalInstance.dismiss("cancel"), $scope.$root.$emit("modal login requested")
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }, $scope.signUp = function() {
+ opn("https://www.pond5.com/login")
+ }
+};
+app.controller("ModalPromoCodeController", function($scope, $uibModal, Service, UserModel) {
+ $scope.items = [], $scope.obj = {
+ label: "APPLY",
+ onlyNumbers: /^\d+$/
+ }, $scope.$root.$on("modal promo requested", function(event) {
+ console.log("ModalPromoCodeController event handler"), $scope.open("sm")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_PROMO_CODE_HTML,
+ controller: ModalPromoCodeInstanceCtrl,
+ size: size,
+ windowClass: "modal-small",
+ resolve: {
+ items: function() {
+ return $scope
+ }
+ }
+ }).result.then(function() {
+ console.log("ModalPromoCodeController OK")
+ }, function() {
+ console.log("ModalPromoCodeController CANCELED")
+ })
+ }
+});
+var ModalPromoCodeInstanceCtrl = function($scope, $uibModalInstance, items, Service, $filter) {
+ $scope.obj = {
+ showMessage: !1,
+ label: "APPLY",
+ onlyNumbers: /^\d+$/
+ }, $scope.$root.$on("promo code added", function(event, data) {
+ var message;
+ console.log("ModalPromoCodeController event handler", data), message = data.commands[0].sum ? $filter("currency")(data.commands[0].sum) + " were succesfully added to your account!" : "Invalid code. Please try again or contact Pond5.", $scope.obj.credits = data, $scope.obj.showMessage = !0, $scope.obj.message = message, $scope.obj.label = "OK"
+ }), $scope.codeApplied = function() {
+ if (console.log("ModalPromoCodeInstanceCtrl codeApplied: ", document.getElementById("promoInput").value), "OK" == $scope.obj.label) $uibModalInstance.close();
+ else {
+ var code = document.getElementById("promoInput").value;
+ 1 < code.length && Service.promoRedeem(code)
+ }
+ }, $scope.ok = function() {
+ console.log("ModalPromoCodeInstanceCtrl OK"), $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalRemoveCollectionController", function($scope, $uibModal, Service, BinsModel, ViewStateModel) {
+ $scope.items = [], $scope.showModal = function() {
+ return BinsModel.showModal
+ }, $scope.$root.$on("modal remove collection requested", function(event) {
+ console.log("ModalRemoveCollectionController remove collection requested event handler", BinsModel.showModal, BinsModel.clipClicked), $scope.items = BinsModel.bins, 0 < $scope.items.length && $scope.open()
+ }), $scope.$root.$on("collection removed", function(event) {
+ console.log("ModalAddCollectionController collection removed event handler")
+ }), $scope.open = function(size) {
+ var modalInstance = $uibModal.open({
+ templateUrl: MODAL_REMOVE_COLLECTION_HTML,
+ controller: ModalRemoveCollectionInstanceCtrl,
+ windowClass: "modal-fit",
+ resolve: {
+ items: function() {
+ return $scope.items
+ }
+ }
+ });
+ $scope.resetBins = function() {
+ BinsModel.showModal = !1;
+ for (var i = 0; i < $scope.items.length; i++) $scope.items[i].selected = !1
+ }, modalInstance.result.then(function() {
+ console.log("OK: ", BinsModel.clipClicked, $scope.items);
+ for (var i = 0; i < $scope.items.length; i++) $scope.items[i].selected && (console.log("ModalRemoveCollectionController selected bin:", $scope.items[i].id), Service.removeBin($scope.items[i].id));
+ $scope.resetBins(), ViewStateModel.allowPreviews = !0
+ }, function() {
+ $scope.resetBins()
+ })
+ }
+});
+var ModalRemoveCollectionInstanceCtrl = function($scope, $uibModalInstance, items) {
+ $scope.items = items, $scope.ok = function() {
+ $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalReplaceController", function($scope, $uibModal, ReplaceModel, ReplaceServiceShared) {
+ $scope.items = [], $scope.$root.$on("modal replace", function(event, items) {
+ console.log("ModalReplaceController event handler: ", items), $scope.items = items, $scope.open("lg")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_REPLACE_HTML,
+ controller: ModalReplaceInstanceCtrl,
+ size: size,
+ resolve: {
+ items: function() {
+ return $scope.items
+ }
+ },
+ windowClass: "modal-replace"
+ }).result.then(function() {
+ ReplaceServiceShared.onModalReplaceOK()
+ }, function() {
+ ReplaceModel.setState(DEFAULT)
+ })
+ }
+});
+var ModalReplaceInstanceCtrl = function($scope, $uibModalInstance, items) {
+ $scope.obj = {
+ checkIcon: "https://plugin.pond5.com/pond5_shared/images/check-icon.png",
+ modalHeader: MODAL_REPLACE_HEADER,
+ modalContent: MODAL_REPLACE_CONTENT,
+ resTitle: MODAL_REPLACE_RES_TITLE
+ }, $scope.items = items;
+ for (var i = 0; i < $scope.items.length; i++) {
+ $scope.items[i].selected = !0;
+ for (var j = 0; j < $scope.items[i].formats.length; j++) console.log("ModalReplaceInstanceCtrl incart: ", $scope.items[i].formats[j].inDownloads), $scope.items[i].formats[j].inDownloads && ($scope.items[i].formats.length = 0), 0 < $scope.items[i].formats.length && $scope.items[i].formats[j].inCart && ($scope.items[i].formats[j].selected = !0, $scope.items[i].oneFormatInCart = !0);
+ !$scope.items[i].oneFormatInCart && 0 < $scope.items[i].formats.length && ($scope.items[i].formats[0].selected = !0)
+ }
+ $scope.selectAllClicked = function() {
+ var item;
+ console.log("ModalReplaceInstanceCtrl selectAllClicked: ", $scope.obj.selectAll);
+ for (var i = 0; i < $scope.items.length; i++) item = $scope.items[i], !$scope.obj.selectAll || item.inCart || item.inDownloads ? item.selected = !0 : item.selected = !1
+ }, $scope.onRbClicked = function(item, index) {
+ console.log("ModalReplaceInstanceCtrl onRbClicked: " + item.name + "-" + item.selected);
+ for (var i = 0; i < item.formats.length; i++) item.formats[i].selected = index === i
+ }, $scope.onCbClicked = function(item, index) {
+ console.log("ModalReplaceInstanceCtrl onCbClicked: " + item.name + "-" + item.selected), item.selected = !item.selected;
+ for (var i = 0; i < item.formats.length; i++) item.formats[i].selected = index === i;
+ console.log("ModalReplaceInstanceCtrl onCbClicked after toggle: " + item.name + "-" + item.selected)
+ }, $scope.ok = function() {
+ $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalReplaceWarningController", function($scope, $uibModal, Service, DownloadModel, ViewStateService, ReplaceModel) {
+ $scope.obj = {}, $scope.obj.requestedState = "", $scope.$root.$on("modal replace warning", function(event, viewState) {
+ console.log("ModalReplaceWarningController event handler, event: ", event), console.log("ModalReplaceWarningController event handler, viewState: ", viewState), $scope.obj.requestedState = viewState, $scope.obj.message = "Visiting the " + viewState + " view will cancel the process of replacing your lo-res previews with hi-res clips. Are you sure you want to visit the " + viewState + " view?", $scope.open("sm")
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_REPLACE_WARNING_HTML,
+ controller: ModalReplaceWarningInstanceCtrl,
+ size: size,
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ },
+ windowClass: "modal-small"
+ }).result.then(function() {
+ ViewStateService.onViewApproved(!0)
+ }, function() {
+ console.log("ModalReplaceWarningController CANCELED"), ViewStateService.onViewApproved(!1)
+ })
+ }
+});
+var ModalReplaceWarningInstanceCtrl = function($scope, $uibModalInstance, obj) {
+ $scope.obj = {}, $scope.obj.message = obj.message, $scope.ok = function() {
+ $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("ModalSimpleController", function($scope, $uibModal, Service, DownloadModel, ViewStateModel) {
+ $scope.obj = {
+ imgUrl: "",
+ showImg: !1
+ }, $scope.$root.$on("modal simple requested", function(event, data, size, list, imgUrl) {
+ var windowClass;
+ $scope.obj.title = null, $scope.obj.messageList = null, $scope.obj.message = null, $scope.obj.imgUrl = null, $scope.obj.showImg = !1, list ? $scope.obj.messageList = data[1] : $scope.obj.message = data[1], 2 === data.length ? $scope.obj.label = "OK" : $scope.obj.label = data[2], imgUrl && ($scope.obj.imgUrl = imgUrl, $scope.obj.showImg = !0), "sm" === size ? windowClass = "modal-small" : "lg" === size && (windowClass = "modal-large"), $scope.open(windowClass)
+ }), $scope.open = function(size) {
+ $uibModal.open({
+ templateUrl: MODAL_SIMPLE_HTML,
+ controller: ModalSimpleInstanceCtrl,
+ windowClass: size,
+ resolve: {
+ obj: function() {
+ return $scope.obj
+ }
+ }
+ }).result.then(function() {
+ ViewStateModel.allowPreviews = !0
+ }, function() {})
+ }
+});
+var ModalSimpleInstanceCtrl = function($scope, $uibModalInstance, obj) {
+ $scope.obj = {}, $scope.obj.message = obj.message, $scope.obj.messageList = obj.messageList, $scope.obj.title = obj.title, $scope.obj.label = obj.label, $scope.obj.imgUrl = obj.imgUrl, $scope.ok = function() {
+ $uibModalInstance.close()
+ }, $scope.cancel = function() {
+ $uibModalInstance.dismiss("cancel")
+ }
+};
+app.controller("PreviewAudioController", function($scope, ViewStateModel) {
+ $scope.obj = {
+ show: !1
+ }, $scope.$root.$on("start preview", function(event, item, xpos) {
+ if (("Music" == item.type || "Sound effect" == item.type) && ViewStateModel.allowPreviews) {
+ var num = Number(item.dur),
+ seconds = Math.floor(num / 1e3),
+ minutes = Math.floor(seconds / 60);
+ 1 === (seconds = seconds - 60 * minutes).toString().length && (seconds = "0" + seconds);
+ var format = minutes + ":" + seconds;
+ $scope.obj.dur = format, item.dur || ($scope.obj.dur = ""), $scope.obj.timer = setTimeout(function() {
+ document.getElementById("tracktime").style.left = "0px", $scope.playAudio(item.m4aURL, xpos), $scope.obj.name = item.abbrName, item.artistName ? $scope.obj.artist = "BY " + item.artistName.toUpperCase() : "n/a" === item.fps ? $scope.obj.artist = "" : $scope.obj.artist = item.fps, $scope.obj.iconLargeURL = item.iconLargeURL, item.priceRange && item.priceRange[0] != item.priceRange[1] ? ($scope.obj.price = "$" + item.priceRange[0] + "-$" + item.priceRange[1], $scope.obj.priceStyle = "preview-price-double") : ($scope.obj.price = "$" + item.price, $scope.obj.priceStyle = "preview-price-single"), $scope.$apply(function() {
+ $scope.obj.show = !0
+ })
+ }, 400)
+ }
+ }), $scope.$root.$on("stop preview", function(event, data) {
+ data && (clearTimeout($scope.obj.timer), setTimeout(function() {
+ $scope.playAudio("")
+ }, 200), $scope.obj.name = "", $scope.obj.price = "", $scope.obj.type = "", $scope.obj.dur = "", $scope.obj.show = !1)
+ }), $scope.playAudio = function(url, xpos) {
+ var audio = document.getElementById("audio");
+ document.getElementById("source-audio").setAttribute("src", url), audio.load()
+ }
+}), app.controller("PreviewPhotoController", function($scope, ViewStateModel) {
+ $scope.obj = {
+ show: !1,
+ showInfo: !0
+ }, $scope.$root.$on("start preview", function(event, item, xpos) {
+ "Photo" != item.type && "Illustration" != item.type || ViewStateModel.allowPreviews && ($scope.obj.timer = setTimeout(function() {
+ $scope.obj.name = item.abbrName, item.artistName ? $scope.obj.artist = "BY " + item.artistName.toUpperCase() : "n/a" === item.fps ? $scope.obj.artist = "" : $scope.obj.artist = item.fps, $scope.obj.vs = item.vs, $scope.obj.ar = item.ar, $scope.obj.audioCodec = item.audioCodec, $scope.obj.videoCodec = item.videoCodec, item.priceRange && item.priceRange[0] != item.priceRange[1] ? ($scope.obj.price = "$" + item.priceRange[0] + "-$" + item.priceRange[1], $scope.obj.priceStyle = "preview-price-double") : ($scope.obj.price = "$" + item.price, $scope.obj.priceStyle = "preview-price-single"), item.ox ? $scope.obj.res = item.ox + " x " + item.oy : $scope.obj.res = "", $scope.obj.type = item.type, $scope.obj.iconLargeURL = item.iconLargeURL;
+ var size = convertAspectRatio(370, 208, item.aq);
+ actualRatio = item.aq, targetRatio = size.x / size.y, adjustmentRatio = targetRatio / actualRatio;
+ var photo = document.getElementById("photo");
+ photo.width = size.x, photo.height = size.y, document.getElementById("preview-loading").style.visibility = "hidden", photo.style.position = "absolute";
+ var x_pos = 185 - photo.width / 2;
+ photo.style.left = x_pos + "px", $scope.obj.name = item.abbrName, item.artistName ? $scope.obj.artist = "BY " + item.artistName.toUpperCase() : "n/a" === item.fps ? $scope.obj.artist = "" : $scope.obj.artist = item.fps, $scope.obj.fps = item.fps, $scope.obj.vs = item.vs, $scope.obj.ar = item.ar, $scope.obj.audioCodec = item.audioCodec, $scope.obj.videoCodec = item.videoCodec, item.videoCodec && -1 != item.videoCodec.indexOf("Apple ProRes") && ($scope.obj.videoCodec = "Apple ProRes"), item.priceRange && item.priceRange[0] != item.priceRange[1] ? ($scope.obj.price = "$" + item.priceRange[0] + "-$" + item.priceRange[1], $scope.obj.priceStyle = "preview-price-double") : ($scope.obj.price = "$" + item.price, $scope.obj.priceStyle = "preview-price-single"), item.ox ? $scope.obj.res = item.ox + " x " + item.oy : $scope.obj.res = "", $scope.$apply(function() {
+ $scope.obj.show = !0
+ })
+ }, 400))
+ }), $scope.$root.$on("stop preview", function(event, item) {
+ item && (clearTimeout($scope.obj.timer), $scope.obj.name = "", $scope.obj.price = "", $scope.obj.type = "", $scope.obj.show = !1)
+ })
+}), app.controller("PreviewVideoController", function($scope, ViewStateModel) {
+ $scope.obj = {
+ show: !1,
+ timer: null,
+ item: null,
+ showInfo: !0
+ }, $scope.$root.$on("start preview", function(event, item) {
+ "Video" != item.type && "AE" != item.type || ViewStateModel.allowPreviews && ($scope.obj.timer = setTimeout(function() {
+ $scope.obj.name = item.abbrName, item.artistName ? $scope.obj.artist = "BY " + item.artistName.toUpperCase() : "n/a" === item.fps && ($scope.obj.artist = ""), $scope.obj.fps = item.fps, $scope.obj.vs = item.vs, $scope.obj.ar = item.ar, $scope.obj.audioCodec = item.audioCodec, $scope.obj.videoCodec = item.videoCodec, item.videoCodec && -1 != item.videoCodec.indexOf("Apple ProRes") && ($scope.obj.videoCodec = "Apple ProRes"), item.priceRange && item.priceRange[0] != item.priceRange[1] ? ($scope.obj.price = "$" + item.priceRange[0] + "-$" + item.priceRange[1], $scope.obj.priceStyle = "preview-price-double") : ($scope.obj.price = "$" + item.price, $scope.obj.priceStyle = "preview-price-single"), item.ox ? $scope.obj.res = item.ox + " x " + item.oy : $scope.obj.res = "", $scope.$apply(function() {
+ $scope.obj.show = !0
+ }), $scope.playVideo(item)
+ }, 400))
+ }), $scope.$root.$on("stop preview", function(event, data) {
+ clearTimeout($scope.obj.timer), $("#video-frame").children().filter("video").each(function() {
+ this.pause(), $(this).remove()
+ }), $("#video-frame").empty(), $scope.obj.name = "", $scope.obj.price = "", $scope.obj.fps = "", $scope.obj.vs = "", $scope.obj.show = !1, document.getElementById("preview-loading").style.visibility = "visible"
+ }), $scope.playVideo = function(item) {
+ $("#video-frame").append($(" "));
+ var video = document.getElementsByTagName("video")[0],
+ source = document.getElementById("source-video");
+ video.style.visibility = "hidden";
+ var size = convertAspectRatio(370, 208, item.aq);
+ video.addEventListener("loadedmetadata", function(event) {
+ video.width = size.x, video.height = size.y, document.getElementById("preview-loading").style.visibility = "hidden", video.style.visibility = "visible"
+ }), item.h264URL ? (video.pause(), source.setAttribute("src", ""), source.setAttribute("src", item.h264URL), video.load()) : (source.setAttribute("src", ""), video.pause())
+ }, $scope.$root.$on("preview info icon over", function() {
+ $scope.obj.showInfo = !0
+ }), $scope.$root.$on("preview info icon out", function() {
+ $scope.obj.showInfo = !1
+ })
+}), app.controller("ReplaceController", function($scope, $timeout, ViewStateModel, ReplaceService, LoginModel, AnalyticsService, ReadClipsOnFSService) {
+ $scope.obj = {
+ show: !1,
+ disabled: !1,
+ buttonLabel: BUTTON_REPLACE_LABEL,
+ buttonTooltip: BUTTON_REPLACE_TOOLTIP
+ }, $scope.$root.$on("replacing complete", function() {
+ $scope.obj.disabled = !1
+ }), $scope.viewState = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewState, function() {
+ "cart" != ViewStateModel.getState() ? $scope.obj.show = !0 : $scope.obj.show = !1
+ }, !0), $scope.onReplaceButtonClicked = function() {
+ if (LoginModel.getLoggedIn()) {
+ $scope.hideTooltip(), $scope.obj.disabled = !0, ReadClipsOnFSService.listPurchasesOnFS(function() {
+ console.log("DragAndDropController fs items listed, call onClipsFSCollected"), ReplaceService.onClipFSCollected()
+ });
+ var ga = {
+ ec: "replace%20with%20hires"
+ };
+ AnalyticsService.sendData(ga)
+ } else $scope.$root.$emit("modal not logged in", [ERROR])
+ }, $scope.onReplaceButtonOver = function() {
+ $timeout(function() {
+ $("#replaceButton").trigger("show")
+ }, 0)
+ }, $scope.onReplaceButtonOut = function() {
+ $scope.hideTooltip()
+ }, $scope.hideTooltip = function() {
+ $timeout(function() {
+ $("#replaceButton").trigger("hide")
+ }, 0)
+ }
+}), app.controller("SearchController", function($scope, ViewStateService, SearchModel, ViewStateModel, AnalyticsService) {
+ $scope.obj = {
+ filters: MEDIA_TYPES,
+ direction: "down",
+ showFilters: !1,
+ view: "search",
+ styleInput: "search-input-reg"
+ }, $scope.viewStateModel = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewStateModel, function() {
+ $scope.obj.view = ViewStateModel.getState(), 0 < THIRD_PARTY.length && ($scope.obj.styleInput = "search-input-tp")
+ }, !0), resizePanel = function() {
+ var numOfTotalResults = SearchModel.searchResultItems.length,
+ numOfResults = SearchModel.numOfResults,
+ rect = window.innerWidth * window.innerHeight;
+ 0 < numOfResults && numOfResults != numOfTotalResults && numOfTotalResults < rect / 25e3 && "search" == ViewStateModel.getState() && (SearchModel.isSearching || (console.log("SearchController resize, new search"), SearchModel.isSearching = !0, SearchModel.resultType = "add", SearchModel.page = SearchModel.page + 1, ViewStateService.viewRequested("search")))
+ }, $scope.obj.selected = $scope.obj.filters[0], $scope.$root.$on("filters button clicked", function(event, state) {
+ $scope.obj.showFilters = state
+ }), $scope.filtersRequested = function() {
+ $scope.obj.showFilters = !$scope.obj.showFilters, $scope.$root.$emit("filters button clicked", $scope.obj.showFilters)
+ }, $scope.onChange = function(val) {
+ var sortID;
+ switch (console.log("SearchController onChange: ", val), $scope.obj.selected = val, $scope.obj.open = !1, $scope.obj.selected) {
+ case "Footage":
+ sortID = BM_VIDEO;
+ break;
+ case "After Effects":
+ sortID = BM_AFTER_EFFECTS;
+ break;
+ case "Music":
+ sortID = BM_MUSIC;
+ break;
+ case "SFX":
+ sortID = BM_SFX;
+ break;
+ case "Public Domain":
+ sortID = BM_PUBLIC_DOMAIN;
+ break;
+ case "Photos":
+ sortID = BM_PHOTO;
+ break;
+ case "Illustrations":
+ sortID = BM_ILLUSTRATIONS
+ }
+ SearchModel.sumOfBitmasks = sortID, console.log("SearchController changed, selected, bm: ", SearchModel.sumOfBitmasks), $scope.$root.$emit("media filter change", sortID), $scope.search()
+ }, $scope.setCurrent = function(val) {
+ $scope.obj.selected = val
+ }, $scope.toggled = function(open) {
+ $scope.obj.direction = open ? "dropup" : "down"
+ }, $scope.search = function() {
+ var query = document.getElementById("search").value;
+ "Search Pond5..." === query && (query = "");
+ var ga = {
+ ec: "search"
+ };
+ ga.ea = $scope.obj.selected.replace(/ /g, "%20"), ga.el = query.replace(/ /g, "%20"), AnalyticsService.sendData(ga), SearchModel.query = query, SearchModel.resultType = "replace", SearchModel.page = 0, SearchModel.sumOfBitmasks === BM_PUBLIC_DOMAIN && (SearchModel.query = SearchModel.query + " editorial:1"), console.log("SearchController search: ", query, SearchModel.sumOfBitmasks, SearchModel.resultType, SearchModel.page), ViewStateService.viewRequested("search")
+ }, $scope.searchButtonClicked = function() {
+ $scope.search()
+ }, $scope.enterThis = function() {
+ 13 === event.keyCode && $scope.search()
+ }, $scope.onSearchIconClicked = function() {
+ ViewStateService.viewRequested("search")
+ }
+});
+var SellController = function($scope, AnalyticsService) {
+ $scope.sellClicked = function() {
+ var ga = {
+ ec: "sell%20media"
+ };
+ console.log("SellController ga", ga), AnalyticsService.sendData(ga), opn("https://www.pond5.com/index.php?page=my_uploads")
+ }
+};
+SellController.$inject = ["$scope", "AnalyticsService"], app.controller("SidebarController", function($scope, ViewStateModel, ViewStateService, AnalyticsService) {
+ $scope.obj = {
+ view: "search"
+ }, $scope.viewStateModel = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewStateModel, function() {
+ $scope.obj.view = ViewStateModel.getState()
+ }), $scope.onDownloadsIconClicked = function() {
+ $scope.$root.$emit("views requested", "downloads"), ViewStateService.viewRequested("downloads");
+ var ga = {
+ ec: "downloads"
+ };
+ AnalyticsService.sendData(ga)
+ }, $scope.onPreviewsIconClicked = function() {
+ ViewStateService.viewRequested("previews");
+ var ga = {
+ ec: "imported%20previews"
+ };
+ AnalyticsService.sendData(ga)
+ }, $scope.onDestinationIconClicked = function() {
+ $scope.$root.$emit("modal add destination requested");
+ var ga = {
+ ec: "add%20destination"
+ };
+ AnalyticsService.sendData(ga)
+ }
+}), app.controller("SubTopRowController", function($scope, ViewStateModel, BinsModel, SearchModel, CartModel, PurchasesModel, UserModel, AnalyticsService) {
+ function onViewStateChange() {
+ var title;
+ switch (ViewStateModel.getState()) {
+ case "downloads":
+ title = "MY DOWNLOADS";
+ break;
+ case "previews":
+ title = "MY IMPORTED PREVIEWS";
+ break;
+ case "cart":
+ title = "MY CART";
+ break;
+ case "freebies":
+ title = "50 FREE MEDIA CLIPS";
+ break;
+ case "bins":
+ console.log("SubTopRowController selected bin name:", BinsModel.showBin.name), title = "COLLECTION: " + BinsModel.showBin.name;
+ break;
+ case "search":
+ title = 0 < SearchModel.query.length ? SearchModel.query.toUpperCase() : "";
+ break;
+ default:
+ title = ""
+ }
+ $scope.obj.title = title, "search" == ViewStateModel.getState() ? $scope.obj.showDropdown = !0 : $scope.obj.showDropdown = !1, "cart" == ViewStateModel.getState() ? $scope.obj.showCreditsWrapper = !0 : $scope.obj.showCreditsWrapper = !1, $scope.showClearAll()
+ }
+ $scope.obj = {
+ showFilters: !1,
+ titleClass: "sub-top-row-title-no-filters",
+ showClearAll: !1,
+ showDropdown: !0,
+ showCreditsWrapper: !1,
+ credits: 0
+ }, $scope.$root.$on("on cart total", function(event) {
+ $scope.obj.credits = CartModel.getCartTotal().creditsData.availableSum
+ }), $scope.cartModel = function() {
+ return CartModel.cartVO
+ }, $scope.$watch($scope.cartModel, function() {
+ $scope.showClearAll()
+ }), $scope.$root.$on("bin selected", function(event) {
+ onViewStateChange()
+ }), $scope.viewStateModelQuery = function() {
+ return SearchModel.query
+ }, $scope.$watch($scope.viewStateModelQuery, onViewStateChange), $scope.viewStateModel = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewStateModel, onViewStateChange), $scope.showClearAll = function() {
+ "cart" == ViewStateModel.getState() && 0 < CartModel.cartVO.items.length ? $scope.obj.showClearAll = !0 : $scope.obj.showClearAll = !1
+ }, $scope.$root.$on("filters button clicked", function(event, state) {
+ $scope.obj.titleClass = state ? "sub-top-row-title-filters" : "sub-top-row-title-no-filters"
+ }), $scope.onClearCartClicked = function() {
+ if (0 != CartModel.cartVO.items.length) {
+ for (var ids = "", i = 0; i < CartModel.cartVO.items.length; i++) i < CartModel.cartVO.items.length ? ids += CartModel.cartVO.items[i].id + "," : ids += CartModel.cartVO.items[i].id;
+ $scope.$root.$emit("clear cart requested", [ids])
+ }
+ }, $scope.buyCreditsClicked = function() {
+ var ga = {
+ ec: "buy%20credits"
+ };
+ console.log("CreditsController ga", ga), AnalyticsService.sendData(ga), $scope.$root.$emit("modal buy credits requested"), console.log("SubTopRowController button clicked")
+ }
+}), app.controller("TileListItemController", function($scope, Service, BinsModel, ImportedPreviewsService, ViewStateModel, LoginModel, ReplaceModel, DownloadModel) {
+ $scope.childObj = {}, $scope.childObj.addedToCart = !1, $scope.childObj.addedToBin = !1, $scope.allowDownload = !0, $scope.childObj.cartClicked = !1, $scope.childObj.binClicked = !1, $scope.childObj.showEditorial = !0, $scope.childObj.viewState = "search", $scope.childObj.notification = "", "FCPX" === HOST_NAME ? $scope.childObj.importTooltip = "CLICK TO DOWNLOAD" : $scope.childObj.importTooltip = "CLICK TO IMPORT", $scope.viewState = function() {
+ return ViewStateModel.getState()
+ }, $scope.$watch($scope.viewState, function() {
+ $scope.childObj.viewState = ViewStateModel.getState()
+ }, !0), $scope.$root.$on("added to cart", function(event) {
+ $scope.childObj.cartClicked && ($scope.childObj.addedToCart = !0), setTimeout(function() {
+ $scope.childObj.cartClicked = !1, $scope.childObj.addedToCart = !1
+ }, 1e3)
+ }), $scope.$root.$on("added to bin", function(event) {
+ $scope.childObj.binClicked && ($scope.childObj.addedToBin = !0), setTimeout(function() {
+ $scope.childObj.binClicked = !1, $scope.childObj.addedToBin = !1
+ }, 1e3)
+ }), $scope.itemHovered = function(e) {
+ $scope.childObj.showMenu = !0, $scope.$root.$emit("start preview", $scope.item, e.clientX)
+ }, $scope.itemLeft = function() {
+ $scope.childObj.showMenu = !1, $scope.$root.$emit("stop preview", $scope.item)
+ }, $scope.opaqueClicked = function() {
+ console.log("TileListItemController opaqueClicked", $scope.allowDownload), $scope.allowDownload && ($scope.allowDownload = !1, $scope.$root.$emit("download requested", [$scope.item]), ImportedPreviewsService.saveItem($scope.item.id), $scope.$root.$emit("stop preview", $scope.item)), setTimeout(function() {
+ $scope.allowDownload = !0
+ }, 2e3)
+ }, $scope.overInfoIcon = function() {
+ $scope.$root.$emit("preview info icon over")
+ }, $scope.outInfoIcon = function() {
+ $scope.$root.$emit("preview info icon out")
+ }, $scope.binIconClicked = function() {
+ console.log("TileListItemController binIconClicked"), LoginModel.loggedIn ? 0 < BinsModel.bins.length ? (console.log("TileListItemController binIconClicked show notification"), Service.modifyBin(BinsModel.addToBin.id, $scope.item.id), $scope.childObj.notification = "Added to the collection!", $scope.childObj.binClicked = !0, setTimeout(function() {
+ $scope.childObj.binClicked = !1, $scope.childObj.addedToBin = !1
+ }, 4e3), $scope.childObj.binClicked = !0) : $scope.$root.$emit("modal simple requested", ["You don't have Collections", "In order to add clips to a Collection you first need to create a Collection"]) : $scope.$root.$emit("modal not logged in", [ERROR])
+ }, $scope.cartIconClicked = function() {
+ $scope.childObj.notification = "Added to the cart successfully!", $scope.childObj.cartClicked = !0, setTimeout(function() {
+ $scope.childObj.cartClicked = !1, $scope.childObj.addedToCart = !1
+ }, 4e3), Service.getFormats($scope.item)
+ }, $scope.trashIconClicked = function() {
+ $scope.$root.$emit("stop preview", $scope.item), "bins" === ViewStateModel.getState() ? Service.modifyBin(BinsModel.binVO.id, "", $scope.item.id) : "previews" === ViewStateModel.getState() && ImportedPreviewsService.deleteItem($scope.item.id)
+ }, $scope.linkClicked = function() {
+ opn("https://www.pond5.com/item/" + $scope.item.id)
+ }
+}), app.controller("TileListSearchController", function($scope, SearchModel, Service) {
+ $scope.obj = {
+ showDeleteIcon: !1
+ }, $scope.searchItems = function() {
+ if (SearchModel.searchResultVO) return SearchModel.searchResultVO.items
+ }, $scope.$watch($scope.searchItems, function() {
+ SearchModel.searchResultVO && ($scope.obj.items = SearchModel.searchResultItems)
+ })
+}), app.controller("TileListPreviewsController", function($scope, PreviewsModel) {
+ $scope.obj = {
+ showDeleteIcon: !0
+ }, $scope.previewItems = function() {
+ if (PreviewsModel.previewsVO) return PreviewsModel.previewsVO.items
+ }, $scope.$watch($scope.previewItems, function() {
+ if (PreviewsModel.previewsVO) {
+ console.log("TileListPreviewsController: ", PreviewsModel.previewsVO), PreviewsModel.previewsVO.items.reverse();
+ for (var previews = PreviewsModel.previewsVO.items, nonAEpreviews = [], i = 0; i < previews.length; i++) "AE" != previews[i].type && nonAEpreviews.push(previews[i]);
+ $scope.obj.items = nonAEpreviews
+ }
+ })
+}), app.controller("TileListBinsController", function($scope, BinsModel) {
+ $scope.obj = {
+ showDeleteIcon: !0
+ }, $scope.binItems = function() {
+ if (BinsModel.binVO) return BinsModel.getBinVO()
+ }, $scope.$watch($scope.binItems, function() {
+ BinsModel.binVO && ($scope.obj.items = BinsModel.binVO.items)
+ }, !0)
+}), app.controller("TileListFreebiesController", function($scope, FreebiesModel) {
+ $scope.obj = {
+ showDeleteIcon: !1
+ }, $scope.freeItems = function() {
+ if (FreebiesModel.freebiesVO) return FreebiesModel.freebiesVO.items
+ }, $scope.$watch($scope.freeItems, function() {
+ FreebiesModel.freebiesVO && ($scope.obj.items = FreebiesModel.freebiesVO.items)
+ })
+}), app.controller("TransactionController", function($scope, ViewStateModel, ViewStateService, Service, AnalyticsService, CheckOutModel, ReplaceModel) {
+ $scope.obj = {
+ url: "",
+ show: !1
+ }, $scope.CheckOutModel = function() {
+ return CheckOutModel
+ }, $scope.$watch($scope.CheckOutModel, function() {
+ if (CheckOutModel.checkOutURL) {
+ (new Date).getTime();
+ $scope.obj.url = CheckOutModel.checkOutURL, $scope.obj.show = !0, CheckOutModel.checkOutURL = "", $("body,html").css("overflow", "hidden")
+ }
+ }, !0), window.parent.addEventListener("message", function() {
+ switch (ViewStateModel.allowPreviews = !0, console.log("TransactionController postMessage: ", event.data), event.data) {
+ case "PAID":
+ ReplaceModel.getState() === NOT_PURCHASED ? Service.getPurchases() : ($scope.$root.$emit("modal simple requested", PURCHASE_SUCCESSFULL), ViewStateService.viewRequested("downloads")), $scope.$root.$emit("purchase complete"), Service.getUserInfo(), console.log("TransactionController CC payment success");
+ break;
+ case "CANCELED":
+ $scope.$root.$emit("modal simple requested", PURCHASE_CANCELED);
+ break;
+ default:
+ $scope.$root.$emit("modal simple requested", [ERROR, "UNKNOWN"])
+ }
+ $scope.obj.show = !1, console.log("TransactionController onDone, show:", $scope.obj.show), $scope.$root.$emit("checkout complete"), $("body,html").css("overflow", "visible")
+ }, !1)
+}), app.directive("enter", function() {
+ return function(scope, element, attrs) {
+ element.bind("keydown", function() {
+ 13 === event.which && scope.$apply(attrs.enter)
+ })
+ }
+}), app.directive("enterFooter", function() {
+ return function(scope, element, attrs) {
+ element.bind("mouseenter", function() {
+ element.children()[0].style.color = "#ccc"
+ })
+ }
+}), app.directive("leaveFooter", function() {
+ return function(scope, element, attrs) {
+ element.bind("mouseleave", function() {
+ element.children()[0].style.color = "#969493"
+ })
+ }
+}), app.directive("repositionImage", function() {
+ return {
+ restrict: "A",
+ link: function(scope, elem, attrs) {
+ elem.on("load", function() {
+ 108 < $(this).height() && elem.addClass("high")
+ })
+ }
+ }
+}), app.directive("rotate", function() {
+ return {
+ restrict: "A",
+ link: function(scope, element, attrs) {
+ scope.$watch(attrs.rotate, function(dir) {
+ var r = "rotate(" + ("up" === dir ? 180 : 0) + "deg)";
+ element.css({
+ "-webkit-transform": r
+ })
+ })
+ }
+ }
+}), app.directive("whenScrolled", ["$window", "ScrollService", function($window, ScrollService) {
+ return function(scope, elm, attr) {
+ elm[0];
+ angular.element($window).bind("scroll", function() {
+ ScrollService.onScroll()
+ })
+ }
+}]), app.directive("scrollTop", [function() {
+ return {
+ restrict: "A",
+ link: function(scope, $elm, attr) {
+ scope.$root.$on("scroll progress to top", function() {
+ $elm.animate({
+ scrollTop: 0
+ }, "slow")
+ })
+ }
+ }
+}]), app.directive("dragMe", function() {
+ return {
+ restrict: "A",
+ link: function(scope, elem, attr, ctrl) {
+ elem.draggable()
+ }
+ }
+}), app.directive("onHoverInfoCart", function() {
+ return {
+ link: function(scope, element, attrs) {
+ element.bind("mouseenter", function($event) {
+ initialMouseX = $event.clientX, initialMouseY = $event.clientY, scope.$root.$emit("cart icon over", initialMouseX, initialMouseY)
+ }), element.bind("mouseleave", function() {
+ scope.$root.$emit("cart icon out")
+ })
+ }
+ }
+}), app.directive("onHoverPreview", function() {
+ return {
+ link: function(scope, element, attrs) {
+ element.bind("mouseenter", function($event) {
+ var previewX, previewY, tileX = element[0].getBoundingClientRect().left;
+ previewX = tileX < 310 ? tileX + 220 : tileX - 400, (previewY = element[0].getBoundingClientRect().top - 200) < 20 && (previewY = 20), 340 < previewY && (previewY = 340);
+ var cols = document.getElementsByClassName("preview");
+ for (i = 0; i < cols.length; i++) cols[i].style.left = previewX.toString() + "px", cols[i].style.top = previewY.toString() + "px"
+ })
+ }
+ }
+}), app.filter("to_trusted", ["$sce", function($sce) {
+ return function(text) {
+ return $sce.trustAsHtml(text)
+ }
+}]), app.filter("trusted", ["$sce", function($sce) {
+ return function(url) {
+ return $sce.trustAsResourceUrl(url)
+ }
+}]), app.filter("secondsToDateTime", [function() {
+ return function(seconds) {
+ return new Date(1970, 0, 1).setSeconds(seconds)
+ }
+}]), app.directive("closeCollectionsList", function($document) {
+ return {
+ restrict: "A",
+ link: function(scope, elem, attr, ctrl) {
+ elem.bind("click", function(e) {
+ e.stopPropagation()
+ }), $document.bind("click", function() {
+ scope.$apply(attr.closeCollectionsList)
+ })
+ }
+ }
+}), app.directive("fieldValidation", function() {
+ return {
+ require: "ngModel",
+ link: function(scope, element, attr, mCtrl) {
+ mCtrl.$parsers.push(function(value) {
+ return /^\w+$/.test(value) && 1 < value.toString().length || 0 == value.toString().length ? (mCtrl.$setValidity("charE", !0), console.log("directive valid true")) : (mCtrl.$setValidity("charE", !1), console.log("directive valid false")), value
+ })
+ }
+ }
+}), app.directive("vatValidation", function() {
+ return {
+ require: "ngModel",
+ link: function(scope, element, attr, mCtrl) {
+ mCtrl.$parsers.push(function(value) {
+ return /^\w+$/.test(value) && 2 < value.toString().length || 0 == value.toString().length ? (mCtrl.$setValidity("charE", !0), console.log("directive valid true")) : (mCtrl.$setValidity("charE", !1), console.log("directive valid false")), value
+ })
+ }
+ }
+}), app.directive("restrictInput", [function() {
+ return {
+ restrict: "A",
+ link: function(scope, element, attrs) {
+ var ele = element[0],
+ regex = RegExp(attrs.restrictInput),
+ value = ele.value;
+ ele.addEventListener("keyup", function(e) {
+ regex.test(ele.value) ? value = ele.value : ele.value = value
+ })
+ }
+ }
+}]), app.filter("searchFilter", function() {
+ return function(input, param1) {
+ if (console.log("------------------------------------------------- begin dump of custom parameters"), console.log("searchFilter input: ", input), input && input.length) {
+ console.log("searchFilter param1: ", param1);
+ var filteredItems = [];
+ for (i = 0; i < input.length; i++) input[i].fps == param1 && filteredItems.push(input[i]);
+ return filteredItems
+ }
+ }
+}), PURCHASE_SUCCESSFULL = ["Your purchase has been successfull!", "Your items are now ready to download."], PURCHASE_CANCELED = ["Canceled.", "Purchase was canceled."], ERROR = "Oops, something went wrong...", NO_RESULTS = ["Your search returned no results", "Try adjusting your filters Check your search term for misspelling or try a few synonyms "], BM_VIDEO = 15, BM_MUSIC = 16, BM_SFX = 32, BM_PHOTO = 128, BM_ILLUSTRATIONS = 1024, BM_AFTER_EFFECTS = 64, BM_PUBLIC_DOMAIN = 16384, MODE = "live", THIRD_PARTY = "", TARGET_APP = "", GA_TRACKING_CODE = "UA-60083218-9", DEFAULT = "not replacing", MISSING_ITEMS = "missing items", NOT_PURCHASED = "not purchased", NOT_DOWNLOADED = "not downloaded", PURCHASED_AND_DOWNLOADED = "purchased and downloaded";
+var BASE_URL = "https://plugin.pond5.com/",
+ NO_RESULTS_ICON = BASE_URL + "pond5_shared/images/no_results_icon.png",
+ DRAGNDROP_IMG = BASE_URL + "pond5_shared/images/intro-icons/dragndrop.png",
+ STATE_IMG = BASE_URL + "pond5_shared/images/intro-states/step",
+ STATE_FCP_IMG = BASE_URL + "pond5_shared/images/intro-states-fcp/step",
+ DOWNLOAD_IMG = BASE_URL + "pond5_shared/images/intro-icons/download.png",
+ CART_IMG = BASE_URL + "pond5_shared/images/intro-icons/cart.png",
+ PREVIEWS_IMG = BASE_URL + "pond5_shared/images/intro-icons/previews.png",
+ DUMMY_IMG = BASE_URL + "pond5_shared/images/intro-icons/dummy.png",
+ CLEAR_CART_TRASH_IMG = BASE_URL + "pond5_shared/images/clear-cart-trash-icon.png",
+ CART_BUTTON_IMG = BASE_URL + "pond5_shared/images/cartButtonIcon.png",
+ PROGRESS_CLOSE_IMG = BASE_URL + "pond5_shared/images/progress-close-icon.png",
+ LOGO_IMG = BASE_URL + "pond5_shared/images/logo-white.png",
+ MODAL_SIMPLE_HTML = BASE_URL + "pond5_shared/views/modals/modalSimple.html",
+ MODAL_ADD_DESTINATION_HTML = BASE_URL + "pond5_shared/views/modals/modalAddDestination.html",
+ MODAL_ADD_COLLECTION_HTML = BASE_URL + "pond5_shared/views/modals/modalAddCollection.html",
+ MODAL_ADD_COLLECTION_CONFIRMATION_HTML = BASE_URL + "pond5_shared/views/modals/modalAddCollectionConfirmation.html",
+ MODAL_SELECT_SEQUENCES_HTML = BASE_URL + "pond5_shared/views/modals/modalSelectSequences.html",
+ MODAL_INTRO_HTML = BASE_URL + "pond5_shared/views/modals/modalIntro.html",
+ MODAL_ADD_TO_CART_HTML = BASE_URL + "pond5_shared/views/modals/modalAddToCart.html",
+ MODAL_BILLING_ADDRESS_HTML = BASE_URL + "pond5_shared/views/modals/modalBillingAddress.html",
+ MODAL_CHOOSE_BILLING_INFO_HTML = BASE_URL + "pond5_shared/views/modals/modalChooseBillingInfo.html",
+ MODAL_CHOOSE_FORMAT_HTML = BASE_URL + "pond5_shared/views/modals/modalChooseFormat.html",
+ MODAL_CHOOSE_VERSION_HTML = BASE_URL + "pond5_shared/views/modals/modalChooseVersion.html",
+ MODAL_FREEBIES_HTML = BASE_URL + "pond5_shared/views/modals/modalFreebies.html",
+ MODAL_LOGIN_HTML = BASE_URL + "pond5_shared/views/modals/modalLogin.html",
+ MODAL_NOT_LOGGED_IN_HTML = BASE_URL + "pond5_shared/views/modals/modalNotLoggedIn.html",
+ MODAL_PROMO_CODE_HTML = BASE_URL + "pond5_shared/views/modals/modalPromoCode.html",
+ MODAL_REMOVE_COLLECTION_HTML = BASE_URL + "pond5_shared/views/modals/modalRemoveCollection.html",
+ MODAL_REPLACE_HTML = BASE_URL + "pond5_shared/views/modals/modalReplace.html",
+ MODAL_REPLACE_WARNING_HTML = BASE_URL + "pond5_shared/views/modals/modalReplaceWarning.html",
+ MODAL_BUY_CREDITS_HTML = BASE_URL + "pond5_shared/views/modals/modalBuyCredits.html",
+ COLLECTIONS_LIST_HTML = BASE_URL + "pond5_shared/views/collectionsList.html";
+$(function() {
+ Offline.options = {
+ checkOnLoad: !0,
+ checks: {
+ image: {
+ url: function() {
+ return "https://plugin.pond5.com/pond5_shared/images/logo-white.png?_=" + Math.floor(1e9 * Math.random())
+ }
+ },
+ active: "image"
+ }
+ }
+}), app.service("AppModel", ["$rootScope", function($rootScope) {
+ var path = require("path"),
+ dirHomePond5 = getUserHome() + path.sep + "pond5",
+ dirImports = dirHomePond5 + path.sep + "imports",
+ dirPrefs = dirHomePond5 + path.sep + "prefs",
+ dirDestinations = dirHomePond5 + path.sep + "destinations",
+ dirDefaultLib = path.sep,
+ dirUser = dirHomePond5 + path.sep + "user",
+ result = (dirDefaultLib = dirHomePond5 + path.sep + "defaultLib", {
+ OS: "",
+ baseFolders: [],
+ currentBaseFolder: "",
+ previewsDir: "",
+ purchasedDir: "",
+ defaultLib: "",
+ defaultLibName: "",
+ defaultLibPath: "",
+ targetApp: "",
+ setEnv: function() {
+ result.setOS(os.platform()), $rootScope.$emit("environment set")
+ },
+ getOS: function() {
+ return result.OS
+ },
+ setOS: function(s) {
+ result.OS = s
+ },
+ getDocumentsPath: function() {
+ return os.homedir() + path.sep + "Documents"
+ },
+ getDirHomePond5: function() {
+ return dirHomePond5
+ },
+ getDirImports: function() {
+ return dirImports
+ },
+ getDirDestinations: function() {
+ return dirDestinations
+ },
+ getDirPrefs: function() {
+ return dirPrefs
+ },
+ getDirUser: function() {
+ return dirUser
+ },
+ getDestinationsXML: function() {
+ return result.getDirDestinations() + path.sep + "destinations.xml"
+ },
+ getUserXML: function() {
+ return result.getDirUser() + path.sep + "user.xml"
+ },
+ getPreferencesXML: function() {
+ return result.getDirPrefs() + path.sep + "preferences.xml"
+ },
+ getDirDefaultLib: function() {
+ return dirDefaultLib
+ },
+ getDefaultLib: function() {
+ return result.defaultLib
+ },
+ setDefaultLib: function(path) {
+ "/" == path.substr(path.length - 1) && (path = path.slice(0, -1)), result.setDefaultLibName(path), result.setDefaultLibPath(path), result.defaultLib = path
+ },
+ getDefaultLibName: function() {
+ return result.defaultLibName
+ },
+ setDefaultLibName: function(path) {
+ var n = path.lastIndexOf("/");
+ result.defaultLibName = path.substring(n + 1).replace(".fcpbundle", "")
+ },
+ getDefaultLibPath: function() {
+ return result.defaultLibPath
+ },
+ setDefaultLibPath: function(path) {
+ result.defaultLibPath = path.substring(0, path.lastIndexOf("/"))
+ },
+ getDefaultLibXML: function() {
+ return result.getDirDefaultLib() + path.sep + "defaultLib.xml"
+ },
+ getTargetApp: function() {
+ return result.targetApp
+ },
+ setTargetApp: function(app) {
+ result.targetApp = app
+ }
+ });
+ return result
+}]), app.factory("BillingInfoModel", ["$rootScope", function($rootScope) {
+ var info = {
+ onBillingInfo: function(data) {
+ info.setBillingInfo(data.commands[0]), info.getBillingInfo().forEach(function(item) {
+ item.isdefault && info.setDefaultInfo(item)
+ })
+ },
+ setBillingInfo: function(data) {
+ info.billingInfo = data
+ },
+ getBillingInfo: function() {
+ return info.billingInfo
+ },
+ setDefaultInfo: function(data) {
+ info.defaultInfo = data
+ },
+ getDefaultInfo: function() {
+ return info.defaultInfo
+ }
+ };
+ return info
+}]), app.service("BinsModel", ["$rootScope", function($rootScope) {
+ var result = {
+ binsVO: null,
+ bins: [],
+ binVO: null,
+ showBin: null,
+ addToBin: null,
+ onBins: function(data) {
+ result.binsVO = new BinsVO(data.commands[0]), result.bins = result.binsVO.bins, $rootScope.$emit("onBins")
+ },
+ onBin: function(data) {
+ result.setBinVO(new BinVO(data.commands[0]))
+ },
+ onActiveBin: function(data) {
+ result.bins.forEach(function(bin) {
+ bin.id == data.commands[0].binid && (result.addToBin = bin)
+ }), $rootScope.$emit("active bin changed", result.addToBin)
+ },
+ setBinVO: function(data) {
+ result.binVO = data
+ },
+ getBinVO: function() {
+ return result.binVO
+ }
+ };
+ return result
+}]);
+var BinsVO = function BinsVO(data) {
+ var i;
+ for (this.bins = [], i = 0; i < data.bins.length; i += 1) {
+ var bin = {};
+ bin.name = data.bins[i].name, bin.abbrBinName = getAbbrName(bin.name, 17), bin.id = data.bins[i].id, bin.total = data.bins[i].tot, bin.selected = !1, this.bins[i] = bin
+ }
+ this.bins.sort(compare), BinsVO.prototype = {
+ toString: function() {
+ console.log("bins: " + this.bins)
+ }
+ }
+ },
+ BinVO = function BinVO(data) {
+ var itemVO, i;
+ this.items = [], this.id = data.binid, this.name = data.name, this.jpegBase = "http://ec.pond5.com/s3/", console.log("BinVO id: ", data.binid, data.name);
+ var filterVS = 0;
+ for (filterVS = "AEFT" == HOST_NAME ? 200 : 102, i = 0; i < data.items.length; i += 1) parseInt(data.items[i].vs) <= filterVS && (itemVO = new ItemVO(data.items[i], data.icon_base, data.flv_base, "", this.jpegBase), this.items.push(itemVO));
+ BinVO.prototype = {
+ toString: function() {
+ console.log("name & id: ", this.id, this.name)
+ }
+ }
+ };
+app.factory("CartModel", ["$rootScope", "ReplaceModel", function($rootScope, ReplaceModel) {
+ $rootScope.$on("on cart", function(event, data) {
+ result.onCart(data)
+ }), $rootScope.$on("on cart total", function(event, data) {
+ result.onCartTotal(data)
+ }), $rootScope.$on("formats complete", function(event, item, formats) {
+ console.log("CartModel onCart ReplaceModel.getState(): ", ReplaceModel.getState()), result.onFormats(item, formats)
+ });
+ var result = {
+ cartVO: [],
+ cartTotal: null,
+ onCart: function(data) {
+ result.cartVO = new ItemsVO(data.commands[0])
+ },
+ onCartTotal: function(data) {
+ result.setCartTotal(data.commands[0])
+ },
+ onFormats: function(item, formats) {
+ if (console.log("CartModel onFormats, num of formats for id: ", item, formats.length), 1 < formats.length) {
+ var uniqueResFormats = _.uniq(formats, function(p) {
+ return p.ti
+ });
+ $rootScope.$emit("on add to cart clicked", uniqueResFormats)
+ } else {
+ var apiObj = {
+ fn: "modifyCart",
+ args: [item.id, ""]
+ };
+ $rootScope.$emit("api call", apiObj)
+ }
+ },
+ setCartTotal: function(data) {
+ result.cartTotal = data
+ },
+ getCartTotal: function() {
+ return result.cartTotal
+ }
+ };
+ return result
+}]), app.factory("CheckOutModel", ["$sce", function($sce) {
+ var result = {
+ onPurchase: function(data) {
+ console.log("CheckOutModel onPurchase, url: ", data.commands[0].url);
+ (new Date).getTime();
+ result.checkOutURL = $sce.trustAsResourceUrl(data.commands[0].url), console.log("CheckOutModel onPurchase, url: ", result.checkOutURL)
+ }
+ };
+ return result
+}]), app.factory("DownloadModel", ["$rootScope", "PurchasesModel", "ReplaceModel", function($rootScope, PurchasesModel, ReplaceModel) {
+ var result = {
+ binBatch: null,
+ itemsDownloadList: [],
+ selectedVersion: 0,
+ downloadingBatchURLs: !1,
+ urlCounter: 0,
+ downloadCounter: -1,
+ stayAwake: !1,
+ onGetPurchaseURL: function(data) {
+ var item = result.getVersionByID(data.commands[0].bid);
+ item && (item.hiresURL = data.commands[0].url, item.downloadType = "purchase", "AE" == item.vs && (item.type = item.vs), $rootScope.$emit("download requested", [item]))
+ },
+ onGetAllPurchaseURLs: function(data) {
+ var i, purchase, purchases = [];
+ for (ReplaceModel.getState() === DEFAULT ? purchases = PurchasesModel.purchasesVO.items : ReplaceModel.getState() === NOT_DOWNLOADED && (purchases = ReplaceModel.missingDownloads), result.urlCounter++, i = 0; i < purchases.length; i += 1) {
+ purchase = purchases[i];
+ var dataItem = data.commands[0];
+ for (k = 0; k < purchase.formats.length; k += 1) purchase.formats[k].id == dataItem.bid && (purchase.hiresURL = dataItem.url, purchase.downloadType = "purchase");
+ purchase.id == dataItem.bid && (purchase.hiresURL = dataItem.url, purchase.downloadType = "purchase", purchase.versions && 0 < purchase.versions.length && (purchase.vs = purchase.versions[0].vs))
+ }
+ purchases = purchases.filter(function(v, i, a) {
+ return a.indexOf(v) == i
+ }), result.urlCounter === purchases.length && ($rootScope.$emit("download requested", purchases), result.urlCounter = 0, result.downloadingBatchURLs = !1)
+ },
+ getVersionByID: function(id) {
+ var foundItem;
+ if (PurchasesModel.purchasesVO.items.forEach(function(item) {
+ item.id === id && (item.parentFormatID && (item.versions[result.selectedVersion].parentFormatID = item.parentFormatID), foundItem = item.versions[result.selectedVersion])
+ }), foundItem) return foundItem
+ }
+ };
+ return result
+}]), app.factory("FreebiesModel", [function() {
+ var result = {
+ onFreebies: function(data) {
+ result.freebiesVO = new ItemsVO(data.commands[0])
+ }
+ };
+ return result
+}]);
+var HiresVO = function HiresVO(dest, name) {
+ this.dest = dest, this.name = name, this.path = dest + name, this.id = name.split(" ")[1], this.replace = !1, this.type = "", this.nameFCP = this.name.replaceAll(" ", "%20"), this.nameFCP = this.nameFCP.replaceAll("-", "%2D"), this.nameFCP = this.nameFCP.replaceAll("&", "and"), this.pathFCP = "file://" + this.path.replaceAll(" ", "%20"), this.pathFCP = this.pathFCP.replaceAll("-", "%2D"), this.pathFCP = this.pathFCP.replaceAll("&", "and"), HiresVO.prototype = {
+ toString: function() {
+ return "\nHiresVO path: " + this.path + "\nname: " + this.name + "\nid: " + this.id + "\nreplace: " + this.replace
+ }
+ }
+ },
+ ItemsVO = function ItemsVO(data) {
+ var itemVO, i;
+ for (this.tot_nbr_rows = data.tot_nbr_rows, this.max_per_page = data.max_per_page, this.nbr_footage = data.nbr_footage, this.nbr_music = data.nbr_music, this.nbr_sfx = data.nbr_sfx, this.nbr_total = data.nbr_total, this.items = [], i = 0; i < data.items.length; i += 1) itemVO = new ItemVO(data.items[i], data.icon_base, data.flv_base, ""), this.items[i] = itemVO;
+ ItemsVO.prototype = {
+ toString: function() {
+ console.log("vs: " + this.vs)
+ }
+ }
+ },
+ ItemVO = function ItemVO(data, iconBase, flvBase, parentID) {
+ var getURL;
+ this.selectedVersion = 0, this.name = data.n, this.abbrName = getAbbrName(this.name, 25), this.abbrTileName = getAbbrName(this.name, 22), this.abbrListName = getAbbrName(this.name, 40), this.artistName = getAbbrName(data.artistname, 40), this.id = data.id, this.title = data.ti, this.vr360 = data.vr360, data.pr < .001 ? this.price = "0" : this.price = data.pr, this.priceRange = data.pricerange, this.vs = getConvertedVideoStandard(data.vs), this.downloadType = "preview", this.downloadURL, this.downloadDestination = "", this.downloading = !1, this.progressPerc = "", this.progressMB = "", this.progressName = "", this.parentFormatID = "", this.canceled = !1, this.completed = !1, this.imported = !1, this.inCart = !1, this.inDownloads = !1, this.selected = !1, this.formats = [], this.versions = [], this.ox = data.ox, this.oy = data.oy, this.ar = getAspectRatio(data.ar), this.ar || (this.ar = "n/a"), this.aq = data.aq, this.dur = data.dur, data.fps ? this.fps = data.fps : this.fps = "n/a", data.ti && (this.title = data.ti), data.tb && (this.subTitle = data.tb), data.i && (this.additionalInfo = data.i), data.id ? this.id = data.id : this.id = parentID, 0 === this.id.length && (this.id = parentID), this.offset = data.so, this.transactionID = data.tr, this.expirationDate = data.exp, this.versionID = data.v, this.videoCodec = data.codg, this.audioCodec = data.coda, this.extension = data.ext, this.version = data.bitoffset, this.type = getMediaType(this.vs), this.baseURL = flvBase || "https://api-cdn.pond5.com/", getURL = function(id, type, baseURL) {
+ var url;
+ switch (type) {
+ case "icon":
+ url = iconBase + ExtendedID.extend(id) + "_iconv.jpeg";
+ break;
+ case "H264":
+ url = baseURL + ExtendedID.extend(id) + "_main_xl.mp4";
+ break;
+ case "vr360":
+ url = baseURL + ExtendedID.extend(id) + "_main360.mp4";
+ break;
+ case "mov":
+ url = baseURL + ExtendedID.extend(id) + "_prev_264.mov";
+ break;
+ case "flv":
+ url = baseURL + ExtendedID.extend(id) + "_prev_xl.flv";
+ break;
+ case "mp3":
+ url = baseURL + ExtendedID.extend(id) + "_prev.mp3";
+ break;
+ case "m4a":
+ url = baseURL + ExtendedID.extend(id) + "_prev.m4a";
+ break;
+ case "icon large":
+ url = iconBase + ExtendedID.extend(id) + "_iconl.jpeg"
+ }
+ return url
+ }, this.iconURL = getURL(this.id, "icon", this.baseURL), this.iconLargeURL = getURL(this.id, "icon large", this.baseURL), this.vr360 ? this.h264URL = getURL(this.id, "vr360", this.baseURL) : this.h264URL = getURL(this.id, "H264", this.baseURL), this.mp3URL = getURL(this.id, "mp3", this.baseURL), this.m4aURL = getURL(this.id, "m4a", this.baseURL), ItemVO.prototype = {}
+ };
+app.factory("LoginModel", [function() {
+ var data = {
+ getLoggedIn: function() {
+ return data.loggedIn
+ },
+ setLoggedIn: function(state) {
+ data.loggedIn = state
+ },
+ getCX: function() {
+ return data.cx
+ },
+ setCX: function(cx) {
+ data.cx = cx
+ },
+ getCM: function() {
+ return data.cm
+ },
+ setCM: function(cm) {
+ data.cm = cm
+ }
+ };
+ return data
+}]), app.service("MissingItemsModel", [function() {
+ return {
+ missingItemsVO: null
+ }
+}]);
+var MissingItemsVO = function MissingItemsVO(data) {
+ var i;
+ for (this.items = [], i = 0; i < data.items.length; i += 1) this.itemVO = new ItemVO(data.items[i], data.icon_base, data.flv_base), this.items[i] = this.itemVO;
+ MissingItemsVO.prototype = {}
+};
+app.factory("PreviewsModel", [function() {
+ var result = {
+ onPreviews: function(data) {
+ console.log("PreviewsModel onPreviews: ", data), result.previewsVO = new ItemsVO(data.commands[0])
+ }
+ };
+ return result
+}]);
+var PreviewVO = function PreviewVO(dest, path) {
+ var parts = (this.path = path).split("/");
+ this.name = parts[parts.length - 1], this.id = this.name.split(" ")[0], PreviewVO.prototype = {
+ toString: function() {
+ return "\nPreviewVO path: " + this.path + "\nname: " + this.name + "\nid: " + this.id
+ }
+ }
+};
+app.service("PurchasesModel", ["$rootScope", "AnalyticsService", function($rootScope, AnalyticsService) {
+ $rootScope.$on("on purchases", function(event, data) {
+ result.onGetPurchases(data)
+ }), $rootScope.$on("purchase complete", function(event) {
+ console.log("PurchasesModel purchase complete handler"), result.sendGA = !0
+ });
+ var result = {
+ purchasesVO: [],
+ sendGA: !1,
+ onGetPurchases: function(data) {
+ result.purchasesVO = new PurchaseVO(data.commands[0]), $rootScope.$emit("on purchases vo", result.purchasesVO), console.log("PurchasesModel onGetPurchases result.purchasesVO: ", result.purchasesVO), result.sendGA && (AnalyticsService.sendData(result.purchasesVO, "transaction"), result.sendGA = !1)
+ }
+ };
+ return result
+}]);
+var PurchaseVO = function PurchaseVO(data) {
+ var i;
+ this.items = [];
+ for ("AEFT" == HOST_NAME ? 200 : 102, i = 0; i < data.items.length; i += 1) {
+ var j;
+ for (this.itemVO = new ItemVO(data.items[i], data.icon_base, data.flv_base, data.items[i].bid), this.itemVO.transactionID = data.items[i].versions[0].tr, this.itemVO.name = data.items[i].versions[0].n, this.itemVO.abbrName = getAbbrName(this.itemVO.name, 30), this.itemVO.expirationDate = data.items[i].versions[0].exp, this.itemVO.parentFormatID = data.items[i].versions[0].vm, this.itemVO.type = getMediaType(getConvertedVideoStandard(data.items[i].versions[0].vs)), this.itemVO.aq = data.items[i].versions[0].aq, this.itemVO.versionID = data.items[i].versions[0].v, this.itemVO.version = data.items[i].versions[0].bitoffset, j = 0; j < data.items[i].versions.length; j += 1) this.itemVO.versions[j] = new ItemVO(data.items[i].versions[j], data.icon_base, data.flv_base, data.items[i].bid);
+ this.items.push(this.itemVO)
+ }
+ PurchaseVO.prototype = {
+ toString: function() {
+ console.log("name & id: ", this.items)
+ }
+ }
+};
+
+function checkNested(obj) {
+ for (var args = Array.prototype.slice.call(arguments), i = (obj = args.shift(), 0); i < args.length; i++) {
+ if (!obj.hasOwnProperty(args[i])) return !1;
+ obj = obj[args[i]]
+ }
+ return !0
+}
+
+function compare(a, b) {
+ return a.name < b.name ? -1 : a.name > b.name ? 1 : 0
+}
+
+function sortArgs() {
+ return Array.prototype.slice.call(arguments, 0).sort()[0]
+}
+
+function getAspectRatio(as) {
+ var standard;
+ switch (as) {
+ case 1:
+ standard = "4:3";
+ break;
+ case 2:
+ standard = "16:9 anamorphic";
+ break;
+ case 3:
+ standard = "16:9 letterboxed";
+ break;
+ case 4:
+ standard = "n/a";
+ break;
+ case 5:
+ standard = "Other";
+ break;
+ case 6:
+ standard = "16:9 native"
+ }
+ return standard
+}
+
+function convertAspectRatio($max_x, $max_y, $aspect_quotient) {
+ var $out_x, $out_y;
+ return $aspect_quotient ? ($out_y = $max_y, $max_x < ($out_x = Math.round($max_y * parseFloat($aspect_quotient))) && ($out_x = $max_x, $out_y = Math.round($max_x / parseFloat($aspect_quotient))), new Point($out_x, $out_y)) : ($out_x = $max_x, $out_y = $max_y, new Point(370, 208))
+}
+app.factory("ReplaceModel", ["$rootScope", function($rootScope) {
+ var result = {
+ clipsInSequences: [],
+ aeItemsinProjectView: [],
+ state: DEFAULT,
+ missingDownloads: [],
+ hiresOnFS: [],
+ previewsOnFS: [],
+ sequences: [],
+ setState: function(newState) {
+ result.state = newState, console.log("ReplaceModel STATE:", result.state), result.state === DEFAULT && $rootScope.$root.$emit("replacing complete")
+ },
+ getState: function() {
+ return result.state
+ },
+ getAEItems: function() {
+ return result.aeItemsinProjectView
+ },
+ setAEItems: function(items) {
+ result.aeItemsinProjectView = items
+ },
+ setSequenceNames: function(seqNames) {
+ result.sequences = [];
+ for (var i = 0; i < seqNames.length; i++) {
+ var obj = {
+ name: seqNames[i],
+ checked: !1
+ };
+ result.sequences[i] = obj
+ }
+ 0 < seqNames.length ? $rootScope.$root.$emit("modal select sequences", result.sequences) : ($rootScope.$root.$emit("modal simple requested", ["Replace With Hi-Res Clips - Warning", "The 'Replace With Hi-Res clips' button replaces lo-res previews with hi-res clips that you have purchased and downloaded. There are currently no sequences in your project."]), result.setState(DEFAULT))
+ },
+ setSequences: function(sequences) {
+ result.sequences = [];
+ for (var i = 0; i < sequences.length; i++) sequences[i].checked = !1;
+ var newArray = [];
+ newArray.push(sequences[0]);
+ for (i = 1; i < sequences.length; i++) {
+ for (var j = 0; j < newArray.length; j++) newArray[j].name === sequences[i].name && (console.log("already exists ", i, j, sequences[i].name), 0, sequences[i].name = sequences[i].name + " (id: " + sequences[i].id + ")");
+ newArray.push(sequences[i])
+ }
+ result.sequences = newArray, console.log("ReplaceModel, sequences:", result.sequences), 0 < sequences.length ? $rootScope.$root.$emit("modal select sequences", result.sequences) : ($rootScope.$root.$emit("modal simple requested", ["Replace With Hi-Res Clips - Warning", "The 'Replace With Hi-Res clips' button replaces lo-res previews with hi-res clips that you have purchased and downloaded. There are currently no sequences in your project."]), result.setState(DEFAULT))
+ },
+ setComps: function(comps) {
+ result.sequences = comps, $rootScope.$root.$emit("modal select comps", result.sequences)
+ },
+ addHires: function(dest, files) {
+ for (var hiresVO, i = 0; i < files.length; i += 1)(hiresVO = new HiresVO(dest, files[i].fileName)).type = files[i].vs, hiresVO.replace = !0, result.hiresOnFS.push(hiresVO)
+ }
+ };
+ return result
+}]), app.service("SearchModel", ["$rootScope", function($rootScope) {
+ var result = {
+ allowInfiniteScroll: !1,
+ searchResultItems: [],
+ numOfResults: 0,
+ onSearch: function(data) {
+ result.searchResultVO = new ItemsVO(data.commands[0]), result.numOfResults = data.commands[0].nbr_footage + data.commands[0].nbr_music + data.commands[0].nbr_sfx + data.commands[0].nbr_ae, console.log("SearchModel onSearch num of results: ", result.numOfResults), "replace" === result.resultType && (result.searchResultItems = [], window.scrollTo(0, 0), 0 === result.numOfResults ? $rootScope.$emit("message view requested", !0, NO_RESULTS, !0, NO_RESULTS_ICON) : $rootScope.$emit("message view requested", !1));
+ for (var i = 0; i < result.searchResultVO.items.length; i++) result.searchResultItems.push(result.searchResultVO.items[i]);
+ result.isSearching = !1, resizePanel()
+ },
+ sumOfBitmasks: "",
+ query: "",
+ filter: "1",
+ resultType: "replace",
+ page: 0,
+ isSearching: !1,
+ filteredItems: [],
+ fps: "",
+ fpsgt: "",
+ res: "",
+ pricegt: "",
+ pricelt: "",
+ durationgt: "",
+ durationlt: ""
+ };
+ return result
+}]), app.factory("UserModel", [function() {
+ var firstTimeUser = !0,
+ user = {
+ onUserInfo: function(data) {
+ user.setCredits(data.credit), user.setUserName(data.un), user.setFirstName(data.fn), user.setLastName(data.ln), user.setAvatarURL(data.icon_base, data.av)
+ },
+ setCredits: function(num) {
+ user.credits = num
+ },
+ getCredits: function() {
+ return user.credits
+ },
+ setUID: function(uid) {
+ user.uid = uid
+ },
+ getUID: function() {
+ return user.uid
+ },
+ setCM: function(cm) {
+ user.cm = cm
+ },
+ getCM: function() {
+ return user.cm
+ },
+ setCX: function(cx) {
+ user.cx = cx
+ },
+ getCX: function() {
+ return user.cx
+ },
+ setUserName: function(name) {
+ user.userName = name
+ },
+ getUserName: function() {
+ return user.userName
+ },
+ setFirstName: function(name) {
+ user.firstName = name
+ },
+ getFirstName: function() {
+ return user.firstName
+ },
+ setLastName: function(name) {
+ user.lastName = name
+ },
+ getLastName: function() {
+ return user.lastName
+ },
+ setAvatarURL: function(base, url) {
+ user.avatarURL = base + url
+ },
+ getAvatarURL: function() {
+ return user.avatarURL
+ },
+ setFirstTimeUser: function(state) {
+ firstTimeUser = state
+ },
+ getFirstTimeUser: function() {
+ return firstTimeUser
+ }
+ };
+ return user
+}]), app.factory("VersionsModel", ["$rootScope", function($rootScope) {
+ var result = {
+ versions: [],
+ setVersions: function(v) {
+ result.versions = [];
+ for (var i = 0; i < v.length; i++) result.versions[i] = v[i];
+ $rootScope.$emit("on versions selected", result.versions)
+ },
+ getVersions: function() {
+ return result.versions
+ }
+ };
+ return result
+}]), app.factory("ViewStateModel", ["$rootScope", "SearchModel", function($rootScope, SearchModel) {
+ var state;
+ return {
+ allowPreviews: !1,
+ setState: function(s) {
+ state = s, SearchModel.allowInfiniteScroll = "search" === state || ($rootScope.$emit("filters button clicked", !1), !1)
+ },
+ getState: function() {
+ return state
+ }
+ }
+}]), app.service("AnalyticsService", ["$http", "$rootScope", "UserModel", "CartModel", function($http, $rootScope, UserModel, CartModel) {
+ var result = {
+ sendData: function(data, type) {
+ GA_TRACKING_CODE,
+ UserModel.getUID(),
+ UserModel.getUID(),
+ HOST_NAME,
+ PLUGIN_VERSION
+ },
+ send: function(payload) {
+ $http({
+ method: "POST",
+ url: payload
+ }).then(function(response) {
+ console.log("AnalyticsService then: ", response)
+ }, function(response) {
+ console.log("AnalyticsService error: ", response)
+ })
+ }
+ };
+ return result
+}]), app.service("Service", ["$rootScope", "APIService", "LoginModel", "UserModel", "SearchModel", "FreebiesModel", "BinsModel", "ViewStateModel", "DownloadModel", "CheckOutModel", "PreviewsModel", "ReplaceModel", "ViewStateService", "ImportedPreviewsService", "AnalyticsService", "UserService", "BillingInfoModel", function($rootScope, APIService, LoginModel, UserModel, SearchModel, FreebiesModel, BinsModel, ViewStateModel, DownloadModel, CheckOutModel, PreviewsModel, ReplaceModel, ViewStateService, ImportedPreviewsService, AnalyticsService, UserService, BillingInfoModel) {
+ $rootScope.$on("api call", function(event, apiObj) {
+ call[apiObj.fn](sortArgs(apiObj.args))
+ });
+ var call = {
+ login: function() {
+ var obj = [{
+ command: "login",
+ username: arguments[0][0],
+ password: arguments[0][1]
+ }];
+ APIService.call(obj).then(function(data) {
+ LoginModel.setLoggedIn(!0), LoginModel.setCX(data.commands[0].cx), LoginModel.setCM(data.commands[0].cm), UserService.saveData(data.commands[0].cx, data.commands[0].cm), call.getUserInfo()
+ }).catch(function(err) {})
+ },
+ logout: function() {
+ console.log("Service logout");
+ APIService.call([{
+ command: "logout"
+ }]).then(function(data) {
+ LoginModel.setLoggedIn(!1)
+ }).catch(function(err) {})
+ },
+ getUserInfo: function() {
+ APIService.call([{
+ command: "userinfo"
+ }]).then(function(data) {
+ "" != data.commands[0].uid && (UserModel.onUserInfo(data.commands[0]), call.getBins(), setTimeout(function() {
+ call.getCart()
+ }, 1e3), call.getActiveBin(), call.getBillingAddresses(), LoginModel.getLoggedIn() || LoginModel.setLoggedIn(!0))
+ }).catch(function(err) {})
+ },
+ search: function() {
+ var obj = [{
+ command: "search",
+ query: SearchModel.query + SearchModel.res + SearchModel.fps + SearchModel.fpsgt + SearchModel.pricegt + SearchModel.pricelt + SearchModel.durationgt + SearchModel.durationlt,
+ sb: SearchModel.filter,
+ bm: SearchModel.sumOfBitmasks,
+ no: "25",
+ p: SearchModel.page,
+ col: "1523"
+ }];
+ APIService.call(obj).then(function(data) {
+ SearchModel.onSearch(data), ViewStateModel.allowPreviews = !0
+ }).catch(function(err) {})
+ },
+ getFreeClips: function() {
+ APIService.call([{
+ command: "get_free_clips"
+ }]).then(function(data) {
+ FreebiesModel.onFreebies(data)
+ }).catch(function(err) {})
+ },
+ getCart: function() {
+ APIService.call([{
+ command: "get_cart_formatted",
+ artistinfo: "1"
+ }]).then(function(data) {
+ console.log("Service getCart data", data), $rootScope.$emit("on cart", data)
+ }).catch(function(err) {})
+ },
+ getCartTotal: function() {
+ var obj = [{
+ command: "get_cart_total",
+ addressid: BillingInfoModel.getDefaultInfo() ? BillingInfoModel.getDefaultInfo().addressid : "",
+ use_credits: "1"
+ }];
+ APIService.call(obj).then(function(data) {
+ $rootScope.$emit("on cart total", data)
+ }).catch(function(err) {})
+ },
+ getBillingAddresses: function(setState) {
+ APIService.call([{
+ command: "get_billing_addresses"
+ }]).then(function(data) {
+ BillingInfoModel.onBillingInfo(data), setState && $rootScope.$emit("on modal choose billing info requested"), call.getCartTotal()
+ }).catch(function(err) {})
+ },
+ setBillingAddress: function(info) {
+ console.log("Service setBillingAddresses obj:", info);
+ var data = info[0];
+ data.addressID || (data.addressID = "");
+ var obj = [{
+ command: "set_billing_address",
+ country: data.country,
+ addressid: data.addressID,
+ first_name: data.firstName,
+ last_name: data.lastName,
+ company_name: data.organization,
+ company_department: data.department,
+ company_id: data.companyID,
+ vat_id: data.vatID,
+ street1: data.street1,
+ street2: data.street2,
+ city: data.city,
+ state: data.state,
+ province: data.province,
+ postal_code: data.zipCode
+ }];
+ APIService.call(obj).then(function(data) {
+ call.getBillingAddresses(!0)
+ }).catch(function(err) {})
+ },
+ getBins: function() {
+ APIService.call([{
+ command: "get_bins"
+ }]).then(function(data) {
+ BinsModel.onBins(data)
+ }).catch(function(err) {})
+ },
+ getActiveBin: function() {
+ APIService.call([{
+ command: "get_active_bin"
+ }]).then(function(data) {
+ BinsModel.onActiveBin(data)
+ }).catch(function(err) {})
+ },
+ setActiveBin: function(id) {
+ var obj = [{
+ command: "set_active_bin",
+ binid: id
+ }];
+ APIService.call(obj).then(function(data) {
+ setTimeout(function() {
+ call.getActiveBin()
+ }, 1e3)
+ }).catch(function(err) {})
+ },
+ getBin: function() {
+ var obj = [{
+ command: "get_bin_formatted",
+ binid: BinsModel.showBin.id
+ }];
+ APIService.call(obj).then(function(data) {
+ BinsModel.onBin(data)
+ }).catch(function(err) {})
+ },
+ modifyBin: function(binID, addID, rmID) {
+ var obj = [{
+ command: "modify_active_bin",
+ binid: binID,
+ addid: addID,
+ rmid: rmID
+ }];
+ APIService.call(obj).then(function(data) {
+ "1" == data.commands[0].nbr_removed ? call.getBin(BinsModel.binVO.id) : $rootScope.$emit("added to bin")
+ }).catch(function(err) {})
+ },
+ createBin: function(binName) {
+ var obj = [{
+ command: "create_bin",
+ name: binName
+ }];
+ APIService.call(obj).then(function(data) {
+ BinsModel.newBinName;
+ call.setActiveBin(data.commands[0].binid), call.getBins()
+ }).catch(function(err) {})
+ },
+ removeBin: function(id) {
+ var obj = [{
+ command: "delete_bin",
+ binid: id
+ }];
+ APIService.call(obj).then(function(data) {
+ call.getBins(), $rootScope.$emit("collection removed", data)
+ }).catch(function(err) {})
+ },
+ getPurchases: function() {
+ APIService.call([{
+ command: "get_downloads_formatted"
+ }]).then(function(data) {
+ console.log("Service getPurchases data", data), $rootScope.$emit("on purchases", data)
+ }).catch(function(err) {})
+ },
+ getPurchaseURL: function(itemID, transactionID, versionID, version) {
+ console.log("Service getPurchaseURL", itemID, transactionID, versionID, version);
+ var obj = [{
+ command: "download",
+ bid: itemID,
+ tr: transactionID,
+ v: versionID,
+ bitoffset: version
+ }];
+ APIService.call(obj).then(function(data) {
+ console.log("Service getPurchaseURL data", data), DownloadModel.downloadingBatchURLs ? DownloadModel.onGetAllPurchaseURLs(data) : DownloadModel.onGetPurchaseURL(data)
+ }).catch(function(err) {})
+ },
+ modifyCart: function() {
+ var obj = [{
+ command: "modify_active_cart",
+ addid: arguments[0][0],
+ rmid: arguments[0][1]
+ }];
+ APIService.call(obj).then(function(data) {
+ 1 === data.commands[0].nbr_added && $rootScope.$emit("added to cart"), call.getCart(), call.getCartTotal()
+ }).catch(function(err) {})
+ },
+ purchaseWithCredits: function(buyAnyway, userData) {
+ var obj = [{
+ command: "purchase_using_credits",
+ override: buyAnyway,
+ userdata: userData,
+ addressid: BillingInfoModel.getDefaultInfo().addressid
+ }];
+ APIService.call(obj).then(function(data) {
+ console.log("purchaseWithCredits data", data), ReplaceModel.getState() === DEFAULT && $rootScope.$emit("modal simple requested", ["Your purchase has been successful!", "Your items are now ready to download."]), $rootScope.$emit("purchase complete"), ReplaceModel.getState() === NOT_PURCHASED ? call.getPurchases() : ViewStateService.viewRequested("downloads"), call.getUserInfo()
+ }).catch(function(err) {})
+ },
+ purchaseWithCash: function(buyAnyway, userData) {
+ var obj = [{
+ command: "purchase_using_cash",
+ AdobePremierePlugin: "html",
+ override: buyAnyway,
+ userdata: userData,
+ addressid: BillingInfoModel.getDefaultInfo().addressid,
+ use_credits: "1"
+ }];
+ APIService.call(obj).then(function(data) {
+ console.log("Service purchaseWithCash data", data), CheckOutModel.onPurchase(data)
+ }).catch(function(err) {})
+ },
+ promoRedeem: function(code) {
+ var obj = [{
+ command: "promo_redeem",
+ promocode: code
+ }];
+ APIService.call(obj).then(function(data) {
+ call.getUserInfo(), $rootScope.$emit("promo code added", data)
+ }).catch(function(err) {})
+ },
+ getImportedPreviews: function() {
+ console.log("Service getImportedPreviews", ImportedPreviewsService.idsString);
+ var obj = [{
+ command: "get_clip_data_array",
+ itemids: ImportedPreviewsService.idsString,
+ col: "1523",
+ verboselvl: "100"
+ }];
+ APIService.call(obj).then(function(data) {
+ PreviewsModel.onPreviews(data)
+ }).catch(function(err) {})
+ },
+ getFormats: function(item) {
+ console.log("Service getFormats", item.id);
+ var obj = [{
+ command: "get_versions_formatted",
+ vm: item.id
+ }];
+ APIService.call(obj).then(function(data) {
+ console.log("Service getFormats data", data);
+ var formats = data.commands[0].items;
+ $rootScope.$emit("formats complete", item, formats)
+ }).catch(function(err) {})
+ },
+ getFormatsReplacing: function(item) {
+ console.log("Service getFormatsReplacing", item.id);
+ var obj = [{
+ command: "get_versions_formatted",
+ vm: item.id
+ }];
+ APIService.call(obj).then(function(data) {
+ console.log("Service getFormatsReplacing data", data);
+ var formats = data.commands[0].items;
+ $rootScope.$emit("formats replacing complete", item, formats)
+ }).catch(function(err) {})
+ },
+ getMissingItems: function(itemIDsString) {
+ console.log("Service getMissingItems itemIDsString", itemIDsString);
+ var obj = [{
+ command: "get_clip_data_array",
+ itemids: itemIDsString,
+ col: "1523",
+ verboselvl: "100"
+ }];
+ APIService.call(obj).then(function(data) {
+ ReplaceModel.setState(MISSING_ITEMS), console.log("Service getMissingItems data", data), $rootScope.$emit("missing items complete", data)
+ }).catch(function(err) {})
+ }
+ };
+ return call
+}]), app.factory("APIService", ["$http", "ViewStateModel", "LoginModel", function($http, ViewStateModel, LoginModel) {
+ return {
+ call: function(data) {
+ ViewStateModel.allowPreviews = !1;
+ var url, secret, apiKey, _0xf310 = ["test", "https://test.pond5.com/?page=api", "live", "https://www.pond5.com/?page=api", "oi23Jan3Inwh2io", "220655_769351580"];
+ MODE === _0xf310[0] ? API_URL = _0xf310[1] : MODE === _0xf310[2] && (API_URL = _0xf310[3]), API_SECRET = _0xf310[4], API_KEY = _0xf310[5], url = API_URL, secret = API_SECRET, apiKey = API_KEY;
+ var stringified = JSON.stringify(data),
+ md5target = stringified + secret + "dragspel",
+ md5tostring = CryptoJS.MD5(md5target).toString(),
+ cx = LoginModel.getCX(),
+ cm = LoginModel.getCM(),
+ dataObj = {
+ api_key: apiKey,
+ commands_json: stringified,
+ commands_hash: md5tostring,
+ ver: 1,
+ https: 1
+ },
+ jsnstr = JSON.stringify(dataObj);
+ return $http({
+ url: url,
+ method: "POST",
+ data: "api=" + jsnstr + "&apicx=" + cx + "&apicm=" + cm,
+ headers: {
+ "Content-Type": "application/x-www-form-urlencoded"
+ }
+ }).then(function(result) {
+ return ViewStateModel.allowPreviews = !0, result.data
+ })
+ }
+ }
+}]), app.factory("myHttpInterceptor", ["$q", "$rootScope", "ViewStateModel", function($q, $rootScope, ViewStateModel) {
+ return {
+ response: function(response) {
+ var errorFree = !0;
+ return "POST" === response.config.method && (response.data.e ? (console.log("Apiservice myHttpInterceptor error >>>", response.data), errorFree = !1) : response.data.commands && response.data.commands.forEach(function(entry) {
+ if (entry && entry.hasOwnProperty("e")) {
+ if (response.config.data && -1 != response.config.data.indexOf("userinfo")) console.log("myHttpInterceptor user info, do not show alert ", response);
+ else if (103 === response.data.commands[0].c) response.data.commands[0].a && (console.log("APIService myHttpInterceptor alreadyBought or onwClips", response.data.commands[0].a), 0 < response.data.commands[0].a.bought_before.length && ($rootScope.$emit("alreadyBought", response.data.commands[0].a.bought_before), console.log("APIService myHttpInterceptor alreadyBought", response.data.commands[0].a.bought_before)), 0 < response.data.commands[0].a.ownClips.length && ($rootScope.$emit("ownClips", response.data.commands[0].a.ownClips), console.log("APIService myHttpInterceptor ownClips", response.data.commands[0].a.ownClips)));
+ else {
+ console.log("myHttpInterceptor modal simple requested :", entry), "You are not logged in" == entry.s.split(": ")[1] ? $rootScope.$emit("modal not logged in", [ERROR]) : $rootScope.$emit("modal simple requested", [ERROR, entry.s.split(": ")[1]])
+ }
+ errorFree = !1
+ }
+ })), errorFree ? response : $q.reject(response)
+ },
+ responseError: function(response) {
+ return response.config.url == MODAL_INTRO_HTML || response.config.url == MODAL_CHOOSE_BILLING_INFO_HTML ? console.log("apiService don't show error modal for ", response.config.url) : ($rootScope.$emit("modal simple requested", [ERROR, response.headers().status]), console.log("apiService don't show error modal but response ", response)), $q.reject(response)
+ }
+ }
+}]), app.config(function($httpProvider) {
+ $httpProvider.interceptors.push("myHttpInterceptor")
+}), app.service("CheckOutService", ["CartModel", "UserModel", "Service", function(CartModel, UserModel, Service) {
+ this.onCheckOutRequested = function(buyAnyway) {
+ console.log("CheckOutService total before VAT: ", CartModel.cartTotal.subtotals.afterVat), console.log("CheckOutService credits: ", CartModel.cartTotal.creditsData.availableSum), console.log("CheckOutService buyAnyway: ", buyAnyway), CartModel.cartTotal.creditsData.availableSum < CartModel.cartTotal.subtotals.afterVat ? Service.purchaseWithCash(buyAnyway) : Service.purchaseWithCredits(buyAnyway)
+ }
+}]), app.service("CreateOnFileSystemService", ["AppModel", "CreateFileCompleteService", function(AppModel, CreateFileCompleteService) {
+ var call = {
+ createUserHomeFolder: function() {
+ call.createDir(AppModel.getDirHomePond5())
+ },
+ createUserSubFolders: function() {
+ console.log("CreateOnFileSystemService createUserSubFolders", AppModel.getDirDefaultLib());
+ for (var dirs = [AppModel.getDirImports(), AppModel.getDirPrefs(), AppModel.getDirDefaultLib(), AppModel.getDirDestinations(), AppModel.getDirUser()], i = 0; i < dirs.length; i++) {
+ var dir = dirs[i];
+ call.createDir(dir)
+ }
+ },
+ createDestinationBaseFolder: function() {
+ call.createDir(AppModel.currentBaseFolder + path.sep + "pond5", !0)
+ },
+ createDestinationFolders: function() {
+ AppModel.previewsDir = AppModel.currentBaseFolder + path.sep + "pond5" + path.sep + "previews", AppModel.purchasedDir = AppModel.currentBaseFolder + path.sep + "pond5" + path.sep + "purchased", call.createDir(AppModel.previewsDir), call.createDir(AppModel.purchasedDir)
+ },
+ createDir: function(dir, isDestination) {
+ fs.exists(dir, function(exists) {
+ exists ? call.onDirReady(dir, isDestination) : fs.mkdir(dir, 511, function(err) {
+ if (err) throw err;
+ call.onDirReady(dir, isDestination)
+ })
+ })
+ },
+ onDirReady: function(dir, isDestination) {
+ if (isDestination = isDestination || !1) this.createDestinationFolders();
+ else {
+ var filePath, xml;
+ switch (dir) {
+ case AppModel.getDirHomePond5():
+ call.createUserSubFolders();
+ break;
+ case AppModel.getDirImports():
+ filePath = "imported_previews.xml", xml = ' ';
+ break;
+ case AppModel.getDirPrefs():
+ filePath = "preferences.xml", xml = ' ';
+ break;
+ case AppModel.getDirUser():
+ filePath = "user.xml", xml = ' ';
+ break;
+ case AppModel.getDirDestinations():
+ filePath = "destinations.xml", xml = ' ';
+ break;
+ case AppModel.getDirDefaultLib():
+ filePath = "defaultLib.xml", xml = ' ';
+ break;
+ case AppModel.currentBaseFolder:
+ this.createDestinationFolders();
+ break;
+ default:
+ return
+ }
+ filePath && call.createFile(dir + path.sep + filePath, '' + xml)
+ }
+ },
+ createFile: function(file, content) {
+ fs.exists(file, function(exists) {
+ exists ? CreateFileCompleteService.onFileReady(file) : fs.writeFile(file, content, function(err) {
+ if (err) throw err;
+ console.log("CreateOnFileSystemService, created file: ", file), CreateFileCompleteService.onFileReady(file)
+ })
+ })
+ }
+ };
+ return call
+}]), app.service("DeleteOnFileSystemService", [function() {
+ return {
+ deleteFiles: function(items) {
+ items.forEach(function(item) {
+ var file = item.downloadDestination + item.fileName;
+ fs.exists(file, function(exists) {
+ exists && fs.unlink(file, function(err) {
+ if (err) throw err
+ })
+ })
+ })
+ },
+ deleteFolder: function(folders, cb) {
+ console.log("DeleteOnFileSystemService deleteFolder, folders, length:", folders.length), folders.forEach(function(folder) {
+ console.log("DeleteOnFileSystemService deleteFolder, folder:", folder), fs.exists(folder, function(exists) {
+ exists ? rimraf(folder, function(err) {
+ if (err) throw err;
+ console.log("DeleteOnFileSystemService deleteFolder deleted: ", folder), cb()
+ }) : (console.log("DeleteOnFileSystemService deleteFile folder does not exist:", folder), cb())
+ })
+ })
+ }
+ }
+}]), app.factory("DownloadBatchService", ["Service", "PurchasesModel", "DownloadModel", function(Service, PurchasesModel, DownloadModel) {
+ return {
+ onBatchRequested: function(purchases) {
+ var j, i;
+ for (purchases = purchases || PurchasesModel.purchasesVO.items, i = 0; i < purchases.length; i += 1)
+ for (j = 0; j < PurchasesModel.purchasesVO.items.length; j += 1) purchases[i].id == PurchasesModel.purchasesVO.items[j].id && (purchases[i] = PurchasesModel.purchasesVO.items[j]);
+ for (DownloadModel.downloadingBatchURLs = !0, purchases = purchases.filter(function(v, i, a) {
+ return a.indexOf(v) == i
+ }), i = 0; i < purchases.length; i += 1) Service.getPurchaseURL(purchases[i].id, purchases[i].transactionID, purchases[i].versionID, purchases[i].version)
+ }
+ }
+}]), app.service("DownloadCancelService", ["$rootScope", "DeleteOnFileSystemService", "ProgressService", "DownloadModel", function($rootScope, DeleteOnFileSystemService, ProgressService, DownloadModel) {
+ return {
+ onCancelSingle: function(item) {
+ console.log("DownloadCancelService onCancelSingle: ", item, item.downloadType), item.canceled = !0, $rootScope.$emit("cancel download", item), ProgressService.clearItem(item), DeleteOnFileSystemService.deleteFiles([item]), item.downloading && (item.downloading = !1, DownloadModel.downloadCounter--);
+ for (var len = DownloadModel.itemsDownloadList.length; len--;)
+ if (DownloadModel.itemsDownloadList[len].fileName === item.fileName) {
+ var removal = DownloadModel.itemsDownloadList[len];
+ DownloadModel.itemsDownloadList = DownloadModel.itemsDownloadList.filter(function(itm) {
+ return itm !== removal
+ })
+ } console.log("DownloadCancelService onCancelSingle num of items: ", DownloadModel.itemsDownloadList.length), $rootScope.$emit("modal simple requested", ["", "Download of " + item.fileName + " has been canceled."], "sm")
+ },
+ onCancelAll: function() {
+ console.log("DownloadCancelService cancel all downloads", DownloadModel.itemsDownloadList);
+ for (var len = DownloadModel.itemsDownloadList.length; len--;) {
+ var item = DownloadModel.itemsDownloadList[len];
+ 100 !== item.progressPerc && (item.canceled = !0, $rootScope.$emit("cancel download", item), ProgressService.clearItem(item), DeleteOnFileSystemService.deleteFiles([item]))
+ }
+ $rootScope.$emit("modal simple requested", ["", "All incomplete downloads have been canceled and deleted."], "sm"), DownloadModel.downloadCounter = -1, DownloadModel.itemsDownloadList = []
+ }
+ }
+}]), app.service("DownloadCompleteService", ["$rootScope", "UnzipService", function($rootScope, UnzipService) {
+ return {
+ onComplete: function(items) {
+ UnzipService.unzipItems(items)
+ }
+ }
+}]), app.service("DownloadRequestService", ["$rootScope", "DownloadService", "ProgressService", "DownloadModel", "ReplaceModel", "AppModel", "ImportService", "ReplaceService", "StayAwakeService", "UnzipService", function($rootScope, DownloadService, ProgressService, DownloadModel, ReplaceModel, AppModel, ImportService, ReplaceService, StayAwakeService, UnzipService) {
+ $rootScope.$on("download requested", function(event, items) {
+ var downloadFolderName;
+ console.log("DownloadRequestService DownloadModel.itemsDownloadList: ", DownloadModel.itemsDownloadList), "preview" === items[0].downloadType ? downloadFolderName = "previews" : "purchase" === items[0].downloadType && (downloadFolderName = "purchased");
+ var item, dest = AppModel.currentBaseFolder + path.sep + "pond5" + path.sep + downloadFolderName + path.sep;
+ console.log("DownloadRequestService downloadRequested items:", items), $rootScope.$emit("scroll progress to top");
+ for (var i = 0; i < items.length; i++) {
+ var codec;
+ (item = items[i]).downloadDestination = dest, "preview" === item.downloadType ? "Video" == item.type || "AE" == item.type ? item.downloadURL = item.h264URL : "Sound effect" == item.type || "Music" == item.type ? item.downloadURL = item.m4aURL : "Photo" != item.type && "Illustration" != item.type || (item.downloadURL = item.iconLargeURL) : "purchase" === item.downloadType && (item.downloadURL = item.hiresURL), "Photo" == item.type ? item.ext = "jpg" : item.ext = item.downloadURL.substr(item.downloadURL.lastIndexOf(".") + 1).split("?")[0], item.videoCodec && (codec = item.videoCodec), "preview" !== item.downloadType && "unknown" !== codec && void 0 !== codec || (codec = ""), item.fileName = getFormattedName(item.id + " " + codec + " " + item.name + "." + item.ext), item.progressName = getAbbrName(item.fileName, 20), "preview" === item.downloadType && "AE" === item.vs && (item.fileName = "AE " + item.fileName), "purchase" === item.downloadType && ("AE" === item.vs ? item.fileName = "AE " + item.fileName : item.fileName = "hires " + item.fileName), $rootScope.$emit("open progress", !1), item.progressPerc = "", item.progressMB = "", ProgressService.addItem(item)
+ }
+ $rootScope.$$listenerCount["on item downloaded"] || $rootScope.$on("on item downloaded", function(event) {
+ DownloadModel.downloadCounter++, console.log("DownloadRequestService on item downloaded DownloadModel.downloadCounter: ", DownloadModel.downloadCounter), console.log("DownloadRequestService on item downloaded DownloadModel.itemsDownloadList: ", DownloadModel.itemsDownloadList);
+ var item = DownloadModel.itemsDownloadList[DownloadModel.downloadCounter];
+ if (item) {
+ StayAwakeService.updateState(!0);
+ new DownloadService.download(item)
+ } else if (StayAwakeService.updateState(!1), DownloadModel.downloadCounter--, console.log("DownloadRequestService download complete, check if something needs to be done, complete previews", ProgressService.getCompletedPreviews()), ProgressService.getCompletedPreviewsStatus() && ImportService.importClips(ProgressService.getCompletedPreviews()), ProgressService.getCompletedPurchasesStatus()) {
+ console.log("DownloadRequestService purchases completed: ", ProgressService.getCompletedPurchases()), console.log("DownloadRequestService purchases completed ReplaceModel.getState(): ", ReplaceModel.getState());
+ var AEItems = [];
+ if (ProgressService.getCompletedPurchases().forEach(function(item) {
+ "AE" == item.type && AEItems.push(item)
+ }), "1.0.8" != PLUGIN_VERSION && UnzipService.unzipItems(AEItems), ReplaceModel.getState() === NOT_DOWNLOADED) {
+ var dest = AppModel.currentBaseFolder + path.sep + "pond5" + path.sep + "purchased" + path.sep;
+ ProgressService.getCompletedPurchases().forEach(function(entry) {
+ ReplaceModel.addHires(dest, [entry])
+ }), ReplaceService.onPurchasedAndDownloaded(AEItems.length)
+ }
+ }
+ }), console.log("DownloadRequestService new request, ProgressService.getIncompleteItems ", ProgressService.getIncompleteItems()), 0 < ProgressService.getIncompleteItems().length && !ProgressService.getDownloadingStatus() && $rootScope.$emit("on item downloaded")
+ })
+}]), app.service("DownloadService", ["$rootScope", "ProgressService", function($rootScope, ProgressService) {
+ function download(item) {
+ console.log("DownloadService download item: ", item);
+ var allowWriting = !0;
+ $rootScope.$on("cancel download", function(event, itm) {
+ itm.fileName === item.fileName && (itm.canceled = !0, item.canceled = !0, allowWriting = !1)
+ }), item.downloading = !0;
+ var file, sizeOnFS, writeOptions, path = item.downloadDestination + item.fileName;
+ writeOptions = fs.existsSync(path) ? (sizeOnFS = fs.statSync(path).size, console.log("DownloadService sizeOnFS: ", sizeOnFS), {
+ flags: "r+"
+ }) : (console.log("DownloadService file does not exist yet, create stream"), {
+ flags: "w"
+ }), file = fs.createWriteStream(path, writeOptions), https.get(item.downloadURL, function(res) {
+ var len;
+ res.headers["content-length"] ? (len = parseInt(res.headers["content-length"], 10), console.log("DownloadService res has content-length: ", res)) : console.log("DownloadService content-length unknown", res);
+ var progressPerc, cur = 0,
+ total = len / 1048576;
+
+ function setToComplete() {
+ item.canceled || (item.progressPerc = 100, item.progressMB = total.toFixed(2) + "/" + total.toFixed(2) + "MB", item.completed = !0), item.canceled = !1, item.downloading = !1, $rootScope.$emit("on item downloaded"), $rootScope.$digest()
+ }
+ res.pipe(file), len <= sizeOnFS && (file.end(), setToComplete()), res.on("data", function(chunk) {
+ allowWriting ? (cur += chunk.length, progressPerc = (100 * cur / len).toFixed(2), $rootScope.$apply(function() {
+ item.progressPerc = progressPerc.split(".")[0], item.progressMB = (cur / 1048576).toFixed(2) + "/" + total.toFixed(2) + "MB"
+ })) : res.destroy()
+ }).on("error", function(e) {
+ console.log("DownloadService error: " + e.message)
+ }).on("end", function() {
+ file.end(), setToComplete()
+ })
+ }).on("error", function(err) {
+ console.error("Download Error code and filename:", err.code, item.fileName), console.error("Download err:", err), item.progressPerc = 0, item.progressMB = "", setTimeout(function() {
+ download(item, options)
+ }, 1e3)
+ })
+ }
+ return {
+ download: function(item, options) {
+ return new download(item, options)
+ }
+ }
+}]), app.service("ImportAEService", ["$rootScope", "ReplaceModel", function($rootScope, ReplaceModel) {
+ var call = {
+ showingModal: !1,
+ import: function(sourceDir) {
+ var walk = function(dir, done) {
+ var files = [];
+ fs.readdir(dir, function(err, list) {
+ if (err) return done(err);
+ var i = 0;
+ ! function next() {
+ var file = list[i++];
+ if (!file) return done(null, files);
+ file = dir + "/" + file, fs.stat(file, function(err, stat) {
+ stat && stat.isDirectory() ? walk(file, function(err, res) {
+ files = files.concat(res), next()
+ }) : (files.push(file), next())
+ })
+ }()
+ })
+ };
+ walk(sourceDir, function(err, files) {
+ if (err) throw err;
+ for (var i = 0; i < files.length; i += 1) console.log("ImportService file", files[i]), -1 != files[i].indexOf(".aep") && csInterface.evalScript("importAETemplate(" + JSON.stringify(files[i]) + ")", function(result) {
+ call.showingModal || ($rootScope.$emit("modal simple requested", ["", "Your project has been updated."]), call.showingModal = !0), console.log("ImportAEService import showingModal", call.showingModal)
+ })
+ })
+ }
+ };
+ return call
+}]), app.factory("ImportedPreviewsService", ["$rootScope", function($rootScope) {
+ var result = {
+ readXML: function() {
+ var dest = path.sep + "pond5" + path.sep + "imports" + path.sep + "imported_previews.xml";
+ result.file = getUserHome() + dest, fs.readFile(result.file, "utf8", function(err, data) {
+ if (err) throw err;
+ result.xml = data, result.parseXML()
+ })
+ },
+ saveItem: function(id) {
+ var idsString = result.idsString.toString(); - 1 == idsString.indexOf(id.toString()) && (0 < idsString.length ? result.idsString += "," + id : result.idsString = id, result.writeToDisk())
+ },
+ deleteItem: function(id) {
+ -1 != result.idsString.indexOf(id) && (result.idsString = result.idsString.replace(id, "")), "," == result.idsString.substr(0, 1) && (result.idsString = result.idsString.substr(1)), "," == result.idsString.substr(result.idsString.length - 1, result.idsString.length) && (result.idsString = result.idsString.slice(0, -1)), result.writeToDisk(), $rootScope.$emit("api call", {
+ fn: "getImportedPreviews"
+ })
+ },
+ parseXML: function() {
+ var parser = new xml2js.Parser;
+ parser.addListener("end", function(res) {
+ (result.parsedXML = res) && (result.idsString = res.root.previews[0].$.ids)
+ }), parser.parseString(result.xml)
+ },
+ writeToDisk: function() {
+ result.parsedXML.root.previews[0].$.ids = result.idsString;
+ var xml = (new xml2js.Builder).buildObject(result.parsedXML);
+ fs.writeFile(result.file, xml, function(err) {
+ if (err) throw err
+ })
+ }
+ };
+ return result
+}]), app.service("MissingItemsService", ["$rootScope", "MissingItemsModel", "ReplaceModel", "Service", "CartModel", "ReplaceServiceShared", function($rootScope, MissingItemsModel, ReplaceModel, Service, CartModel, ReplaceServiceShared) {
+ $rootScope.$on("missing items complete", function(event, items) {
+ console.log("MissingItemsService on missing items: ", items), ReplaceModel.getState() === MISSING_ITEMS && result.onMissingItems(items)
+ }), $rootScope.$on("formats replacing complete", function(event, item, formats) {
+ ReplaceModel.getState() === MISSING_ITEMS && result.onMissingItemsFormats(item, formats)
+ }), $rootScope.$on("on purchases vo", function(event, vo) {
+ console.log("MissingItemsService on purchases vo, state: ", ReplaceModel.getState()), ReplaceModel.getState() != DEFAULT && result.onPurchasesVO(vo)
+ });
+ var result = {
+ missingItemsCounter: 0,
+ onMissingItems: function(data) {
+ var missingItemsVO = new MissingItemsVO(data.commands[0]);
+ (MissingItemsModel.missingItemsVO = missingItemsVO).items.forEach(function(entry) {
+ Service.getFormatsReplacing(entry)
+ })
+ },
+ onMissingItemsFormats: function(item, formats) {
+ if (result.missingItemsCounter++, 1 < (formats = _.uniq(formats, function(p) {
+ return p.ti
+ })).length)
+ for (i = 0; i < formats.length; i++) item.formats[i] = new ItemVO(formats[i]), item.parentFormatID = item.id, item.formats[i].offset = formats[i].offset;
+ result.missingItemsCounter === MissingItemsModel.missingItemsVO.items.length && (result.missingItemsCounter = 0, Service.getPurchases())
+ },
+ onPurchasesVO: function(purchasesVO) {
+ for (var item, missingItems = MissingItemsModel.missingItemsVO.items, cartItems = CartModel.cartVO.items, purchasedItems = purchasesVO.items, i = 0; i < missingItems.length; i++) {
+ var cartItem, purchase;
+ item = missingItems[i];
+ for (var j = 0; j < cartItems.length; j++) {
+ cartItem = cartItems[j], item.id == cartItem.id && (item.inCart = !0);
+ for (var formats = item.formats, k = 0; k < formats.length; k++) formats[k].id == cartItem.id && formats[k].offset == cartItem.offset && (formats[k].inCart = !0, item.inCart = !0)
+ }
+ for (j = 0; j < purchasedItems.length; j++) {
+ purchase = purchasedItems[j], item.id == purchase.id && (item.inDownloads = !0, item.transactionID = purchase.transactionID);
+ for (formats = item.formats, k = 0; k < formats.length; k++) formats[k].id == purchase.id && (formats[k].inDownloads = !0, formats[k].transactionID = purchase.transactionID, purchasedItems[j].parentFormatID && (formats[k].parentFormatID = purchase.parentFormatID))
+ }
+ }
+ ReplaceModel.getState() === MISSING_ITEMS ? $rootScope.$emit("modal replace", missingItems) : ReplaceModel.getState() === NOT_PURCHASED && ReplaceServiceShared.onPurchased(missingItems)
+ }
+ };
+ return result
+}]), app.service("ProgressService", ["$rootScope", "DownloadModel", function($rootScope, DownloadModel) {
+ var result = {
+ alreadyHasItem: function(item) {
+ var itemsContainItem = !1;
+ return DownloadModel.itemsDownloadList.forEach(function(entry) {
+ entry.fileName === item.fileName && (itemsContainItem = !0)
+ }), itemsContainItem
+ },
+ addItem: function(item) {
+ DownloadModel.itemsDownloadList.forEach(function(entry) {
+ entry.fileName === item.fileName && (console.log("ProgressService already in list: ", item.fileName), item.completed = !1, item.imported = !1, item.canceled = !1, item.progressPerc = 0, item.progressMB = "", DownloadModel.downloadCounter--, result.clearItem(item), console.log("ProgressService already in list, cleared: ", DownloadModel.itemsDownloadList))
+ }), DownloadModel.itemsDownloadList.push(item), console.log("ProgressService addItem, list: ", DownloadModel.itemsDownloadList), $rootScope.$emit("added to progress")
+ },
+ clearCompleteItems: function() {
+ console.log("ProgressService clearCompleteItems ");
+ for (var len = DownloadModel.itemsDownloadList.length, oldLen = len; len--;) {
+ var item = DownloadModel.itemsDownloadList[len];
+ if (100 === item.progressPerc) {
+ item.completed = !1, item.imported = !1, item.canceled = !1, item.progressPerc = 0;
+ var removal = DownloadModel.itemsDownloadList[len];
+ DownloadModel.itemsDownloadList = DownloadModel.itemsDownloadList.filter(function(itm) {
+ return itm !== removal
+ })
+ }
+ }
+ var diff = oldLen - DownloadModel.itemsDownloadList.length;
+ DownloadModel.downloadCounter = DownloadModel.downloadCounter - diff, console.log("ProgressService clearCompleteItems DownloadModel.itemsDownloadList: ", DownloadModel.itemsDownloadList), console.log("ProgressService clearCompleteItems new downloadCounter: ", DownloadModel.downloadCounter), $rootScope.$emit("clear progress")
+ },
+ clearIncompleteItems: function() {
+ console.log("ProgressService clearIncompleteItems ");
+ for (var len = DownloadModel.itemsDownloadList.length; len--;)
+ if (100 !== DownloadModel.itemsDownloadList[len].progressPerc) {
+ var removal = DownloadModel.itemsDownloadList[len];
+ DownloadModel.itemsDownloadList = DownloadModel.itemsDownloadList.filter(function(itm) {
+ return itm !== removal
+ })
+ } $rootScope.$emit("on clear", DownloadModel.itemsDownloadList)
+ },
+ clearAllItems: function() {
+ console.log("ProgressService clearAllItems "), DownloadModel.itemsDownloadList = [], $rootScope.$emit("clear progress"), DownloadModel.downloadCounter = 0
+ },
+ clearItem: function(item) {
+ console.log("ProgressService clearItem ");
+ for (var len = DownloadModel.itemsDownloadList.length; len--;)
+ if (DownloadModel.itemsDownloadList[len].fileName === item.fileName) {
+ var removal = DownloadModel.itemsDownloadList[len];
+ DownloadModel.itemsDownloadList = DownloadModel.itemsDownloadList.filter(function(itm) {
+ return itm !== removal
+ })
+ } $rootScope.$emit("clear progress")
+ },
+ getIncompleteItems: function() {
+ var incompletes = [];
+ return DownloadModel.itemsDownloadList.forEach(function(entry) {
+ entry.completed || (console.log("ProgressService not completed: ", entry.fileName), incompletes.push(entry))
+ }), incompletes
+ },
+ getCompletedPreviewsStatus: function() {
+ var allCompleted = !0;
+ return DownloadModel.itemsDownloadList.forEach(function(entry) {
+ entry.completed || "preview" !== entry.downloadType || (allCompleted = !1)
+ }), 0 === DownloadModel.itemsDownloadList.length && (allCompleted = !1), console.log("ProgressService getCompletedPreviewsStatus allCompleted", allCompleted), allCompleted
+ },
+ getCompletedPreviews: function() {
+ var completes = [];
+ return DownloadModel.itemsDownloadList.forEach(function(entry) {
+ entry.completed && "preview" == entry.downloadType && completes.push(entry)
+ }), completes
+ },
+ getCompletedPurchasesStatus: function() {
+ var allCompleted = !0;
+ return DownloadModel.itemsDownloadList.forEach(function(entry) {
+ entry.completed || "purchase" !== entry.downloadType || (allCompleted = !1)
+ }), 0 === DownloadModel.itemsDownloadList.length && (allCompleted = !1), console.log("ProgressService getCompletedPurchasesStatus allCompleted", allCompleted), allCompleted
+ },
+ getCompletedPurchases: function() {
+ var completes = [];
+ return DownloadModel.itemsDownloadList.forEach(function(entry) {
+ entry.completed && "purchase" == entry.downloadType && completes.push(entry)
+ }), completes
+ },
+ getDownloadingStatus: function() {
+ var downloading = !1;
+ return DownloadModel.itemsDownloadList.forEach(function(entry) {
+ entry.downloading && (downloading = !0)
+ }), downloading
+ }
+ };
+ return result
+}]), app.service("ReadClipsOnFSService", ["$rootScope", "ReplaceModel", "MissingItemsModel", "ViewStateService", "DownloadBatchService", "AppModel", function($rootScope, ReplaceModel, MissingItemsModel, ViewStateService, DownloadBatchService, AppModel) {
+ var call = {
+ listPurchasesOnFS: function(cb) {
+ ReplaceModel.hiresOnFS = [];
+ for (var cbCounter = 0, i = 0; i < AppModel.baseFolders.length; i++) call.readPurchasesFolders(AppModel.baseFolders[i] + path.sep + "pond5" + path.sep + "purchased" + path.sep, function() {
+ ++cbCounter === AppModel.baseFolders.length && (console.log("\nReadClipsOnFSService ReplaceModel.hiresOnFS done: ", cbCounter, ReplaceModel.hiresOnFS), call.listPreviewsOnFS(function() {
+ cb()
+ }))
+ })
+ },
+ readPurchasesFolders: function(dest, cb) {
+ fs.readdir(dest, function(err, files) {
+ if (err) throw new Error("ReadClipsOnFSService: " + dest + " does not exist.");
+ var hiresVO;
+ files = files.filter(junk.not);
+ for (var i = 0; i < files.length; i += 1) hiresVO = new HiresVO(dest, files[i]), ReplaceModel.hiresOnFS.push(hiresVO), 0 === path.extname(files[i]).length ? hiresVO.type = "AE folder" : ".zip" === path.extname(files[i]) ? hiresVO.type = "AE zip" : ".mov" === path.extname(files[i]) ? hiresVO.type = "video" : ".wav" === path.extname(files[i]) && (hiresVO.type = "audio");
+ cb()
+ })
+ },
+ listPreviewsOnFS: function(cb) {
+ ReplaceModel.previewsOnFS = [];
+ for (var i = 0; i < AppModel.baseFolders.length; i++) {
+ var walk = function(dir, done) {
+ var files = [];
+ fs.readdir(dir, function(err, list) {
+ if (err) return done(err);
+ var i = 0;
+ ! function next() {
+ var file = list[i++];
+ if (!file) return done(null, files);
+ file = dir + "/" + file, fs.stat(file, function(err, stat) {
+ stat && stat.isDirectory() ? walk(file, function(err, res) {
+ files = files.concat(res), next()
+ }) : (files.push(file), next())
+ })
+ }()
+ })
+ },
+ dest = AppModel.baseFolders[i] + path.sep + "pond5" + path.sep + "previews",
+ counter = 0;
+ walk(dest, function(err, files) {
+ if (err) throw err;
+ for (var previewVO, i = 0; i < files.length; i += 1) previewVO = new PreviewVO(dest, files[i]), ReplaceModel.previewsOnFS.push(previewVO);
+ ++counter === AppModel.baseFolders.length && cb()
+ })
+ }
+ }
+ };
+ return call
+}]), app.service("ReplaceServiceShared", ["$rootScope", "ReplaceModel", "Service", "MissingItemsModel", "ViewStateService", "DownloadBatchService", "ImportAEService", "DeleteOnFileSystemService", function($rootScope, ReplaceModel, Service, MissingItemsModel, ViewStateService, DownloadBatchService, ImportAEService, DeleteOnFileSystemService) {
+ var call = {
+ removeDuplicates: function(clips) {
+ return clips = clips.filter(function(v, i, a) {
+ return a.indexOf(v) === i
+ })
+ },
+ getPreviewsOnFSNames: function() {
+ var previewNamesonFS = [];
+ return ReplaceModel.previewsOnFS.forEach(function(entry) {
+ previewNamesonFS.push(entry.name)
+ }), previewNamesonFS
+ },
+ filterNonP5Clips: function(clips, previewNamesOnFS) {
+ return clips = clips.filter(function(n) {
+ return -1 != previewNamesOnFS.indexOf(n)
+ })
+ },
+ getPreviewsIDs: function(clips) {
+ var previewIDs = [];
+ return clips.forEach(function(entry) {
+ var substr = entry.split(" ");
+ "AE" === substr[0] ? previewIDs.push(substr[1]) : previewIDs.push(substr[0])
+ }), console.log("\nReplaceServiceShared previewIDs: " + previewIDs), previewIDs
+ },
+ setReplaceProp: function(ids) {
+ for (var i = 0; i < ids.length; i++)
+ for (var j = 0; j < ReplaceModel.hiresOnFS.length; j++) ids[i] === ReplaceModel.hiresOnFS[j].id && (ReplaceModel.hiresOnFS[j].replace = !0)
+ },
+ getMissingItemIDs: function(clipsInSeqs) {
+ var clipsInSelectedSequences = clipsInSeqs;
+ console.log("ReplaceService ReplaceModel.aeItemsinProjectView: ", ReplaceModel.getAEItems()), 0 < ReplaceModel.getAEItems().length && (clipsInSelectedSequences = clipsInSelectedSequences.concat(ReplaceModel.getAEItems())), console.log("ReplaceService clips after concat layer items and AE items: ", clipsInSelectedSequences), clipsInSelectedSequences = call.removeDuplicates(clipsInSelectedSequences), console.log("\nReplaceServiceShared clipsInSelectedSequences after removing duplicates: ", clipsInSelectedSequences);
+ var previewNamesonFS = call.getPreviewsOnFSNames();
+ console.log("\nReplaceServiceShared previewNamesonFS: ", previewNamesonFS), clipsInSelectedSequences = call.filterNonP5Clips(clipsInSelectedSequences, previewNamesonFS), console.log("\nReplaceServiceShared after filterNonP5Clips", clipsInSelectedSequences);
+ var previewIDs = call.getPreviewsIDs(clipsInSelectedSequences);
+ console.log("\nReplaceServiceShared previewIDs: " + previewIDs), call.setReplaceProp(previewIDs), console.log("\nReplaceServiceShared after set replace: " + ReplaceModel.hiresOnFS);
+ var hiresIDs = call.getHiresIDsonFS();
+ console.log("\nReplaceServiceShared hiresIDs: " + hiresIDs);
+ var missingItemIDs = _(previewIDs).difference(hiresIDs),
+ missingIDsToString = missingItemIDs.join(",");
+ if (console.log("nReplaceServiceShared missingIDsToString: " + missingIDsToString), 0 < missingItemIDs.length) Service.getMissingItems(missingIDsToString);
+ else {
+ if (0 < hiresIDs.length) return hiresIDs.length;
+ 0 === clipsInSelectedSequences.length && (ReplaceModel.setState(DEFAULT), $rootScope.$emit("modal simple requested", ["", "There are no Pond5 previews in your current project."]))
+ }
+ },
+ getHiresIDsonFS: function() {
+ var hiresIDs = [];
+ return ReplaceModel.hiresOnFS.forEach(function(entry) {
+ (entry.replace || entry.importAE) && hiresIDs.push(entry.id)
+ }), hiresIDs
+ },
+ onModalReplaceOK: function() {
+ for (var item, missingItems = MissingItemsModel.missingItemsVO.items, itemsNotPurchased = [], itemsNotDownloaded = [], i = 0; i < missingItems.length; i++)(item = missingItems[i]).selected && !item.inDownloads && itemsNotPurchased.push(item), item.selected && item.inDownloads && itemsNotDownloaded.push(item);
+ 0 < itemsNotPurchased.length ? call.onNotPurchased(itemsNotPurchased) : 0 < itemsNotDownloaded.length ? (console.log("ReplaceServiceShared onModalReplaceOK, download items: ", itemsNotDownloaded), ReplaceModel.missingDownloads = itemsNotDownloaded, call.onNotDownloaded(itemsNotDownloaded)) : (ReplaceModel.setState(PURCHASED_AND_DOWNLOADED), console.log("ReplaceServiceShared onModalReplaceOK, replace"), call.onPurchasedAndDownloaded())
+ },
+ onNotPurchased: function(itemsNotPurchased) {
+ for (var addToCartItems = [], i = 0; i < itemsNotPurchased.length; i++)
+ if (item = itemsNotPurchased[i], 0 < itemsNotPurchased[i].formats.length)
+ for (var j = 0; j < itemsNotPurchased[i].formats.length; j++) format = itemsNotPurchased[i].formats[j], format.selected && (console.log("ReplaceServiceShared onNotPurchased add this format to cart: ", format), addToCartItems.push(format.id));
+ else console.log("ReplaceServiceShared onNotPurchased add this item to cart: ", item), addToCartItems.push(item.id);
+ $rootScope.$emit("modal simple requested", ["", "Please review your Cart. Press the 'Checkout' button to proceed with replacing your previews."]);
+ var apiObj = {
+ fn: "modifyCart",
+ args: [addToCartItems.join(","), ""]
+ };
+ $rootScope.$emit("api call", apiObj), ViewStateService.viewRequested("cart"), ReplaceModel.setState(NOT_PURCHASED)
+ },
+ onPurchased: function(downloadItems) {
+ console.log("ReplaceServiceShared onPurchased: ", downloadItems);
+ for (var item, missingItems = MissingItemsModel.missingItemsVO.items, itemsNotDownloaded = [], i = 0; i < missingItems.length; i++)(item = missingItems[i]).inDownloads && itemsNotDownloaded.push(item);
+ 0 < itemsNotDownloaded.length && (console.log("ReplaceServiceShared onPurchased, download items: ", itemsNotDownloaded), ReplaceModel.missingDownloads = itemsNotDownloaded, $rootScope.$emit("modal simple requested", ["Your purchase has been successful.", "Your purchased clips will begin downloading now. Once the downloads are completed, your lo-res previews will be replaced with your high-res clips."]), call.onNotDownloaded(itemsNotDownloaded, !0))
+ },
+ onNotDownloaded: function(itemsNotDownloaded, afterPurchase) {
+ afterPurchase = afterPurchase || !1, console.log("ReplaceServiceShared onNotDownloaded missing items:", itemsNotDownloaded);
+ for (var downloadItems = [], i = 0; i < itemsNotDownloaded.length; i++)
+ if (item = itemsNotDownloaded[i], 0 < itemsNotDownloaded[i].formats.length)
+ for (var j = 0; j < itemsNotDownloaded[i].formats.length; j++) format = itemsNotDownloaded[i].formats[j], format.selected && (console.log("ReplaceServiceShared onNotDownloaded download this format: ", format), downloadItems.push(format));
+ else console.log("ReplaceServiceShared onNotDownloaded download item: ", item), downloadItems.push(item);
+ afterPurchase || $rootScope.$emit("modal simple requested", ["You have purchases that are missing in your project. ", "They will be downloaded. Once the downloads are completed, your lo-res previews will be replaced with your high-res clips."]), DownloadBatchService.onBatchRequested(downloadItems), ReplaceModel.setState(NOT_DOWNLOADED)
+ }
+ };
+ return call
+}]), app.service("ScrollService", ["SearchModel", "Service", function(SearchModel, Service) {
+ this.onScroll = function() {
+ if (SearchModel.allowInfiniteScroll) {
+ var m = document.getElementById("main-holder");
+ 1 === (getScroll()[1] - 72) / (m.scrollHeight - window.innerHeight) && (console.log("ScrollService show more: " + SearchModel.isSearching), SearchModel.isSearching || (SearchModel.isSearching = !0, SearchModel.resultType = "add", SearchModel.page = SearchModel.page + 1, Service.search()))
+ }
+ }
+}]), app.factory("StartUpService", ["$rootScope", "CreateOnFileSystemService", "MissingItemsService", "ViewStateService", "AppModel", function($rootScope, CreateOnFileSystemService, MissingItemsService, ViewStateService, AppModel) {
+ return $("#logo").click(function() {
+ location.reload()
+ }), $rootScope.$on("environment set", function() {
+ console.log("StartUpService, 26/10 pointing at ", window.location.href), gup("tp", window.location.href) && (THIRD_PARTY = gup("tp", window.location.href)), -1 < window.location.href.indexOf("test") ? MODE = "test" : MODE = "live", console.log("StartUpService MODE:", MODE), console.log("StartUpService OS:", os.platform()), console.log("StartUpService, app version: ", PLUGIN_VERSION), AppModel.currentBaseFolder = AppModel.getDocumentsPath(), console.log("StartUpService currentBaseFolder: ", AppModel.currentBaseFolder + "\n\n"), CreateOnFileSystemService.createUserHomeFolder(), MissingItemsService.missingItemsCounter = 0, ViewStateService.viewRequested("search")
+ }), {
+ init: function() {
+ setTimeout(function() {
+ AppModel.setEnv()
+ }, 2e3)
+ }
+ }
+}]), app.factory("StayAwakeService", ["$rootScope", "DownloadModel", function($rootScope, DownloadModel) {
+ return {
+ updateState: function(state) {
+ console.log("StayAwakeService state: ", state), state && !DownloadModel.stayAwake ? (sleep.prevent(), DownloadModel.stayAwake = !0) : !state && DownloadModel.stayAwake && (sleep.allow(), DownloadModel.stayAwake = !1)
+ }
+ }
+}]), app.service("TransactionService", ["$q", "ViewStateService", "Service", "ReplaceModel", "AnalyticsService", "CartModel", function($q, ViewStateService, Service, ReplaceModel, AnalyticsService, CartModel) {
+ this.onMessageReceivedFromAdyen = function(event) {
+ console.log("event.source: ", event.source), console.log("event origin: ", event.origin), console.log("event data: ", event.data);
+ var deferred = $q.defer();
+ switch (event.data) {
+ case "PAID":
+ console.log("TransactionService PAID"), deferred.resolve("PAID"), ReplaceModel.getState() === NOT_PURCHASED ? Service.getPurchases() : ViewStateService.viewRequested("downloads"), AnalyticsService.sendData(null, "transaction"), Service.getUserInfo();
+ break;
+ case "CANCELED":
+ deferred.reject("CANCELED"), console.log("TransactionService CANCELED");
+ break;
+ case "PENDING":
+ console.log("TransactionService PENDING"), deferred.reject("PENDING");
+ break;
+ default:
+ deferred.reject("UNKNOWN")
+ }
+ return deferred.promise
+ }
+}]), app.service("UnzipService", ["$rootScope", "DeleteOnFileSystemService", "ReplaceModel", "ImportAEService", function($rootScope, DeleteOnFileSystemService, ReplaceModel, ImportAEService) {
+ var call = {
+ unzippedCounter: 0,
+ deletedCounter: 0,
+ numOfItems: 0,
+ items: [],
+ deleteObjects: [],
+ itemObjects: [],
+ unzipItems: function(items) {
+ call.unzippedCounter = 0, call.deletedCounter = 0, call.numOfItems = items.length, call.items = items, call.deleteObjects = [], call.itemObjects = [], call.items.forEach(function(item) {
+ var itemObj = {
+ dest: item.downloadDestination + "AE " + item.id,
+ source: item.downloadDestination + item.fileName
+ };
+ call.itemObjects.push(itemObj), call.deleteObjects.push(itemObj.source, itemObj.dest + path.sep + "__MACOSX"), call.unzip(itemObj)
+ }), console.log("UnzipService unzipItems numOfItems:", call.numOfItems), console.log("UnzipService unzipItems call.deleteObjects:", call.deleteObjects), console.log("UnzipService unzipItems call.deleteObjects.length:", call.deleteObjects.length)
+ },
+ unzip: function(itemObj) {
+ var unzipper = new DecompressZip(itemObj.source);
+ unzipper.on("error", function(err) {
+ console.log("UnzipService Caught an error: ", err)
+ }), unzipper.on("extract", function(log) {
+ console.log("UnzipService Finished extracting"), call.unzippedCounter++, call.unzippedCounter === call.numOfItems && (console.log("UnzipService Finished extracting all items, unzippedCounter", call.unzippedCounter), DeleteOnFileSystemService.deleteFolder(call.deleteObjects, function() {
+ console.log("UnzipService zip or mac os folder deleted"), call.deletedCounter++, console.log("UnzipService call.deletedCounter: ", call.deletedCounter), console.log("UnzipService call.deleteObjects.length: ", call.deleteObjects.length), call.deletedCounter === call.deleteObjects.length && (console.log("UnzipService ALL zip or mac os folders deleted", ReplaceModel.getState()), call.itemObjects.forEach(function(item) {
+ ReplaceModel.getState() === NOT_DOWNLOADED && "AEFT" == HOST_NAME && ImportAEService.import(item.dest)
+ }), ReplaceModel.getState() === DEFAULT && 1 < call.numOfItems ? opn(call.items[0].downloadDestination) : ReplaceModel.getState() === DEFAULT && 1 === call.numOfItems && (console.log("UnzipService opn finder"), opn(itemObj.dest)), ReplaceModel.setState(DEFAULT))
+ }))
+ }), unzipper.on("progress", function(fileIndex, fileCount) {
+ console.log("UnzipService Extracted file " + (fileIndex + 1) + " of " + fileCount)
+ }), unzipper.extract({
+ path: itemObj.dest
+ })
+ }
+ };
+ return call
+}]), app.factory("UserService", ["$rootScope", "AppModel", "LoginModel", function($rootScope, AppModel, LoginModel) {
+ var file, parsedLocalXML, cm, cx, result = {
+ readXML: function() {
+ file = AppModel.getUserXML(), fs.readFile(file, "utf8", function(err, data) {
+ if (err) throw err;
+ result.parseLocalXML(data)
+ })
+ },
+ saveData: function(cx, cm) {
+ parsedLocalXML.root.user[0].$.cm = cm, parsedLocalXML.root.user[0].$.cx = cx, result.writeToDisk()
+ },
+ parseLocalXML: function(xml) {
+ var parser = new xml2js.Parser;
+ parser.addListener("end", function(res) {
+ if (cm = (parsedLocalXML = res).root.user[0].$.cm, cx = res.root.user[0].$.cx, 0 < cm.length && 0 < cx.length) {
+ LoginModel.setCX(cx), LoginModel.setCM(cm);
+ $rootScope.$emit("api call", {
+ fn: "getUserInfo"
+ })
+ }
+ }), parser.parseString(xml)
+ },
+ writeToDisk: function() {
+ var xml = (new xml2js.Builder).buildObject(parsedLocalXML);
+ fs.writeFile(file, xml, function(err) {
+ if (err) throw err
+ })
+ }
+ };
+ return result
+}]), app.factory("ViewStateService", ["$rootScope", "ViewStateModel", "ReplaceModel", "LoginModel", function($rootScope, ViewStateModel, ReplaceModel, LoginModel) {
+ var requestedState, result = {
+ viewRequested: function(state) {
+ console.log("ViewStateService viewRequested: ", state), "downloads" !== (requestedState = state) && "previews" !== requestedState && "cart" !== requestedState || LoginModel.getLoggedIn() ? (ViewStateModel.setState(state), result.onViewApproved(!0)) : $rootScope.$emit("modal not logged in", [ERROR])
+ },
+ onViewApproved: function(result) {
+ if (console.log("ViewStateService onViewApproved ", result, requestedState), result) {
+ var fName;
+ switch (ViewStateModel.setState(requestedState), requestedState) {
+ case "downloads":
+ fName = "getPurchases";
+ break;
+ case "previews":
+ fName = "getImportedPreviews";
+ break;
+ case "cart":
+ fName = "getCart";
+ break;
+ case "freebies":
+ fName = "getFreeClips";
+ break;
+ case "bins":
+ fName = "getBin";
+ break;
+ case "search":
+ default:
+ fName = "search"
+ }
+ $rootScope.$emit("api call", {
+ fn: fName
+ })
+ } else console.log("ViewStateService onViewApproved cancel clicked in modal, stay in current view")
+ }
+ };
+ return result
+}]);
+var imgHeight, imgWidth, COUNTRIES = [{
+ name: "United States",
+ code: "US"
+ }, {
+ name: "Afghanistan",
+ code: "AF"
+ }, {
+ name: "Aland Islands",
+ code: "AX"
+ }, {
+ name: "Albania",
+ code: "AL"
+ }, {
+ name: "Algeria",
+ code: "DZ"
+ }, {
+ name: "American Samoa",
+ code: "AS"
+ }, {
+ name: "Andorra",
+ code: "AD"
+ }, {
+ name: "Angola",
+ code: "AO"
+ }, {
+ name: "Anguilla",
+ code: "AI"
+ }, {
+ name: "Antarctica",
+ code: "AQ"
+ }, {
+ name: "Antigua and Barbuda",
+ code: "AG"
+ }, {
+ name: "Argentina",
+ code: "AR"
+ }, {
+ name: "Armenia",
+ code: "AM"
+ }, {
+ name: "Aruba",
+ code: "AW"
+ }, {
+ name: "Australia",
+ code: "AU"
+ }, {
+ name: "Austria",
+ code: "AT"
+ }, {
+ name: "Azerbaijan",
+ code: "AZ"
+ }, {
+ name: "Bahamas",
+ code: "BS"
+ }, {
+ name: "Bahrain",
+ code: "BH"
+ }, {
+ name: "Bangladesh",
+ code: "BD"
+ }, {
+ name: "Barbados",
+ code: "BB"
+ }, {
+ name: "Belarus",
+ code: "BY"
+ }, {
+ name: "Belgium",
+ code: "BE"
+ }, {
+ name: "Belize",
+ code: "BZ"
+ }, {
+ name: "Benin",
+ code: "BJ"
+ }, {
+ name: "Bermuda",
+ code: "BM"
+ }, {
+ name: "Bhutan",
+ code: "BT"
+ }, {
+ name: "Bolivia",
+ code: "BO"
+ }, {
+ name: "Bosnia and Herzegovina",
+ code: "BA"
+ }, {
+ name: "Botswana",
+ code: "BW"
+ }, {
+ name: "Bouvet Island",
+ code: "BV"
+ }, {
+ name: "Brazil",
+ code: "BR"
+ }, {
+ name: "British Indian Ocean Territory",
+ code: "IO"
+ }, {
+ name: "Brunei Darussalam",
+ code: "BN"
+ }, {
+ name: "Bulgaria",
+ code: "BG"
+ }, {
+ name: "Burkina Faso",
+ code: "BF"
+ }, {
+ name: "Burundi",
+ code: "BI"
+ }, {
+ name: "Cambodia",
+ code: "KH"
+ }, {
+ name: "Cameroon",
+ code: "CM"
+ }, {
+ name: "Canada",
+ code: "CA"
+ }, {
+ name: "Cape Verde",
+ code: "CV"
+ }, {
+ name: "Cayman Islands",
+ code: "KY"
+ }, {
+ name: "Central African Republic",
+ code: "CF"
+ }, {
+ name: "Chad",
+ code: "TD"
+ }, {
+ name: "Chile",
+ code: "CL"
+ }, {
+ name: "China",
+ code: "CN"
+ }, {
+ name: "Christmas Island",
+ code: "CX"
+ }, {
+ name: "Cocos (Keeling) Islands",
+ code: "CC"
+ }, {
+ name: "Colombia",
+ code: "CO"
+ }, {
+ name: "Comoros",
+ code: "KM"
+ }, {
+ name: "Congo",
+ code: "CG"
+ }, {
+ name: "Congo, The Democratic Republic of the",
+ code: "CD"
+ }, {
+ name: "Cook Islands",
+ code: "CK"
+ }, {
+ name: "Costa Rica",
+ code: "CR"
+ }, {
+ name: "Cote D'Ivoire",
+ code: "CI"
+ }, {
+ name: "Croatia",
+ code: "HR"
+ }, {
+ name: "Cuba",
+ code: "CU"
+ }, {
+ name: "Cyprus",
+ code: "CY"
+ }, {
+ name: "Czech Republic",
+ code: "CZ"
+ }, {
+ name: "Denmark",
+ code: "DK"
+ }, {
+ name: "Djibouti",
+ code: "DJ"
+ }, {
+ name: "Dominica",
+ code: "DM"
+ }, {
+ name: "Dominican Republic",
+ code: "DO"
+ }, {
+ name: "Ecuador",
+ code: "EC"
+ }, {
+ name: "Egypt",
+ code: "EG"
+ }, {
+ name: "El Salvador",
+ code: "SV"
+ }, {
+ name: "Equatorial Guinea",
+ code: "GQ"
+ }, {
+ name: "Eritrea",
+ code: "ER"
+ }, {
+ name: "Estonia",
+ code: "EE"
+ }, {
+ name: "Ethiopia",
+ code: "ET"
+ }, {
+ name: "Falkland Islands (Malvinas)",
+ code: "FK"
+ }, {
+ name: "Faroe Islands",
+ code: "FO"
+ }, {
+ name: "Fiji",
+ code: "FJ"
+ }, {
+ name: "Finland",
+ code: "FI"
+ }, {
+ name: "France",
+ code: "FR"
+ }, {
+ name: "French Guiana",
+ code: "GF"
+ }, {
+ name: "French Polynesia",
+ code: "PF"
+ }, {
+ name: "French Southern Territories",
+ code: "TF"
+ }, {
+ name: "Gabon",
+ code: "GA"
+ }, {
+ name: "Gambia",
+ code: "GM"
+ }, {
+ name: "Georgia",
+ code: "GE"
+ }, {
+ name: "Germany",
+ code: "DE"
+ }, {
+ name: "Ghana",
+ code: "GH"
+ }, {
+ name: "Gibraltar",
+ code: "GI"
+ }, {
+ name: "Greece",
+ code: "GR"
+ }, {
+ name: "Greenland",
+ code: "GL"
+ }, {
+ name: "Grenada",
+ code: "GD"
+ }, {
+ name: "Guadeloupe",
+ code: "GP"
+ }, {
+ name: "Guam",
+ code: "GU"
+ }, {
+ name: "Guatemala",
+ code: "GT"
+ }, {
+ name: "Guernsey",
+ code: "GG"
+ }, {
+ name: "Guinea",
+ code: "GN"
+ }, {
+ name: "Guinea-Bissau",
+ code: "GW"
+ }, {
+ name: "Guyana",
+ code: "GY"
+ }, {
+ name: "Haiti",
+ code: "HT"
+ }, {
+ name: "Heard Island and Mcdonald Islands",
+ code: "HM"
+ }, {
+ name: "Holy See (Vatican City State)",
+ code: "VA"
+ }, {
+ name: "Honduras",
+ code: "HN"
+ }, {
+ name: "Hong Kong",
+ code: "HK"
+ }, {
+ name: "Hungary",
+ code: "HU"
+ }, {
+ name: "Iceland",
+ code: "IS"
+ }, {
+ name: "India",
+ code: "IN"
+ }, {
+ name: "Indonesia",
+ code: "ID"
+ }, {
+ name: "Iran, Islamic Republic Of",
+ code: "IR"
+ }, {
+ name: "Iraq",
+ code: "IQ"
+ }, {
+ name: "Ireland",
+ code: "IE"
+ }, {
+ name: "Isle of Man",
+ code: "IM"
+ }, {
+ name: "Israel",
+ code: "IL"
+ }, {
+ name: "Italy",
+ code: "IT"
+ }, {
+ name: "Jamaica",
+ code: "JM"
+ }, {
+ name: "Japan",
+ code: "JP"
+ }, {
+ name: "Jersey",
+ code: "JE"
+ }, {
+ name: "Jordan",
+ code: "JO"
+ }, {
+ name: "Kazakhstan",
+ code: "KZ"
+ }, {
+ name: "Kenya",
+ code: "KE"
+ }, {
+ name: "Kiribati",
+ code: "KI"
+ }, {
+ name: "Korea, Democratic People's Republic of",
+ code: "KP"
+ }, {
+ name: "Korea, Republic of",
+ code: "KR"
+ }, {
+ name: "Kuwait",
+ code: "KW"
+ }, {
+ name: "Kyrgyzstan",
+ code: "KG"
+ }, {
+ name: "Lao People's Democratic Republic",
+ code: "LA"
+ }, {
+ name: "Latvia",
+ code: "LV"
+ }, {
+ name: "Lebanon",
+ code: "LB"
+ }, {
+ name: "Lesotho",
+ code: "LS"
+ }, {
+ name: "Liberia",
+ code: "LR"
+ }, {
+ name: "Libyan Arab Jamahiriya",
+ code: "LY"
+ }, {
+ name: "Liechtenstein",
+ code: "LI"
+ }, {
+ name: "Lithuania",
+ code: "LT"
+ }, {
+ name: "Luxembourg",
+ code: "LU"
+ }, {
+ name: "Macao",
+ code: "MO"
+ }, {
+ name: "Macedonia, The Former Yugoslav Republic of",
+ code: "MK"
+ }, {
+ name: "Madagascar",
+ code: "MG"
+ }, {
+ name: "Malawi",
+ code: "MW"
+ }, {
+ name: "Malaysia",
+ code: "MY"
+ }, {
+ name: "Maldives",
+ code: "MV"
+ }, {
+ name: "Mali",
+ code: "ML"
+ }, {
+ name: "Malta",
+ code: "MT"
+ }, {
+ name: "Marshall Islands",
+ code: "MH"
+ }, {
+ name: "Martinique",
+ code: "MQ"
+ }, {
+ name: "Mauritania",
+ code: "MR"
+ }, {
+ name: "Mauritius",
+ code: "MU"
+ }, {
+ name: "Mayotte",
+ code: "YT"
+ }, {
+ name: "Mexico",
+ code: "MX"
+ }, {
+ name: "Micronesia, Federated States of",
+ code: "FM"
+ }, {
+ name: "Moldova, Republic of",
+ code: "MD"
+ }, {
+ name: "Monaco",
+ code: "MC"
+ }, {
+ name: "Mongolia",
+ code: "MN"
+ }, {
+ name: "Montserrat",
+ code: "MS"
+ }, {
+ name: "Morocco",
+ code: "MA"
+ }, {
+ name: "Mozambique",
+ code: "MZ"
+ }, {
+ name: "Myanmar",
+ code: "MM"
+ }, {
+ name: "Namibia",
+ code: "NA"
+ }, {
+ name: "Nauru",
+ code: "NR"
+ }, {
+ name: "Nepal",
+ code: "NP"
+ }, {
+ name: "Netherlands",
+ code: "NL"
+ }, {
+ name: "Netherlands Antilles",
+ code: "AN"
+ }, {
+ name: "New Caledonia",
+ code: "NC"
+ }, {
+ name: "New Zealand",
+ code: "NZ"
+ }, {
+ name: "Nicaragua",
+ code: "NI"
+ }, {
+ name: "Niger",
+ code: "NE"
+ }, {
+ name: "Nigeria",
+ code: "NG"
+ }, {
+ name: "Niue",
+ code: "NU"
+ }, {
+ name: "Norfolk Island",
+ code: "NF"
+ }, {
+ name: "Northern Mariana Islands",
+ code: "MP"
+ }, {
+ name: "Norway",
+ code: "NO"
+ }, {
+ name: "Oman",
+ code: "OM"
+ }, {
+ name: "Pakistan",
+ code: "PK"
+ }, {
+ name: "Palau",
+ code: "PW"
+ }, {
+ name: "Palestinian Territory, Occupied",
+ code: "PS"
+ }, {
+ name: "Panama",
+ code: "PA"
+ }, {
+ name: "Papua New Guinea",
+ code: "PG"
+ }, {
+ name: "Paraguay",
+ code: "PY"
+ }, {
+ name: "Peru",
+ code: "PE"
+ }, {
+ name: "Philippines",
+ code: "PH"
+ }, {
+ name: "Pitcairn",
+ code: "PN"
+ }, {
+ name: "Poland",
+ code: "PL"
+ }, {
+ name: "Portugal",
+ code: "PT"
+ }, {
+ name: "Puerto Rico",
+ code: "PR"
+ }, {
+ name: "Qatar",
+ code: "QA"
+ }, {
+ name: "Reunion",
+ code: "RE"
+ }, {
+ name: "Romania",
+ code: "RO"
+ }, {
+ name: "Russian Federation",
+ code: "RU"
+ }, {
+ name: "Rwanda",
+ code: "RW"
+ }, {
+ name: "Saint Helena",
+ code: "SH"
+ }, {
+ name: "Saint Kitts and Nevis",
+ code: "KN"
+ }, {
+ name: "Saint Lucia",
+ code: "LC"
+ }, {
+ name: "Saint Pierre and Miquelon",
+ code: "PM"
+ }, {
+ name: "Saint Vincent and the Grenadines",
+ code: "VC"
+ }, {
+ name: "Samoa",
+ code: "WS"
+ }, {
+ name: "San Marino",
+ code: "SM"
+ }, {
+ name: "Sao Tome and Principe",
+ code: "ST"
+ }, {
+ name: "Saudi Arabia",
+ code: "SA"
+ }, {
+ name: "Senegal",
+ code: "SN"
+ }, {
+ name: "Serbia and Montenegro",
+ code: "CS"
+ }, {
+ name: "Seychelles",
+ code: "SC"
+ }, {
+ name: "Sierra Leone",
+ code: "SL"
+ }, {
+ name: "Singapore",
+ code: "SG"
+ }, {
+ name: "Slovakia",
+ code: "SK"
+ }, {
+ name: "Slovenia",
+ code: "SI"
+ }, {
+ name: "Solomon Islands",
+ code: "SB"
+ }, {
+ name: "Somalia",
+ code: "SO"
+ }, {
+ name: "South Africa",
+ code: "ZA"
+ }, {
+ name: "South Georgia and the South Sandwich Islands",
+ code: "GS"
+ }, {
+ name: "Spain",
+ code: "ES"
+ }, {
+ name: "Sri Lanka",
+ code: "LK"
+ }, {
+ name: "Sudan",
+ code: "SD"
+ }, {
+ name: "Suriname",
+ code: "SR"
+ }, {
+ name: "Svalbard and Jan Mayen",
+ code: "SJ"
+ }, {
+ name: "Swaziland",
+ code: "SZ"
+ }, {
+ name: "Sweden",
+ code: "SE"
+ }, {
+ name: "Switzerland",
+ code: "CH"
+ }, {
+ name: "Syrian Arab Republic",
+ code: "SY"
+ }, {
+ name: "Taiwan, Province of China",
+ code: "TW"
+ }, {
+ name: "Tajikistan",
+ code: "TJ"
+ }, {
+ name: "Tanzania, United Republic of",
+ code: "TZ"
+ }, {
+ name: "Thailand",
+ code: "TH"
+ }, {
+ name: "Timor-Leste",
+ code: "TL"
+ }, {
+ name: "Togo",
+ code: "TG"
+ }, {
+ name: "Tokelau",
+ code: "TK"
+ }, {
+ name: "Tonga",
+ code: "TO"
+ }, {
+ name: "Trinidad and Tobago",
+ code: "TT"
+ }, {
+ name: "Tunisia",
+ code: "TN"
+ }, {
+ name: "Turkey",
+ code: "TR"
+ }, {
+ name: "Turkmenistan",
+ code: "TM"
+ }, {
+ name: "Turks and Caicos Islands",
+ code: "TC"
+ }, {
+ name: "Tuvalu",
+ code: "TV"
+ }, {
+ name: "Uganda",
+ code: "UG"
+ }, {
+ name: "Ukraine",
+ code: "UA"
+ }, {
+ name: "United Arab Emirates",
+ code: "AE"
+ }, {
+ name: "United Kingdom",
+ code: "GB"
+ }, {
+ name: "United States",
+ code: "US"
+ }, {
+ name: "United States Minor Outlying Islands",
+ code: "UM"
+ }, {
+ name: "Uruguay",
+ code: "UY"
+ }, {
+ name: "Uzbekistan",
+ code: "UZ"
+ }, {
+ name: "Vanuatu",
+ code: "VU"
+ }, {
+ name: "Venezuela",
+ code: "VE"
+ }, {
+ name: "Vietnam",
+ code: "VN"
+ }, {
+ name: "Virgin Islands, British",
+ code: "VG"
+ }, {
+ name: "Virgin Islands, U.S.",
+ code: "VI"
+ }, {
+ name: "Wallis and Futuna",
+ code: "WF"
+ }, {
+ name: "Western Sahara",
+ code: "EH"
+ }, {
+ name: "Yemen",
+ code: "YE"
+ }, {
+ name: "Zambia",
+ code: "ZM"
+ }, {
+ name: "Zimbabwe",
+ code: "ZW"
+ }],
+ STATES = [{
+ name: "Alabama",
+ label: "Alabama",
+ code: "AL"
+ }, {
+ name: "Alaska",
+ label: "Alaska",
+ code: "AK"
+ }, {
+ name: "American Samoa",
+ label: "American Samoa",
+ code: "AS"
+ }, {
+ name: "Arizona",
+ label: "Arizona",
+ code: "AZ"
+ }, {
+ name: "Arkansas",
+ label: "Arkansas",
+ code: "AR"
+ }, {
+ name: "Armed Forces Europe",
+ label: "Armed Forces Europe",
+ code: "AE"
+ }, {
+ name: "Armed Forces Pacific",
+ label: "Armed Forces Pacific",
+ code: "AP"
+ }, {
+ name: "Armed Forces the Americas",
+ label: "Armed Forces the Americas",
+ code: "AA"
+ }, {
+ name: "California",
+ label: "California",
+ code: "CA"
+ }, {
+ name: "Colorado",
+ label: "Colorado",
+ code: "CO"
+ }, {
+ name: "Connecticut",
+ label: "Connecticut",
+ code: "CT"
+ }, {
+ name: "Delaware",
+ label: "Delaware",
+ code: "DE"
+ }, {
+ name: "District of Columbia",
+ label: "District of Columbia",
+ code: "DC"
+ }, {
+ name: "Federated States of Micronesia",
+ label: "Federated States of Micronesia",
+ code: "FM"
+ }, {
+ name: "Florida",
+ label: "Florida",
+ code: "FL"
+ }, {
+ name: "Georgia",
+ label: "Georgia",
+ code: "GA"
+ }, {
+ name: "Guam",
+ label: "Guam",
+ code: "GU"
+ }, {
+ name: "Hawaii",
+ label: "Hawaii",
+ code: "HI"
+ }, {
+ name: "Idaho",
+ label: "Idaho",
+ code: "ID"
+ }, {
+ name: "Illinois",
+ label: "Illinois",
+ code: "IL"
+ }, {
+ name: "Indiana",
+ label: "Indiana",
+ code: "IN"
+ }, {
+ name: "Iowa",
+ label: "Iowa",
+ code: "IA"
+ }, {
+ name: "Kansas",
+ label: "Kansas",
+ code: "KS"
+ }, {
+ name: "Kentucky",
+ label: "Kentucky",
+ code: "KY"
+ }, {
+ name: "Louisiana",
+ label: "Louisiana",
+ code: "LA"
+ }, {
+ name: "Maine",
+ label: "Maine",
+ code: "ME"
+ }, {
+ name: "Marshall Islands",
+ label: "Marshall Islands",
+ code: "MH"
+ }, {
+ name: "Maryland",
+ label: "Maryland",
+ code: "MD"
+ }, {
+ name: "Massachusetts",
+ label: "Massachusetts",
+ code: "MA"
+ }, {
+ name: "Michigan",
+ label: "Michigan",
+ code: "MI"
+ }, {
+ name: "Minnesota",
+ label: "Minnesota",
+ code: "MN"
+ }, {
+ name: "Mississippi",
+ label: "Mississippi",
+ code: "MS"
+ }, {
+ name: "Missouri",
+ label: "Missouri",
+ code: "MO"
+ }, {
+ name: "Montana",
+ label: "Montana",
+ code: "MT"
+ }, {
+ name: "Nebraska",
+ label: "Nebraska",
+ code: "NE"
+ }, {
+ name: "Nevada",
+ label: "Nevada",
+ code: "NV"
+ }, {
+ name: "New Hampshire",
+ label: "New Hampshire",
+ code: "NH"
+ }, {
+ name: "New Jersey",
+ label: "New Jersey",
+ code: "NJ"
+ }, {
+ name: "New Mexico",
+ label: "New Mexico",
+ code: "NM"
+ }, {
+ name: "New York",
+ label: "New York",
+ code: "NY"
+ }, {
+ name: "North Carolina",
+ label: "North Carolina",
+ code: "NC"
+ }, {
+ name: "North Dakota",
+ label: "North Dakota",
+ code: "ND"
+ }, {
+ name: "Northern Mariana Islands",
+ label: "Northern Mariana Islands",
+ code: "MP"
+ }, {
+ name: "Ohio",
+ label: "Ohio",
+ code: "OH"
+ }, {
+ name: "Oklahoma",
+ label: "Oklahoma",
+ code: "OK"
+ }, {
+ name: "Oregon",
+ label: "Oregon",
+ code: "OR"
+ }, {
+ name: "Pennsylvania",
+ label: "Pennsylvania",
+ code: "PA"
+ }, {
+ name: "Puerto Rico",
+ label: "Puerto Rico",
+ code: "PR"
+ }, {
+ name: "Rhode Island",
+ label: "Rhode Island",
+ code: "RI"
+ }, {
+ name: "South Carolina",
+ label: "South Carolina",
+ code: "SC"
+ }, {
+ name: "South Dakota",
+ label: "South Dakota",
+ code: "SD"
+ }, {
+ name: "Tennessee",
+ label: "Tennessee",
+ code: "TN"
+ }, {
+ name: "Texas",
+ label: "Texas",
+ code: "TX"
+ }, {
+ name: "Utah",
+ label: "Utah",
+ code: "UT"
+ }, {
+ name: "Vermont",
+ label: "Vermont",
+ code: "VT"
+ }, {
+ name: "Virgin Islands, U.S.",
+ label: "Virgin Islands, U.S.",
+ code: "VI"
+ }, {
+ name: "Virginia",
+ label: "Virginia",
+ code: "VA"
+ }, {
+ name: "Washington",
+ label: "Washington",
+ code: "WA"
+ }, {
+ name: "West Virginia",
+ label: "West Virginia",
+ code: "WV"
+ }, {
+ name: "Wisconsin",
+ label: "Wisconsin",
+ code: "WI"
+ }, {
+ name: "Wyoming",
+ label: "Wyoming",
+ code: "WY"
+ }];
+
+function get_browser() {
+ var tem, ua = navigator.userAgent,
+ M = ua.match(/(opera|chrome|safari|firefox|msie|trident(?=\/))\/?\s*(\d+)/i) || [];
+ return /trident/i.test(M[1]) ? "IE " + ((tem = /\brv[ :]+(\d+)/g.exec(ua) || [])[1] || "") : "Chrome" === M[1] && null != (tem = ua.match(/\bOPR\/(\d+)/)) ? "Opera " + tem[1] : (M = M[2] ? [M[1], M[2]] : [navigator.appName, navigator.appVersion, "-?"], null != (tem = ua.match(/version\/(\d+)/i)) && M.splice(1, 1, tem[1]), M[0])
+}
+
+function get_browser_version() {
+ var tem, ua = navigator.userAgent,
+ M = ua.match(/(opera|chrome|safari|firefox|msie|trident(?=\/))\/?\s*(\d+)/i) || [];
+ return /trident/i.test(M[1]) ? "IE " + ((tem = /\brv[ :]+(\d+)/g.exec(ua) || [])[1] || "") : "Chrome" === M[1] && null != (tem = ua.match(/\bOPR\/(\d+)/)) ? "Opera " + tem[1] : (M = M[2] ? [M[1], M[2]] : [navigator.appName, navigator.appVersion, "-?"], null != (tem = ua.match(/version\/(\d+)/i)) && M.splice(1, 1, tem[1]), M[1])
+}
+
+function findHHandWW() {
+ return imgHeight = this.height, imgWidth = this.width, !0
+}
+
+function showImage(imgPath) {
+ var myImage = new Image;
+ myImage.name = imgPath, myImage.onload = findHHandWW, myImage.src = imgPath
+}
+
+function log(className, prefix, obj) {
+ if (prefix = " " + prefix + ": ", obj instanceof Array) obj.forEach(function(entry) {
+ log(className, "item", entry)
+ });
+ else
+ for (key in console.log(className + ":"), obj) console.log(prefix + key + ": " + obj[key]), "formats" === key && obj[key].forEach(function(entry) {
+ log(className, " format", entry)
+ }), "versions" === key && obj[key].forEach(function(entry) {
+ log(className, " versions", entry)
+ })
+}
+
+function ExtendedID() {}
+
+function getAbbrName(name, len) {
+ return name && name.length > len ? name.slice(0, len) + "..." : name
+}
+
+function convertArrayToCommaSeperatedString(ids) {
+ var idsToString = "";
+ return ids.forEach(function(id) {
+ idsToString += id + ","
+ }), idsToString = idsToString.slice(0, -1)
+}
+
+function getFormattedName(input) {
+ for (; - 1 != input.indexOf(",");) input = input.replace(",", " ");
+ for (; - 1 != input.indexOf("&");) input = input.replace("&", "and");
+ for (; - 1 != input.indexOf("/");) input = input.replace("/", " ");
+ for (; - 1 != input.indexOf("'");) input = input.replace("'", " ");
+ for (; - 1 != input.indexOf("(");) input = input.replace("(", " ");
+ for (; - 1 != input.indexOf(")");) input = input.replace(")", " ");
+ for (; - 1 != input.indexOf(":");) input = input.replace(":", " ");
+ for (; - 1 != input.indexOf(" ");) input = input.replace(" ", " ");
+ return input
+}
+
+function getUID() {
+ var d = (new Date).getTime();
+ return "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, function(c) {
+ var r = (d + 16 * Math.random()) % 16 | 0;
+ return d = Math.floor(d / 16), ("x" == c ? r : 3 & r | 8).toString(16)
+ })
+}
+
+function getStringPosition(string, subString, index) {
+ return string.split(subString, index).join(subString).length
+}
+
+function gup(name, url) {
+ url || (url = location.href), name = name.replace(/[\[]/, "\\[").replace(/[\]]/, "\\]");
+ var results = new RegExp("[\\?&]" + name + "=([^]*)").exec(url);
+ return null == results ? null : results[1]
+}
+
+function checkVersion(tv, uv) {
+ var updaterVersion = uv;
+ if (tv === updaterVersion) return !1;
+ var splitThis = tv.split("."),
+ splitThisInt = [];
+ splitThis.forEach(function(string) {
+ splitThisInt.push(parseInt(string))
+ });
+ var splitUpdater = updaterVersion.split("."),
+ splitUpdaterInt = [];
+ return splitUpdater.forEach(function(string) {
+ splitUpdaterInt.push(parseInt(string))
+ }), splitUpdaterInt[0] > splitThisInt[0] || (splitUpdaterInt[0] >= splitThisInt[0] && splitUpdaterInt[1] > splitThisInt[1] || splitUpdaterInt[0] >= splitThisInt[0] && splitUpdaterInt[1] >= splitThisInt[1] && splitUpdaterInt[2] > splitThisInt[2])
+}
+
+function getConvertedVideoStandard(vs) {
+ var standard;
+ switch (parseInt(vs)) {
+ case 0:
+ standard = "Multimedia / Unknown";
+ break;
+ case 1:
+ standard = "NTSC D1";
+ break;
+ case 2:
+ standard = "NTSC DV";
+ break;
+ case 3:
+ standard = "PAL / PAL DV";
+ break;
+ case 4:
+ standard = "HD 1080";
+ break;
+ case 5:
+ standard = "HDV 720p";
+ break;
+ case 6:
+ standard = "Other Hi-Def";
+ break;
+ case 7:
+ standard = "Multimedia";
+ break;
+ case 8:
+ standard = "HDV 1080i";
+ break;
+ case 9:
+ standard = "HD 720";
+ break;
+ case 10:
+ standard = "4k+";
+ break;
+ case 100:
+ standard = "Music";
+ break;
+ case 101:
+ standard = "Sound effect";
+ break;
+ case 200:
+ standard = "AE";
+ break;
+ case 300:
+ standard = "Photo";
+ break;
+ case 301:
+ standard = "Illustration";
+ break;
+ case 400:
+ standard = "3D"
+ }
+ return standard
+}
+
+function getMediaType(vs) {
+ var type;
+ switch (vs) {
+ case "Music":
+ case "Sound effect":
+ case "Photo":
+ case "Illustration":
+ case "AE":
+ type = vs;
+ break;
+ default:
+ type = "Video"
+ }
+ return type
+}
+Number.prototype.formatMoney = function(decPlaces, thouSeparator, decSeparator, currencySymbol) {
+ decPlaces = isNaN(decPlaces = Math.abs(decPlaces)) ? 2 : decPlaces, decSeparator = null == decSeparator ? "." : decSeparator, thouSeparator = null == thouSeparator ? "," : thouSeparator, currencySymbol = null == currencySymbol ? "$" : currencySymbol;
+ var n = this,
+ sign = n < 0 ? "-" : "",
+ i = parseInt(n = Math.abs(+n || 0).toFixed(decPlaces)) + "",
+ j = 3 < (j = i.length) ? j % 3 : 0;
+ return sign + currencySymbol + (j ? i.substr(0, j) + thouSeparator : "") + i.substr(j).replace(/(\d{3})(?=\d)/g, "$1" + thouSeparator) + (decPlaces ? decSeparator + Math.abs(n - i).toFixed(decPlaces).slice(2) : "")
+ },
+ function() {
+ function Point(x, y) {
+ this.x = x || 0, this.y = y || 0
+ }
+ Point.prototype.x = null, Point.prototype.y = null, Point.prototype.add = function(v) {
+ return new Point(this.x + v.x, this.y + v.y)
+ }, Point.prototype.clone = function() {
+ return new Point(this.x, this.y)
+ }, Point.prototype.degreesTo = function(v) {
+ var dx = this.x - v.x,
+ dy = this.y - v.y;
+ return Math.atan2(dy, dx) * (180 / Math.PI)
+ }, Point.prototype.distance = function(v) {
+ var x = this.x - v.x,
+ y = this.y - v.y;
+ return Math.sqrt(x * x + y * y)
+ }, Point.prototype.equals = function(toCompare) {
+ return this.x == toCompare.x && this.y == toCompare.y
+ }, Point.prototype.interpolate = function(v, f) {
+ return new Point((this.x + v.x) * f, (this.y + v.y) * f)
+ }, Point.prototype.length = function() {
+ return Math.sqrt(this.x * this.x + this.y * this.y)
+ }, Point.prototype.normalize = function(thickness) {
+ var l = this.length();
+ this.x = this.x / l * thickness, this.y = this.y / l * thickness
+ }, Point.prototype.orbit = function(origin, arcWidth, arcHeight, degrees) {
+ var radians = degrees * (Math.PI / 180);
+ this.x = origin.x + arcWidth * Math.cos(radians), this.y = origin.y + arcHeight * Math.sin(radians)
+ }, Point.prototype.offset = function(dx, dy) {
+ this.x += dx, this.y += dy
+ }, Point.prototype.subtract = function(v) {
+ return new Point(this.x - v.x, this.y - v.y)
+ }, Point.prototype.toString = function() {
+ return "(x=" + this.x + ", y=" + this.y + ")"
+ }, Point.interpolate = function(pt1, pt2, f) {
+ return new Point((pt1.x + pt2.x) * f, (pt1.y + pt2.y) * f)
+ }, Point.polar = function(len, angle) {
+ return new Point(len * Math.sin(angle), len * Math.cos(angle))
+ }, Point.distance = function(pt1, pt2) {
+ var x = pt1.x - pt2.x,
+ y = pt1.y - pt2.y;
+ return Math.sqrt(x * x + y * y)
+ }, this.Point = window.Point = Point
+ }(), ExtendedID.extend = function(id) {
+ if (id) {
+ for (var extendedID = id.toString(); extendedID.length < 9;) extendedID = "0" + extendedID;
+ return extendedID
+ }
+ }, String.prototype.insert = function(index, string) {
+ return 0 < index ? this.substring(0, index) + string + this.substring(index, this.length) : string + this
+ }, String.prototype.replaceAll = function(search, replacement) {
+ return this.replace(new RegExp(search, "g"), replacement)
+ }, getMousePosition = function(element) {
+ for (var xPosition = 0, yPosition = 0; element;) xPosition += element.offsetLeft - element.scrollLeft + element.clientLeft, yPosition += element.offsetTop - element.scrollTop + element.clientTop, element = element.offsetParent;
+ return {
+ x: xPosition,
+ y: yPosition
+ }
+ }, getScroll = function() {
+ if (null != window.pageYOffset) return [pageXOffset, pageYOffset];
+ var d = document,
+ r = d.documentElement,
+ b = d.body;
+ return [r.scrollLeft || b.scrollLeft || 0, r.scrollTop || b.scrollTop || 0]
+ }, getUserHome = function() {
+ return require("os").homedir()
+ }, getName = function(input) {
+ for (; - 1 != input.indexOf(",");) input = input.replace(",", " ");
+ for (; - 1 != input.indexOf("&");) input = input.replace("&", "and");
+ for (; - 1 != input.indexOf("/");) input = input.replace("/", " ");
+ for (; - 1 != input.indexOf("'");) input = input.replace("'", " ");
+ for (; - 1 != input.indexOf("(");) input = input.replace("(", " ");
+ for (; - 1 != input.indexOf(")");) input = input.replace(")", " ");
+ for (; - 1 != input.indexOf(":");) input = input.replace(":", " ");
+ return input
+ }, getPosition = function(element) {
+ for (var xPosition = 0, yPosition = 0; element;) xPosition += element.offsetLeft - element.scrollLeft + element.clientLeft, yPosition += element.offsetTop - element.scrollTop + element.clientTop, element = element.offsetParent;
+ return {
+ x: xPosition,
+ y: yPosition
+ }
+ }, getChromeVersion = function() {
+ var raw = navigator.userAgent.match(/Chrom(e|ium)\/([0-9]+)\./);
+ return !!raw && parseInt(raw[2], 10)
+ };
diff --git a/pype/premiere/extensions/com.pond5.ppro/remote/index_files/jquery-3.3.1.min.js b/pype/premiere/extensions/com.pond5.ppro/remote/index_files/jquery-3.3.1.min.js
new file mode 100644
index 0000000000..4d9b3a2587
--- /dev/null
+++ b/pype/premiere/extensions/com.pond5.ppro/remote/index_files/jquery-3.3.1.min.js
@@ -0,0 +1,2 @@
+/*! jQuery v3.3.1 | (c) JS Foundation and other contributors | jquery.org/license */
+!function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(e,t){"use strict";var n=[],r=e.document,i=Object.getPrototypeOf,o=n.slice,a=n.concat,s=n.push,u=n.indexOf,l={},c=l.toString,f=l.hasOwnProperty,p=f.toString,d=p.call(Object),h={},g=function e(t){return"function"==typeof t&&"number"!=typeof t.nodeType},y=function e(t){return null!=t&&t===t.window},v={type:!0,src:!0,noModule:!0};function m(e,t,n){var i,o=(t=t||r).createElement("script");if(o.text=e,n)for(i in v)n[i]&&(o[i]=n[i]);t.head.appendChild(o).parentNode.removeChild(o)}function x(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?l[c.call(e)]||"object":typeof e}var b="3.3.1",w=function(e,t){return new w.fn.init(e,t)},T=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;w.fn=w.prototype={jquery:"3.3.1",constructor:w,length:0,toArray:function(){return o.call(this)},get:function(e){return null==e?o.call(this):e<0?this[e+this.length]:this[e]},pushStack:function(e){var t=w.merge(this.constructor(),e);return t.prevObject=this,t},each:function(e){return w.each(this,e)},map:function(e){return this.pushStack(w.map(this,function(t,n){return e.call(t,n,t)}))},slice:function(){return this.pushStack(o.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(n>=0&&n0&&t-1 in e)}var E=function(e){var t,n,r,i,o,a,s,u,l,c,f,p,d,h,g,y,v,m,x,b="sizzle"+1*new Date,w=e.document,T=0,C=0,E=ae(),k=ae(),S=ae(),D=function(e,t){return e===t&&(f=!0),0},N={}.hasOwnProperty,A=[],j=A.pop,q=A.push,L=A.push,H=A.slice,O=function(e,t){for(var n=0,r=e.length;n+~]|"+M+")"+M+"*"),z=new RegExp("="+M+"*([^\\]'\"]*?)"+M+"*\\]","g"),X=new RegExp(W),U=new RegExp("^"+R+"$"),V={ID:new RegExp("^#("+R+")"),CLASS:new RegExp("^\\.("+R+")"),TAG:new RegExp("^("+R+"|[*])"),ATTR:new RegExp("^"+I),PSEUDO:new RegExp("^"+W),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+P+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},G=/^(?:input|select|textarea|button)$/i,Y=/^h\d$/i,Q=/^[^{]+\{\s*\[native \w/,J=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,K=/[+~]/,Z=new RegExp("\\\\([\\da-f]{1,6}"+M+"?|("+M+")|.)","ig"),ee=function(e,t,n){var r="0x"+t-65536;return r!==r||n?t:r<0?String.fromCharCode(r+65536):String.fromCharCode(r>>10|55296,1023&r|56320)},te=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ne=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},re=function(){p()},ie=me(function(e){return!0===e.disabled&&("form"in e||"label"in e)},{dir:"parentNode",next:"legend"});try{L.apply(A=H.call(w.childNodes),w.childNodes),A[w.childNodes.length].nodeType}catch(e){L={apply:A.length?function(e,t){q.apply(e,H.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function oe(e,t,r,i){var o,s,l,c,f,h,v,m=t&&t.ownerDocument,T=t?t.nodeType:9;if(r=r||[],"string"!=typeof e||!e||1!==T&&9!==T&&11!==T)return r;if(!i&&((t?t.ownerDocument||t:w)!==d&&p(t),t=t||d,g)){if(11!==T&&(f=J.exec(e)))if(o=f[1]){if(9===T){if(!(l=t.getElementById(o)))return r;if(l.id===o)return r.push(l),r}else if(m&&(l=m.getElementById(o))&&x(t,l)&&l.id===o)return r.push(l),r}else{if(f[2])return L.apply(r,t.getElementsByTagName(e)),r;if((o=f[3])&&n.getElementsByClassName&&t.getElementsByClassName)return L.apply(r,t.getElementsByClassName(o)),r}if(n.qsa&&!S[e+" "]&&(!y||!y.test(e))){if(1!==T)m=t,v=e;else if("object"!==t.nodeName.toLowerCase()){(c=t.getAttribute("id"))?c=c.replace(te,ne):t.setAttribute("id",c=b),s=(h=a(e)).length;while(s--)h[s]="#"+c+" "+ve(h[s]);v=h.join(","),m=K.test(e)&&ge(t.parentNode)||t}if(v)try{return L.apply(r,m.querySelectorAll(v)),r}catch(e){}finally{c===b&&t.removeAttribute("id")}}}return u(e.replace(B,"$1"),t,r,i)}function ae(){var e=[];function t(n,i){return e.push(n+" ")>r.cacheLength&&delete t[e.shift()],t[n+" "]=i}return t}function se(e){return e[b]=!0,e}function ue(e){var t=d.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function le(e,t){var n=e.split("|"),i=n.length;while(i--)r.attrHandle[n[i]]=t}function ce(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function fe(e){return function(t){return"input"===t.nodeName.toLowerCase()&&t.type===e}}function pe(e){return function(t){var n=t.nodeName.toLowerCase();return("input"===n||"button"===n)&&t.type===e}}function de(e){return function(t){return"form"in t?t.parentNode&&!1===t.disabled?"label"in t?"label"in t.parentNode?t.parentNode.disabled===e:t.disabled===e:t.isDisabled===e||t.isDisabled!==!e&&ie(t)===e:t.disabled===e:"label"in t&&t.disabled===e}}function he(e){return se(function(t){return t=+t,se(function(n,r){var i,o=e([],n.length,t),a=o.length;while(a--)n[i=o[a]]&&(n[i]=!(r[i]=n[i]))})})}function ge(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}n=oe.support={},o=oe.isXML=function(e){var t=e&&(e.ownerDocument||e).documentElement;return!!t&&"HTML"!==t.nodeName},p=oe.setDocument=function(e){var t,i,a=e?e.ownerDocument||e:w;return a!==d&&9===a.nodeType&&a.documentElement?(d=a,h=d.documentElement,g=!o(d),w!==d&&(i=d.defaultView)&&i.top!==i&&(i.addEventListener?i.addEventListener("unload",re,!1):i.attachEvent&&i.attachEvent("onunload",re)),n.attributes=ue(function(e){return e.className="i",!e.getAttribute("className")}),n.getElementsByTagName=ue(function(e){return e.appendChild(d.createComment("")),!e.getElementsByTagName("*").length}),n.getElementsByClassName=Q.test(d.getElementsByClassName),n.getById=ue(function(e){return h.appendChild(e).id=b,!d.getElementsByName||!d.getElementsByName(b).length}),n.getById?(r.filter.ID=function(e){var t=e.replace(Z,ee);return function(e){return e.getAttribute("id")===t}},r.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&g){var n=t.getElementById(e);return n?[n]:[]}}):(r.filter.ID=function(e){var t=e.replace(Z,ee);return function(e){var n="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return n&&n.value===t}},r.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&g){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),r.find.TAG=n.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):n.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},r.find.CLASS=n.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&g)return t.getElementsByClassName(e)},v=[],y=[],(n.qsa=Q.test(d.querySelectorAll))&&(ue(function(e){h.appendChild(e).innerHTML=" ",e.querySelectorAll("[msallowcapture^='']").length&&y.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||y.push("\\["+M+"*(?:value|"+P+")"),e.querySelectorAll("[id~="+b+"-]").length||y.push("~="),e.querySelectorAll(":checked").length||y.push(":checked"),e.querySelectorAll("a#"+b+"+*").length||y.push(".#.+[+~]")}),ue(function(e){e.innerHTML=" ";var t=d.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&y.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&y.push(":enabled",":disabled"),h.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&y.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),y.push(",.*:")})),(n.matchesSelector=Q.test(m=h.matches||h.webkitMatchesSelector||h.mozMatchesSelector||h.oMatchesSelector||h.msMatchesSelector))&&ue(function(e){n.disconnectedMatch=m.call(e,"*"),m.call(e,"[s!='']:x"),v.push("!=",W)}),y=y.length&&new RegExp(y.join("|")),v=v.length&&new RegExp(v.join("|")),t=Q.test(h.compareDocumentPosition),x=t||Q.test(h.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},D=t?function(e,t){if(e===t)return f=!0,0;var r=!e.compareDocumentPosition-!t.compareDocumentPosition;return r||(1&(r=(e.ownerDocument||e)===(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!n.sortDetached&&t.compareDocumentPosition(e)===r?e===d||e.ownerDocument===w&&x(w,e)?-1:t===d||t.ownerDocument===w&&x(w,t)?1:c?O(c,e)-O(c,t):0:4&r?-1:1)}:function(e,t){if(e===t)return f=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e===d?-1:t===d?1:i?-1:o?1:c?O(c,e)-O(c,t):0;if(i===o)return ce(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?ce(a[r],s[r]):a[r]===w?-1:s[r]===w?1:0},d):d},oe.matches=function(e,t){return oe(e,null,null,t)},oe.matchesSelector=function(e,t){if((e.ownerDocument||e)!==d&&p(e),t=t.replace(z,"='$1']"),n.matchesSelector&&g&&!S[t+" "]&&(!v||!v.test(t))&&(!y||!y.test(t)))try{var r=m.call(e,t);if(r||n.disconnectedMatch||e.document&&11!==e.document.nodeType)return r}catch(e){}return oe(t,d,null,[e]).length>0},oe.contains=function(e,t){return(e.ownerDocument||e)!==d&&p(e),x(e,t)},oe.attr=function(e,t){(e.ownerDocument||e)!==d&&p(e);var i=r.attrHandle[t.toLowerCase()],o=i&&N.call(r.attrHandle,t.toLowerCase())?i(e,t,!g):void 0;return void 0!==o?o:n.attributes||!g?e.getAttribute(t):(o=e.getAttributeNode(t))&&o.specified?o.value:null},oe.escape=function(e){return(e+"").replace(te,ne)},oe.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},oe.uniqueSort=function(e){var t,r=[],i=0,o=0;if(f=!n.detectDuplicates,c=!n.sortStable&&e.slice(0),e.sort(D),f){while(t=e[o++])t===e[o]&&(i=r.push(o));while(i--)e.splice(r[i],1)}return c=null,e},i=oe.getText=function(e){var t,n="",r=0,o=e.nodeType;if(o){if(1===o||9===o||11===o){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=i(e)}else if(3===o||4===o)return e.nodeValue}else while(t=e[r++])n+=i(t);return n},(r=oe.selectors={cacheLength:50,createPseudo:se,match:V,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(Z,ee),e[3]=(e[3]||e[4]||e[5]||"").replace(Z,ee),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||oe.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&oe.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return V.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=a(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(Z,ee).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=E[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&E(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(e,t,n){return function(r){var i=oe.attr(r,e);return null==i?"!="===t:!t||(i+="","="===t?i===n:"!="===t?i!==n:"^="===t?n&&0===i.indexOf(n):"*="===t?n&&i.indexOf(n)>-1:"$="===t?n&&i.slice(-n.length)===n:"~="===t?(" "+i.replace($," ")+" ").indexOf(n)>-1:"|="===t&&(i===n||i.slice(0,n.length+1)===n+"-"))}},CHILD:function(e,t,n,r,i){var o="nth"!==e.slice(0,3),a="last"!==e.slice(-4),s="of-type"===t;return 1===r&&0===i?function(e){return!!e.parentNode}:function(t,n,u){var l,c,f,p,d,h,g=o!==a?"nextSibling":"previousSibling",y=t.parentNode,v=s&&t.nodeName.toLowerCase(),m=!u&&!s,x=!1;if(y){if(o){while(g){p=t;while(p=p[g])if(s?p.nodeName.toLowerCase()===v:1===p.nodeType)return!1;h=g="only"===e&&!h&&"nextSibling"}return!0}if(h=[a?y.firstChild:y.lastChild],a&&m){x=(d=(l=(c=(f=(p=y)[b]||(p[b]={}))[p.uniqueID]||(f[p.uniqueID]={}))[e]||[])[0]===T&&l[1])&&l[2],p=d&&y.childNodes[d];while(p=++d&&p&&p[g]||(x=d=0)||h.pop())if(1===p.nodeType&&++x&&p===t){c[e]=[T,d,x];break}}else if(m&&(x=d=(l=(c=(f=(p=t)[b]||(p[b]={}))[p.uniqueID]||(f[p.uniqueID]={}))[e]||[])[0]===T&&l[1]),!1===x)while(p=++d&&p&&p[g]||(x=d=0)||h.pop())if((s?p.nodeName.toLowerCase()===v:1===p.nodeType)&&++x&&(m&&((c=(f=p[b]||(p[b]={}))[p.uniqueID]||(f[p.uniqueID]={}))[e]=[T,x]),p===t))break;return(x-=i)===r||x%r==0&&x/r>=0}}},PSEUDO:function(e,t){var n,i=r.pseudos[e]||r.setFilters[e.toLowerCase()]||oe.error("unsupported pseudo: "+e);return i[b]?i(t):i.length>1?(n=[e,e,"",t],r.setFilters.hasOwnProperty(e.toLowerCase())?se(function(e,n){var r,o=i(e,t),a=o.length;while(a--)e[r=O(e,o[a])]=!(n[r]=o[a])}):function(e){return i(e,0,n)}):i}},pseudos:{not:se(function(e){var t=[],n=[],r=s(e.replace(B,"$1"));return r[b]?se(function(e,t,n,i){var o,a=r(e,null,i,[]),s=e.length;while(s--)(o=a[s])&&(e[s]=!(t[s]=o))}):function(e,i,o){return t[0]=e,r(t,null,o,n),t[0]=null,!n.pop()}}),has:se(function(e){return function(t){return oe(e,t).length>0}}),contains:se(function(e){return e=e.replace(Z,ee),function(t){return(t.textContent||t.innerText||i(t)).indexOf(e)>-1}}),lang:se(function(e){return U.test(e||"")||oe.error("unsupported lang: "+e),e=e.replace(Z,ee).toLowerCase(),function(t){var n;do{if(n=g?t.lang:t.getAttribute("xml:lang")||t.getAttribute("lang"))return(n=n.toLowerCase())===e||0===n.indexOf(e+"-")}while((t=t.parentNode)&&1===t.nodeType);return!1}}),target:function(t){var n=e.location&&e.location.hash;return n&&n.slice(1)===t.id},root:function(e){return e===h},focus:function(e){return e===d.activeElement&&(!d.hasFocus||d.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:de(!1),disabled:de(!0),checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!r.pseudos.empty(e)},header:function(e){return Y.test(e.nodeName)},input:function(e){return G.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:he(function(){return[0]}),last:he(function(e,t){return[t-1]}),eq:he(function(e,t,n){return[n<0?n+t:n]}),even:he(function(e,t){for(var n=0;n=0;)e.push(r);return e}),gt:he(function(e,t,n){for(var r=n<0?n+t:n;++r1?function(t,n,r){var i=e.length;while(i--)if(!e[i](t,n,r))return!1;return!0}:e[0]}function be(e,t,n){for(var r=0,i=t.length;r-1&&(o[l]=!(a[l]=f))}}else v=we(v===a?v.splice(h,v.length):v),i?i(null,a,v,u):L.apply(a,v)})}function Ce(e){for(var t,n,i,o=e.length,a=r.relative[e[0].type],s=a||r.relative[" "],u=a?1:0,c=me(function(e){return e===t},s,!0),f=me(function(e){return O(t,e)>-1},s,!0),p=[function(e,n,r){var i=!a&&(r||n!==l)||((t=n).nodeType?c(e,n,r):f(e,n,r));return t=null,i}];u1&&xe(p),u>1&&ve(e.slice(0,u-1).concat({value:" "===e[u-2].type?"*":""})).replace(B,"$1"),n,u0,i=e.length>0,o=function(o,a,s,u,c){var f,h,y,v=0,m="0",x=o&&[],b=[],w=l,C=o||i&&r.find.TAG("*",c),E=T+=null==w?1:Math.random()||.1,k=C.length;for(c&&(l=a===d||a||c);m!==k&&null!=(f=C[m]);m++){if(i&&f){h=0,a||f.ownerDocument===d||(p(f),s=!g);while(y=e[h++])if(y(f,a||d,s)){u.push(f);break}c&&(T=E)}n&&((f=!y&&f)&&v--,o&&x.push(f))}if(v+=m,n&&m!==v){h=0;while(y=t[h++])y(x,b,a,s);if(o){if(v>0)while(m--)x[m]||b[m]||(b[m]=j.call(u));b=we(b)}L.apply(u,b),c&&!o&&b.length>0&&v+t.length>1&&oe.uniqueSort(u)}return c&&(T=E,l=w),x};return n?se(o):o}return s=oe.compile=function(e,t){var n,r=[],i=[],o=S[e+" "];if(!o){t||(t=a(e)),n=t.length;while(n--)(o=Ce(t[n]))[b]?r.push(o):i.push(o);(o=S(e,Ee(i,r))).selector=e}return o},u=oe.select=function(e,t,n,i){var o,u,l,c,f,p="function"==typeof e&&e,d=!i&&a(e=p.selector||e);if(n=n||[],1===d.length){if((u=d[0]=d[0].slice(0)).length>2&&"ID"===(l=u[0]).type&&9===t.nodeType&&g&&r.relative[u[1].type]){if(!(t=(r.find.ID(l.matches[0].replace(Z,ee),t)||[])[0]))return n;p&&(t=t.parentNode),e=e.slice(u.shift().value.length)}o=V.needsContext.test(e)?0:u.length;while(o--){if(l=u[o],r.relative[c=l.type])break;if((f=r.find[c])&&(i=f(l.matches[0].replace(Z,ee),K.test(u[0].type)&&ge(t.parentNode)||t))){if(u.splice(o,1),!(e=i.length&&ve(u)))return L.apply(n,i),n;break}}}return(p||s(e,d))(i,t,!g,n,!t||K.test(e)&&ge(t.parentNode)||t),n},n.sortStable=b.split("").sort(D).join("")===b,n.detectDuplicates=!!f,p(),n.sortDetached=ue(function(e){return 1&e.compareDocumentPosition(d.createElement("fieldset"))}),ue(function(e){return e.innerHTML=" ","#"===e.firstChild.getAttribute("href")})||le("type|href|height|width",function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),n.attributes&&ue(function(e){return e.innerHTML=" ",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||le("value",function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue}),ue(function(e){return null==e.getAttribute("disabled")})||le(P,function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null}),oe}(e);w.find=E,w.expr=E.selectors,w.expr[":"]=w.expr.pseudos,w.uniqueSort=w.unique=E.uniqueSort,w.text=E.getText,w.isXMLDoc=E.isXML,w.contains=E.contains,w.escapeSelector=E.escape;var k=function(e,t,n){var r=[],i=void 0!==n;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&w(e).is(n))break;r.push(e)}return r},S=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},D=w.expr.match.needsContext;function N(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var A=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function j(e,t,n){return g(t)?w.grep(e,function(e,r){return!!t.call(e,r,e)!==n}):t.nodeType?w.grep(e,function(e){return e===t!==n}):"string"!=typeof t?w.grep(e,function(e){return u.call(t,e)>-1!==n}):w.filter(t,e,n)}w.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?w.find.matchesSelector(r,e)?[r]:[]:w.find.matches(e,w.grep(t,function(e){return 1===e.nodeType}))},w.fn.extend({find:function(e){var t,n,r=this.length,i=this;if("string"!=typeof e)return this.pushStack(w(e).filter(function(){for(t=0;t1?w.uniqueSort(n):n},filter:function(e){return this.pushStack(j(this,e||[],!1))},not:function(e){return this.pushStack(j(this,e||[],!0))},is:function(e){return!!j(this,"string"==typeof e&&D.test(e)?w(e):e||[],!1).length}});var q,L=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;(w.fn.init=function(e,t,n){var i,o;if(!e)return this;if(n=n||q,"string"==typeof e){if(!(i="<"===e[0]&&">"===e[e.length-1]&&e.length>=3?[null,e,null]:L.exec(e))||!i[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(i[1]){if(t=t instanceof w?t[0]:t,w.merge(this,w.parseHTML(i[1],t&&t.nodeType?t.ownerDocument||t:r,!0)),A.test(i[1])&&w.isPlainObject(t))for(i in t)g(this[i])?this[i](t[i]):this.attr(i,t[i]);return this}return(o=r.getElementById(i[2]))&&(this[0]=o,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):g(e)?void 0!==n.ready?n.ready(e):e(w):w.makeArray(e,this)}).prototype=w.fn,q=w(r);var H=/^(?:parents|prev(?:Until|All))/,O={children:!0,contents:!0,next:!0,prev:!0};w.fn.extend({has:function(e){var t=w(e,this),n=t.length;return this.filter(function(){for(var e=0;e-1:1===n.nodeType&&w.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(o.length>1?w.uniqueSort(o):o)},index:function(e){return e?"string"==typeof e?u.call(w(e),this[0]):u.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(w.uniqueSort(w.merge(this.get(),w(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}});function P(e,t){while((e=e[t])&&1!==e.nodeType);return e}w.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return k(e,"parentNode")},parentsUntil:function(e,t,n){return k(e,"parentNode",n)},next:function(e){return P(e,"nextSibling")},prev:function(e){return P(e,"previousSibling")},nextAll:function(e){return k(e,"nextSibling")},prevAll:function(e){return k(e,"previousSibling")},nextUntil:function(e,t,n){return k(e,"nextSibling",n)},prevUntil:function(e,t,n){return k(e,"previousSibling",n)},siblings:function(e){return S((e.parentNode||{}).firstChild,e)},children:function(e){return S(e.firstChild)},contents:function(e){return N(e,"iframe")?e.contentDocument:(N(e,"template")&&(e=e.content||e),w.merge([],e.childNodes))}},function(e,t){w.fn[e]=function(n,r){var i=w.map(this,t,n);return"Until"!==e.slice(-5)&&(r=n),r&&"string"==typeof r&&(i=w.filter(r,i)),this.length>1&&(O[e]||w.uniqueSort(i),H.test(e)&&i.reverse()),this.pushStack(i)}});var M=/[^\x20\t\r\n\f]+/g;function R(e){var t={};return w.each(e.match(M)||[],function(e,n){t[n]=!0}),t}w.Callbacks=function(e){e="string"==typeof e?R(e):w.extend({},e);var t,n,r,i,o=[],a=[],s=-1,u=function(){for(i=i||e.once,r=t=!0;a.length;s=-1){n=a.shift();while(++s-1)o.splice(n,1),n<=s&&s--}),this},has:function(e){return e?w.inArray(e,o)>-1:o.length>0},empty:function(){return o&&(o=[]),this},disable:function(){return i=a=[],o=n="",this},disabled:function(){return!o},lock:function(){return i=a=[],n||t||(o=n=""),this},locked:function(){return!!i},fireWith:function(e,n){return i||(n=[e,(n=n||[]).slice?n.slice():n],a.push(n),t||u()),this},fire:function(){return l.fireWith(this,arguments),this},fired:function(){return!!r}};return l};function I(e){return e}function W(e){throw e}function $(e,t,n,r){var i;try{e&&g(i=e.promise)?i.call(e).done(t).fail(n):e&&g(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}w.extend({Deferred:function(t){var n=[["notify","progress",w.Callbacks("memory"),w.Callbacks("memory"),2],["resolve","done",w.Callbacks("once memory"),w.Callbacks("once memory"),0,"resolved"],["reject","fail",w.Callbacks("once memory"),w.Callbacks("once memory"),1,"rejected"]],r="pending",i={state:function(){return r},always:function(){return o.done(arguments).fail(arguments),this},"catch":function(e){return i.then(null,e)},pipe:function(){var e=arguments;return w.Deferred(function(t){w.each(n,function(n,r){var i=g(e[r[4]])&&e[r[4]];o[r[1]](function(){var e=i&&i.apply(this,arguments);e&&g(e.promise)?e.promise().progress(t.notify).done(t.resolve).fail(t.reject):t[r[0]+"With"](this,i?[e]:arguments)})}),e=null}).promise()},then:function(t,r,i){var o=0;function a(t,n,r,i){return function(){var s=this,u=arguments,l=function(){var e,l;if(!(t=o&&(r!==W&&(s=void 0,u=[e]),n.rejectWith(s,u))}};t?c():(w.Deferred.getStackHook&&(c.stackTrace=w.Deferred.getStackHook()),e.setTimeout(c))}}return w.Deferred(function(e){n[0][3].add(a(0,e,g(i)?i:I,e.notifyWith)),n[1][3].add(a(0,e,g(t)?t:I)),n[2][3].add(a(0,e,g(r)?r:W))}).promise()},promise:function(e){return null!=e?w.extend(e,i):i}},o={};return w.each(n,function(e,t){var a=t[2],s=t[5];i[t[1]]=a.add,s&&a.add(function(){r=s},n[3-e][2].disable,n[3-e][3].disable,n[0][2].lock,n[0][3].lock),a.add(t[3].fire),o[t[0]]=function(){return o[t[0]+"With"](this===o?void 0:this,arguments),this},o[t[0]+"With"]=a.fireWith}),i.promise(o),t&&t.call(o,o),o},when:function(e){var t=arguments.length,n=t,r=Array(n),i=o.call(arguments),a=w.Deferred(),s=function(e){return function(n){r[e]=this,i[e]=arguments.length>1?o.call(arguments):n,--t||a.resolveWith(r,i)}};if(t<=1&&($(e,a.done(s(n)).resolve,a.reject,!t),"pending"===a.state()||g(i[n]&&i[n].then)))return a.then();while(n--)$(i[n],s(n),a.reject);return a.promise()}});var B=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;w.Deferred.exceptionHook=function(t,n){e.console&&e.console.warn&&t&&B.test(t.name)&&e.console.warn("jQuery.Deferred exception: "+t.message,t.stack,n)},w.readyException=function(t){e.setTimeout(function(){throw t})};var F=w.Deferred();w.fn.ready=function(e){return F.then(e)["catch"](function(e){w.readyException(e)}),this},w.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--w.readyWait:w.isReady)||(w.isReady=!0,!0!==e&&--w.readyWait>0||F.resolveWith(r,[w]))}}),w.ready.then=F.then;function _(){r.removeEventListener("DOMContentLoaded",_),e.removeEventListener("load",_),w.ready()}"complete"===r.readyState||"loading"!==r.readyState&&!r.documentElement.doScroll?e.setTimeout(w.ready):(r.addEventListener("DOMContentLoaded",_),e.addEventListener("load",_));var z=function(e,t,n,r,i,o,a){var s=0,u=e.length,l=null==n;if("object"===x(n)){i=!0;for(s in n)z(e,t,s,n[s],!0,o,a)}else if(void 0!==r&&(i=!0,g(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(w(e),n)})),t))for(;s1,null,!0)},removeData:function(e){return this.each(function(){K.remove(this,e)})}}),w.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=J.get(e,t),n&&(!r||Array.isArray(n)?r=J.access(e,t,w.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=w.queue(e,t),r=n.length,i=n.shift(),o=w._queueHooks(e,t),a=function(){w.dequeue(e,t)};"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,a,o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return J.get(e,n)||J.access(e,n,{empty:w.Callbacks("once memory").add(function(){J.remove(e,[t+"queue",n])})})}}),w.fn.extend({queue:function(e,t){var n=2;return"string"!=typeof e&&(t=e,e="fx",n--),arguments.length\x20\t\r\n\f]+)/i,he=/^$|^module$|\/(?:java|ecma)script/i,ge={option:[1,""," "],thead:[1,""],col:[2,""],tr:[2,""],td:[3,""],_default:[0,"",""]};ge.optgroup=ge.option,ge.tbody=ge.tfoot=ge.colgroup=ge.caption=ge.thead,ge.th=ge.td;function ye(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&N(e,t)?w.merge([e],n):n}function ve(e,t){for(var n=0,r=e.length;n-1)i&&i.push(o);else if(l=w.contains(o.ownerDocument,o),a=ye(f.appendChild(o),"script"),l&&ve(a),n){c=0;while(o=a[c++])he.test(o.type||"")&&n.push(o)}return f}!function(){var e=r.createDocumentFragment().appendChild(r.createElement("div")),t=r.createElement("input");t.setAttribute("type","radio"),t.setAttribute("checked","checked"),t.setAttribute("name","t"),e.appendChild(t),h.checkClone=e.cloneNode(!0).cloneNode(!0).lastChild.checked,e.innerHTML="",h.noCloneChecked=!!e.cloneNode(!0).lastChild.defaultValue}();var be=r.documentElement,we=/^key/,Te=/^(?:mouse|pointer|contextmenu|drag|drop)|click/,Ce=/^([^.]*)(?:\.(.+)|)/;function Ee(){return!0}function ke(){return!1}function Se(){try{return r.activeElement}catch(e){}}function De(e,t,n,r,i,o){var a,s;if("object"==typeof t){"string"!=typeof n&&(r=r||n,n=void 0);for(s in t)De(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=ke;else if(!i)return e;return 1===o&&(a=i,(i=function(e){return w().off(e),a.apply(this,arguments)}).guid=a.guid||(a.guid=w.guid++)),e.each(function(){w.event.add(this,t,i,r,n)})}w.event={global:{},add:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,y=J.get(e);if(y){n.handler&&(n=(o=n).handler,i=o.selector),i&&w.find.matchesSelector(be,i),n.guid||(n.guid=w.guid++),(u=y.events)||(u=y.events={}),(a=y.handle)||(a=y.handle=function(t){return"undefined"!=typeof w&&w.event.triggered!==t.type?w.event.dispatch.apply(e,arguments):void 0}),l=(t=(t||"").match(M)||[""]).length;while(l--)d=g=(s=Ce.exec(t[l])||[])[1],h=(s[2]||"").split(".").sort(),d&&(f=w.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=w.event.special[d]||{},c=w.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&w.expr.match.needsContext.test(i),namespace:h.join(".")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(e,r,h,a)||e.addEventListener&&e.addEventListener(d,a)),f.add&&(f.add.call(e,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),w.event.global[d]=!0)}},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,y=J.hasData(e)&&J.get(e);if(y&&(u=y.events)){l=(t=(t||"").match(M)||[""]).length;while(l--)if(s=Ce.exec(t[l])||[],d=g=s[1],h=(s[2]||"").split(".").sort(),d){f=w.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),a=o=p.length;while(o--)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,y.handle)||w.removeEvent(e,d,y.handle),delete u[d])}else for(d in u)w.event.remove(e,d+t[l],n,r,!0);w.isEmptyObject(u)&&J.remove(e,"handle events")}},dispatch:function(e){var t=w.event.fix(e),n,r,i,o,a,s,u=new Array(arguments.length),l=(J.get(this,"events")||{})[t.type]||[],c=w.event.special[t.type]||{};for(u[0]=t,n=1;n=1))for(;l!==this;l=l.parentNode||this)if(1===l.nodeType&&("click"!==e.type||!0!==l.disabled)){for(o=[],a={},n=0;n-1:w.find(i,this,null,[l]).length),a[i]&&o.push(r);o.length&&s.push({elem:l,handlers:o})}return l=this,u\x20\t\r\n\f]*)[^>]*)\/>/gi,Ae=/
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Refresh panel
+
+
+
+
+
+