UNPKG

@aurigma/design-atoms

Version:

Design Atoms is a part of Customer's Canvas SDK which allows for manipulating individual design elements through your code.

241 lines 13.1 kB
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; var __generator = (this && this.__generator) || function (thisArg, body) { var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; function verb(n) { return function (v) { return step([n, v]); }; } function step(op) { if (f) throw new TypeError("Generator is already executing."); while (_) try { if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; if (y = 0, t) op = [op[0] & 2, t.value]; switch (op[0]) { case 0: case 1: t = op; break; case 4: _.label++; return { value: op[1], done: false }; case 5: _.label++; y = op[1]; op = [0]; continue; case 7: op = _.ops.pop(); _.trys.pop(); continue; default: if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } if (t[2]) _.ops.pop(); _.trys.pop(); continue; } op = body.call(thisArg, _); } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; } }; var __values = (this && this.__values) || function(o) { var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0; if (m) return m.call(o); if (o && typeof o.length === "number") return { next: function () { if (o && i >= o.length) o = void 0; return { value: o && o[i++], done: !o }; } }; throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined."); }; import { EventObject, EquatableKeyDictionary } from "@aurigma/design-atoms-model"; import { ColorPreviewLoadAwaiter } from "./ColorPreviewLoadAwaiter"; var ColorPreviewService = /** @class */ (function () { function ColorPreviewService(apiClient, renderingConfigProvider) { this._apiClient = apiClient; this._previews = new EquatableKeyDictionary(); this._previewLoadedEvents = new EquatableKeyDictionary(); this._renderingConfigProvider = renderingConfigProvider; } Object.defineProperty(ColorPreviewService.prototype, "_colorSettings", { get: function () { return { rgbColorProfileName: this._renderingConfigProvider.getRgbColorProfileName(), cmykColorProfileName: this._renderingConfigProvider.getCmykColorProfileName(), grayscaleColorProfileName: this._renderingConfigProvider.getGrayscaleColorProfileName(), hiResDestinationColorProfileName: this._renderingConfigProvider.getHiResDestinationColorProfileName() }; }, enumerable: true, configurable: true }); ColorPreviewService.prototype.getPreviews = function (colors) { if (colors == null) return null; var response = []; for (var i = 0; i < colors.length; i++) { if (colors[i] == null) response[i] = null; else response[i] = this._getPreview(colors[i]); } return response; }; ColorPreviewService.prototype.getPreviewsAsync = function (colors) { return __awaiter(this, void 0, void 0, function () { var colorsToRequest, remap, response, previewAwaiter, previewAwaiterIndexes, i_1, color, _a, hasPreview, previewValue, _b, hasRequest, requestValue, colorsToRequest_1, colorsToRequest_1_1, requestColor, apiResult, i_2, responseIndex, preview, color, previewAwaiterIndexes_1, previewAwaiterIndexes_1_1, i, color, _c, hasPreview, previewValue; var e_1, _d, e_2, _e; return __generator(this, function (_f) { switch (_f.label) { case 0: if (colors == null) return [2 /*return*/, null]; colorsToRequest = []; remap = []; response = []; previewAwaiter = new ColorPreviewLoadAwaiter(); previewAwaiterIndexes = []; for (i_1 = 0; i_1 < colors.length; i_1++) { color = colors[i_1]; if (color == null) { response[i_1] = null; continue; } _a = this._previews.tryGetValueOf(color), hasPreview = _a.hasValue, previewValue = _a.value; if (hasPreview) { response[i_1] = previewValue.clone(); continue; } _b = this._previewLoadedEvents.tryGetValueOf(color), hasRequest = _b.hasValue, requestValue = _b.value; if (hasRequest) { previewAwaiterIndexes.push(i_1); previewAwaiter.appendColor(color); requestValue.add(previewAwaiter.listener); continue; } remap.push(i_1); colorsToRequest.push(color); } if (!(colorsToRequest.length > 0)) return [3 /*break*/, 2]; try { for (colorsToRequest_1 = __values(colorsToRequest), colorsToRequest_1_1 = colorsToRequest_1.next(); !colorsToRequest_1_1.done; colorsToRequest_1_1 = colorsToRequest_1.next()) { requestColor = colorsToRequest_1_1.value; this._previewLoadedEvents.set(requestColor, new EventObject()); } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (colorsToRequest_1_1 && !colorsToRequest_1_1.done && (_d = colorsToRequest_1.return)) _d.call(colorsToRequest_1); } finally { if (e_1) throw e_1.error; } } return [4 /*yield*/, this._apiClient.getColorPreviews(colorsToRequest, this._colorSettings)]; case 1: apiResult = _f.sent(); if (apiResult == null || apiResult.length != colorsToRequest.length) throw new Error("Unexpected getColorPreviews respose"); for (i_2 = 0; i_2 < apiResult.length; i_2++) { responseIndex = remap[i_2]; preview = apiResult[i_2]; color = colorsToRequest[i_2]; this._previews.set(color, preview); this._notifyPreviewLoaded(color); response[responseIndex] = apiResult[i_2]; } _f.label = 2; case 2: if (!(previewAwaiterIndexes.length > 0)) return [3 /*break*/, 4]; return [4 /*yield*/, previewAwaiter.waitForLoad()]; case 3: _f.sent(); try { for (previewAwaiterIndexes_1 = __values(previewAwaiterIndexes), previewAwaiterIndexes_1_1 = previewAwaiterIndexes_1.next(); !previewAwaiterIndexes_1_1.done; previewAwaiterIndexes_1_1 = previewAwaiterIndexes_1.next()) { i = previewAwaiterIndexes_1_1.value; color = colors[i]; _c = this._previews.tryGetValueOf(color), hasPreview = _c.hasValue, previewValue = _c.value; if (hasPreview) { response[i] = previewValue.clone(); } else { console.error("Expected color to be present in previews array, but it was not.", color); } } } catch (e_2_1) { e_2 = { error: e_2_1 }; } finally { try { if (previewAwaiterIndexes_1_1 && !previewAwaiterIndexes_1_1.done && (_e = previewAwaiterIndexes_1.return)) _e.call(previewAwaiterIndexes_1); } finally { if (e_2) throw e_2.error; } } _f.label = 4; case 4: return [2 /*return*/, response]; } }); }); }; ColorPreviewService.prototype.getPreview = function (color) { if (color == null) { return null; } return this._getPreview(color); }; ColorPreviewService.prototype.getPreviewAsync = function (color) { return __awaiter(this, void 0, void 0, function () { var result; return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this.getPreviewsAsync([color])]; case 1: result = _a.sent(); if (result == null) return [2 /*return*/, null]; return [2 /*return*/, result[0]]; } }); }); }; ColorPreviewService.prototype.subscribeToPreviewLoaded = function (color, listener) { var _a = this._previewLoadedEvents.tryGetValueOf(color), hasValue = _a.hasValue, value = _a.value; if (hasValue) { value.add(listener); } }; ColorPreviewService.prototype.unsubscribeFromPreviewLoaded = function (color, listener) { var _a = this._previewLoadedEvents.tryGetValueOf(color), hasValue = _a.hasValue, value = _a.value; if (hasValue) { value.remove(listener); } }; ColorPreviewService.prototype._getPreview = function (color) { var _a = this._previews.tryGetValueOf(color), hasValue = _a.hasValue, value = _a.value; if (hasValue) { return value.clone(); } if (this._previewLoadedEvents.hasEqual(color)) { return null; } this._previewLoadedEvents.set(color, new EventObject()); this._requestPreviewFromServer(color); return null; }; ColorPreviewService.prototype._notifyPreviewLoaded = function (color) { var _a = this._previewLoadedEvents.tryGetKeyEqualTo(color), hasKey = _a.hasKey, key = _a.key; if (hasKey) { var event_1 = this._previewLoadedEvents.get(key); event_1.notify({ color: color }); if (event_1.listenersCount() === 0) { this._previewLoadedEvents.delete(key); } } }; ColorPreviewService.prototype._requestPreviewFromServer = function (color) { var _this = this; this._apiClient.getColorPreview(color, this._colorSettings) .then(function (preview) { _this._previews.set(color, preview); _this._notifyPreviewLoaded(color); }); }; return ColorPreviewService; }()); export { ColorPreviewService }; //# sourceMappingURL=ColorPreviewService.js.map