@qoh/core-react 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md ADDED
@@ -0,0 +1,5 @@
1
+ # **0.0.1** feature parity _(2023-03-20)_
2
+
3
+ #### changes:
4
+
5
+ - use the same features and names as the angular version
package/LICENSE.md ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2023 gravity&storm GmbH
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,2 @@
1
+ #Queen of hearts client core package
2
+ This package is providing the core client packages in react.
@@ -0,0 +1,9 @@
1
+ export declare class ApiError extends Error {
2
+ status: number;
3
+ body: {
4
+ id: string;
5
+ summary: string;
6
+ details: string;
7
+ };
8
+ constructor(status: number, body: any);
9
+ }
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.ApiError = void 0;
8
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
9
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
10
+ var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
11
+ var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
12
+ var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
13
+ var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
14
+ var _wrapNativeSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/wrapNativeSuper"));
15
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
16
+ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
17
+ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
18
+ var ApiError = exports.ApiError = /*#__PURE__*/function (_Error) {
19
+ (0, _inherits2["default"])(ApiError, _Error);
20
+ var _super = _createSuper(ApiError);
21
+ function ApiError(status, body) {
22
+ var _this;
23
+ (0, _classCallCheck2["default"])(this, ApiError);
24
+ _this = _super.call(this, body.summary);
25
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "status", void 0);
26
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "body", void 0);
27
+ _this.name = "ApiError";
28
+ _this.status = status;
29
+ _this.body = body;
30
+ return _this;
31
+ }
32
+ return (0, _createClass2["default"])(ApiError);
33
+ }( /*#__PURE__*/(0, _wrapNativeSuper2["default"])(Error));
@@ -0,0 +1,66 @@
1
+ export interface IFCDictionary {
2
+ [index: string]: ReactFCWithFieldNames;
3
+ }
4
+ export interface ReactFCWithFieldNames {
5
+ component: React.FC<any>;
6
+ fieldNames?: string[];
7
+ }
8
+ export declare let componentRegistry: IFCDictionary;
9
+ export declare function unregisterComponent(name: string): void;
10
+ export declare function registerComponent(functionalComponent: React.FC<any>, typeName: string, fieldNames?: string[]): void;
11
+ export declare function getAllregisteredComponents(): IFCDictionary;
12
+ import React from 'react';
13
+ import Backend from './backend/Backend';
14
+ export declare enum Filter {
15
+ eq = "eq",
16
+ in = "in",
17
+ neq = "neq",
18
+ notIn = "notIn"
19
+ }
20
+ export interface QohResponse {
21
+ pages: any | null;
22
+ message: string;
23
+ }
24
+ export declare class QueenofheartsService {
25
+ private static instance;
26
+ data: any;
27
+ debug: boolean;
28
+ backend: Backend;
29
+ apiToken: string;
30
+ localServer?: string;
31
+ latestUrl: string;
32
+ latestData: Object;
33
+ private constructor();
34
+ static init(backend: Backend, apiToken: string, localServer?: string): void;
35
+ static getInstance(): QueenofheartsService;
36
+ createComponent(props: any): JSX.Element | null;
37
+ private buildUrl;
38
+ queryGraphql: (graphqlQuery: string) => Promise<any>;
39
+ query: (queryName: string, options?: {
40
+ filter?: {
41
+ name: string;
42
+ operator: Filter;
43
+ value: string;
44
+ }[];
45
+ components?: string;
46
+ ignoreProperties?: string[];
47
+ variables?: {
48
+ [x: string]: unknown;
49
+ filter?: {
50
+ name: string;
51
+ operator: Filter;
52
+ value: string;
53
+ }[];
54
+ locale?: string;
55
+ };
56
+ locale?: string;
57
+ depth?: number;
58
+ }) => Promise<any>;
59
+ private getRegisteredComponentsWithFields;
60
+ getQueries: () => Promise<any>;
61
+ private injectIds;
62
+ private sendDebugEvent;
63
+ private sendQueriesEvent;
64
+ private sendComponentHTML;
65
+ private highlightComponent;
66
+ }
@@ -0,0 +1,462 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.componentRegistry = exports.QueenofheartsService = exports.Filter = void 0;
8
+ exports.getAllregisteredComponents = getAllregisteredComponents;
9
+ exports.registerComponent = registerComponent;
10
+ exports.unregisterComponent = unregisterComponent;
11
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
12
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
14
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
15
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
16
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
17
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
18
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
19
+ var _ApiError = require("./ApiError");
20
+ var _react = _interopRequireDefault(require("react"));
21
+ var _Dodo = _interopRequireDefault(require("./components/Dodo"));
22
+ var _class;
23
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
24
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
25
+ var qohUri = 'https://qoh.azurewebsites.net/api';
26
+ var componentRegistry = exports.componentRegistry = {};
27
+ function unregisterComponent(name) {
28
+ delete componentRegistry[name];
29
+ }
30
+ function registerComponent(functionalComponent, typeName, fieldNames) {
31
+ if (typeName !== undefined) {
32
+ if (componentRegistry[typeName] === undefined) {
33
+ var componentWithFieldNames = {
34
+ component: functionalComponent,
35
+ fieldNames: fieldNames
36
+ };
37
+ componentRegistry[typeName] = componentWithFieldNames;
38
+ }
39
+ }
40
+ }
41
+ function getAllregisteredComponents() {
42
+ return componentRegistry;
43
+ }
44
+
45
+ //TODO: remove????
46
+ var Filter = exports.Filter = /*#__PURE__*/function (Filter) {
47
+ Filter["eq"] = "eq";
48
+ Filter["in"] = "in";
49
+ Filter["neq"] = "neq";
50
+ Filter["notIn"] = "notIn";
51
+ return Filter;
52
+ }({});
53
+ var QueenofheartsService = exports.QueenofheartsService = /*#__PURE__*/function () {
54
+ function QueenofheartsService(backend, apiToken, localServer) {
55
+ var _this = this;
56
+ (0, _classCallCheck2["default"])(this, QueenofheartsService);
57
+ (0, _defineProperty2["default"])(this, "data", void 0);
58
+ (0, _defineProperty2["default"])(this, "debug", void 0);
59
+ (0, _defineProperty2["default"])(this, "backend", void 0);
60
+ (0, _defineProperty2["default"])(this, "apiToken", void 0);
61
+ (0, _defineProperty2["default"])(this, "localServer", void 0);
62
+ //debugger-data:
63
+ (0, _defineProperty2["default"])(this, "latestUrl", '');
64
+ (0, _defineProperty2["default"])(this, "latestData", {});
65
+ (0, _defineProperty2["default"])(this, "buildUrl", function (endpoint) {
66
+ //use Azure function
67
+ if (_this.apiToken) {
68
+ var _this$localServer;
69
+ return "".concat((_this$localServer = _this.localServer) !== null && _this$localServer !== void 0 ? _this$localServer : qohUri, "/").concat(endpoint, "?code=").concat(_this.apiToken);
70
+ }
71
+ //use localServer (API token not provided)
72
+ else if (_this.apiToken == '') {
73
+ return "".concat(_this.localServer, "/").concat(endpoint);
74
+ } else {
75
+ return null;
76
+ }
77
+ });
78
+ (0, _defineProperty2["default"])(this, "queryGraphql", /*#__PURE__*/function () {
79
+ var _ref = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(graphqlQuery) {
80
+ var queryUrl, response, body, errorResponse;
81
+ return _regenerator["default"].wrap(function _callee$(_context) {
82
+ while (1) switch (_context.prev = _context.next) {
83
+ case 0:
84
+ /*
85
+ if (!this.backend.uri) {
86
+ throw new Error(
87
+ 'Backend-Uri is missing. The Backend-Uri is either set via the constructor or the init methode.'
88
+ );
89
+ }
90
+ if (!this.backend.token) {
91
+ throw new Error(
92
+ 'Token is missing. The token is eihter set via the constructor or the init methode.'
93
+ );
94
+ }
95
+ */
96
+ queryUrl = _this.buildUrl('execGraphqlQuery');
97
+ _context.next = 3;
98
+ return fetch(queryUrl, {
99
+ method: 'POST',
100
+ headers: {
101
+ 'Content-Type': 'application/json'
102
+ },
103
+ body: JSON.stringify({
104
+ uri: _this.backend.uri,
105
+ query: graphqlQuery,
106
+ token: _this.backend.token
107
+ })
108
+ });
109
+ case 3:
110
+ response = _context.sent;
111
+ if (!response.ok) {
112
+ _context.next = 12;
113
+ break;
114
+ }
115
+ _context.next = 7;
116
+ return response.json();
117
+ case 7:
118
+ body = _context.sent;
119
+ _this.sendDebugEvent();
120
+ return _context.abrupt("return", body);
121
+ case 12:
122
+ _context.next = 14;
123
+ return response.json();
124
+ case 14:
125
+ errorResponse = _context.sent;
126
+ console.log(errorResponse);
127
+ throw new _ApiError.ApiError(response.status, errorResponse);
128
+ case 17:
129
+ case "end":
130
+ return _context.stop();
131
+ }
132
+ }, _callee);
133
+ }));
134
+ return function (_x) {
135
+ return _ref.apply(this, arguments);
136
+ };
137
+ }());
138
+ (0, _defineProperty2["default"])(this, "query", /*#__PURE__*/function () {
139
+ var _ref2 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2(queryName, options) {
140
+ var queryUrl, extendedVariables, _extendedVariables$fi, _options$variables, _extendedVariables$fi2, response, _yield$response$json, body, normalizedBody, injectedBody, errorResponse;
141
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
142
+ while (1) switch (_context2.prev = _context2.next) {
143
+ case 0:
144
+ // if (!this.backend.uri) {
145
+ // throw new Error(
146
+ // 'Backend-Uri is missing. The Backend-Uri is either set via the constructor or the init methode.'
147
+ // );
148
+ // }
149
+ // if (!this.backend.token) {
150
+ // throw new Error(
151
+ // 'Token is missing. The token is eihter set via the constructor or the init methode.'
152
+ // );
153
+ // }
154
+ // if (queryName) {
155
+ // throw new Error('QueryName is missing. The QueryName is has to be provided when calling the query methode. The queryName refers to the name of the objects to be queried. E.g. pages');
156
+ // }
157
+ queryUrl = _this.buildUrl('execQuery');
158
+ extendedVariables = options !== null && options !== void 0 && options.variables ? _objectSpread({}, options.variables) : {};
159
+ if (options !== null && options !== void 0 && options.locale) {
160
+ extendedVariables.locale = options.locale;
161
+ }
162
+ if (options !== null && options !== void 0 && options.filter && Array.isArray(options.filter)) {
163
+ if (!extendedVariables.filter) {
164
+ extendedVariables.filter = [];
165
+ }
166
+ (_extendedVariables$fi = extendedVariables.filter).push.apply(_extendedVariables$fi, (0, _toConsumableArray2["default"])(options.filter));
167
+ if (options !== null && options !== void 0 && (_options$variables = options.variables) !== null && _options$variables !== void 0 && _options$variables.filter && Array.isArray(options.variables.filter)) {
168
+ (_extendedVariables$fi2 = extendedVariables.filter).push.apply(_extendedVariables$fi2, (0, _toConsumableArray2["default"])(options.variables.filter));
169
+ }
170
+ }
171
+ _context2.next = 6;
172
+ return fetch(queryUrl, {
173
+ method: 'POST',
174
+ headers: {
175
+ 'Content-Type': 'application/json'
176
+ },
177
+ body: JSON.stringify({
178
+ uri: _this.backend.uri,
179
+ queryname: queryName,
180
+ token: _this.backend.token,
181
+ variables: extendedVariables,
182
+ components: _this.getRegisteredComponentsWithFields(),
183
+ ignoreProperties: options.ignoreProperties,
184
+ depth: options.depth
185
+ })
186
+ });
187
+ case 6:
188
+ response = _context2.sent;
189
+ if (!response.ok) {
190
+ _context2.next = 27;
191
+ break;
192
+ }
193
+ _context2.next = 10;
194
+ return response.json();
195
+ case 10:
196
+ _context2.t1 = _yield$response$json = _context2.sent;
197
+ _context2.t0 = _context2.t1 === null;
198
+ if (_context2.t0) {
199
+ _context2.next = 14;
200
+ break;
201
+ }
202
+ _context2.t0 = _yield$response$json === void 0;
203
+ case 14:
204
+ if (!_context2.t0) {
205
+ _context2.next = 18;
206
+ break;
207
+ }
208
+ _context2.t2 = void 0;
209
+ _context2.next = 19;
210
+ break;
211
+ case 18:
212
+ _context2.t2 = _yield$response$json.data;
213
+ case 19:
214
+ body = _context2.t2;
215
+ normalizedBody = _this.backend.normalize(body);
216
+ injectedBody = _this.debug ? _this.injectIds(normalizedBody) : normalizedBody;
217
+ _this.latestData = injectedBody;
218
+ _this.sendDebugEvent();
219
+ return _context2.abrupt("return", injectedBody);
220
+ case 27:
221
+ _context2.next = 29;
222
+ return response.json();
223
+ case 29:
224
+ errorResponse = _context2.sent;
225
+ console.log(errorResponse);
226
+ throw new _ApiError.ApiError(response.status, errorResponse);
227
+ case 32:
228
+ case "end":
229
+ return _context2.stop();
230
+ }
231
+ }, _callee2);
232
+ }));
233
+ return function (_x2, _x3) {
234
+ return _ref2.apply(this, arguments);
235
+ };
236
+ }());
237
+ (0, _defineProperty2["default"])(this, "getRegisteredComponentsWithFields", function () {
238
+ var components = {};
239
+ var entries = Object.entries(getAllregisteredComponents());
240
+ if (entries && Array.isArray(entries)) {
241
+ entries.forEach(function (_ref3) {
242
+ var _ref4 = (0, _slicedToArray2["default"])(_ref3, 2),
243
+ key = _ref4[0],
244
+ value = _ref4[1];
245
+ var fields = {};
246
+ var fieldNames = value.fieldNames;
247
+ var hasAtLeastOneField = false;
248
+ if (fieldNames && Array.isArray(fieldNames)) {
249
+ fieldNames.forEach(function (field) {
250
+ fields[field] = true;
251
+ hasAtLeastOneField = true;
252
+ });
253
+ }
254
+ if (hasAtLeastOneField) {
255
+ components[key] = fields;
256
+ } else {
257
+ components[key] = {
258
+ __all: true
259
+ };
260
+ }
261
+ });
262
+ }
263
+ return components;
264
+ });
265
+ (0, _defineProperty2["default"])(this, "getQueries", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
266
+ var queryUrl, response, body;
267
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
268
+ while (1) switch (_context3.prev = _context3.next) {
269
+ case 0:
270
+ queryUrl = _this.buildUrl('queries');
271
+ if (!(queryUrl && _this.backend && (_this.localServer || _this.backend.token))) {
272
+ _context3.next = 18;
273
+ break;
274
+ }
275
+ _context3.next = 4;
276
+ return fetch(queryUrl, {
277
+ method: 'POST',
278
+ headers: {
279
+ 'Content-Type': 'application/json'
280
+ },
281
+ body: JSON.stringify({
282
+ uri: _this.backend.uri,
283
+ token: _this.backend.token || null
284
+ })
285
+ });
286
+ case 4:
287
+ response = _context3.sent;
288
+ if (!response.ok) {
289
+ _context3.next = 16;
290
+ break;
291
+ }
292
+ _context3.prev = 6;
293
+ _context3.next = 9;
294
+ return response.json();
295
+ case 9:
296
+ body = _context3.sent;
297
+ return _context3.abrupt("return", body);
298
+ case 13:
299
+ _context3.prev = 13;
300
+ _context3.t0 = _context3["catch"](6);
301
+ console.error(_context3.t0);
302
+ case 16:
303
+ _context3.next = 19;
304
+ break;
305
+ case 18:
306
+ console.error('api, uri and CMSToken have to be provided');
307
+ case 19:
308
+ return _context3.abrupt("return", '');
309
+ case 20:
310
+ case "end":
311
+ return _context3.stop();
312
+ }
313
+ }, _callee3, null, [[6, 13]]);
314
+ })));
315
+ this.backend = backend;
316
+ this.apiToken = apiToken;
317
+ this.localServer = localServer;
318
+ // devtools-panel events and debug-option
319
+ this.debug = typeof document !== 'undefined' && document.getElementsByTagName('body')[0].classList.contains('qoh-inject-ids');
320
+ if (this.debug && typeof window !== 'undefined') {
321
+ window.addEventListener('QueenOfHearts-RequestData', function () {
322
+ _this.sendDebugEvent();
323
+ });
324
+ window.addEventListener('QueenOfHearts-RequestQueries', function () {
325
+ _this.sendQueriesEvent();
326
+ });
327
+ window.addEventListener('QueenOfHearts-HighlightComponent', function (event) {
328
+ _this.highlightComponent(event.detail);
329
+ });
330
+ window.addEventListener('QueenOfHearts-RequestComponentHTML', function (event) {
331
+ _this.sendComponentHTML(event.detail);
332
+ });
333
+ }
334
+ }
335
+ (0, _createClass2["default"])(QueenofheartsService, [{
336
+ key: "createComponent",
337
+ value: function createComponent(props) {
338
+ var _componentRegistry$pr, _componentRegistry$pr2;
339
+ var functionalComponent = (_componentRegistry$pr = (_componentRegistry$pr2 = componentRegistry[props.data.__typename]) === null || _componentRegistry$pr2 === void 0 ? void 0 : _componentRegistry$pr2.component) !== null && _componentRegistry$pr !== void 0 ? _componentRegistry$pr : _Dodo["default"];
340
+ return /*#__PURE__*/_react["default"].createElement(functionalComponent, _objectSpread(_objectSpread({}, props), props.data));
341
+ }
342
+ }, {
343
+ key: "injectIds",
344
+ value: function injectIds(data) {
345
+ var _this2 = this;
346
+ if (Array.isArray(data)) {
347
+ data.forEach(function (entry) {
348
+ return _this2.injectIds(entry);
349
+ });
350
+ } else if (data && (0, _typeof2["default"])(data) === 'object') {
351
+ if (data.hasOwnProperty('__typename')) {
352
+ var id = Math.random().toString();
353
+ data.__qohId = id.substr(id.indexOf('.') + 1);
354
+ }
355
+ Object.keys(data).forEach(function (key) {
356
+ return data[key] = _this2.injectIds(data[key]);
357
+ });
358
+ }
359
+ return data;
360
+ }
361
+ }, {
362
+ key: "sendDebugEvent",
363
+ value: function sendDebugEvent() {
364
+ if (typeof window === 'undefined') return;
365
+ var debugData = {
366
+ registeredComponents: Object.keys(componentRegistry),
367
+ url: this.latestUrl,
368
+ data: this.latestData
369
+ };
370
+ var event = new CustomEvent('QueenOfHearts-DebuggingData', {
371
+ detail: debugData
372
+ });
373
+ window.dispatchEvent(event);
374
+ }
375
+ }, {
376
+ key: "sendQueriesEvent",
377
+ value: function () {
378
+ var _sendQueriesEvent = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4() {
379
+ var event;
380
+ return _regenerator["default"].wrap(function _callee4$(_context4) {
381
+ while (1) switch (_context4.prev = _context4.next) {
382
+ case 0:
383
+ if (!(typeof window === 'undefined')) {
384
+ _context4.next = 2;
385
+ break;
386
+ }
387
+ return _context4.abrupt("return");
388
+ case 2:
389
+ _context4.t0 = CustomEvent;
390
+ _context4.next = 5;
391
+ return this.getQueries();
392
+ case 5:
393
+ _context4.t1 = _context4.sent;
394
+ _context4.t2 = {
395
+ detail: _context4.t1
396
+ };
397
+ event = new _context4.t0('QueenOfHearts-AvailableQueries', _context4.t2);
398
+ window.dispatchEvent(event);
399
+ case 9:
400
+ case "end":
401
+ return _context4.stop();
402
+ }
403
+ }, _callee4, this);
404
+ }));
405
+ function sendQueriesEvent() {
406
+ return _sendQueriesEvent.apply(this, arguments);
407
+ }
408
+ return sendQueriesEvent;
409
+ }()
410
+ }, {
411
+ key: "sendComponentHTML",
412
+ value: function sendComponentHTML(id) {
413
+ var _document$querySelect;
414
+ if (typeof window === 'undefined') return;
415
+ var component = (_document$querySelect = document.querySelector("[qohId='".concat(id, "']"))) === null || _document$querySelect === void 0 ? void 0 : _document$querySelect.nextElementSibling;
416
+ if (component) {
417
+ var event = new CustomEvent('QueenOfHearts-SelectedComponentHTML', {
418
+ detail: {
419
+ qohId: id,
420
+ html: component.outerHTML
421
+ }
422
+ });
423
+ window.dispatchEvent(event);
424
+ }
425
+ }
426
+ }, {
427
+ key: "highlightComponent",
428
+ value: function highlightComponent(id) {
429
+ var _document$querySelect2;
430
+ var animation = [{
431
+ outline: 'thick auto white'
432
+ }, {
433
+ outline: 'thick auto red'
434
+ }];
435
+ var animationTiming = {
436
+ duration: 1000,
437
+ iterations: 2
438
+ };
439
+ var component = (_document$querySelect2 = document.querySelector("[qohId='".concat(id, "']"))) === null || _document$querySelect2 === void 0 ? void 0 : _document$querySelect2.nextElementSibling;
440
+ component && component.scrollIntoView({
441
+ behavior: 'smooth',
442
+ block: 'center',
443
+ inline: 'center'
444
+ });
445
+ component && component.animate(animation, animationTiming);
446
+ }
447
+ }], [{
448
+ key: "init",
449
+ value: function init(backend, apiToken, localServer) {
450
+ QueenofheartsService.instance = new QueenofheartsService(backend, apiToken, localServer);
451
+ }
452
+ }, {
453
+ key: "getInstance",
454
+ value: function getInstance() {
455
+ if (!QueenofheartsService.instance) console.error('QueenofheartsService was not initializes using QueenofheartsService.init(backend, apiToken)');
456
+ return QueenofheartsService.instance;
457
+ }
458
+ }]);
459
+ return QueenofheartsService;
460
+ }();
461
+ _class = QueenofheartsService;
462
+ (0, _defineProperty2["default"])(QueenofheartsService, "instance", void 0);
@@ -0,0 +1,5 @@
1
+ export default interface Backend {
2
+ token: string;
3
+ uri: string;
4
+ normalize(data: any): any;
5
+ }
@@ -0,0 +1 @@
1
+ "use strict";
@@ -0,0 +1,8 @@
1
+ import Backend from './Backend';
2
+ export default class DatoCMS implements Backend {
3
+ token: string;
4
+ uri: string;
5
+ constructor(token: string);
6
+ renameSEOMetaTags(props: any): void;
7
+ normalize(data: any): any;
8
+ }
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = void 0;
8
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
9
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
10
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
11
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
12
+ var DatoCMS = exports["default"] = /*#__PURE__*/function () {
13
+ function DatoCMS(token) {
14
+ (0, _classCallCheck2["default"])(this, DatoCMS);
15
+ (0, _defineProperty2["default"])(this, "token", '');
16
+ (0, _defineProperty2["default"])(this, "uri", 'https://graphql.datocms.com/');
17
+ this.token = token;
18
+ }
19
+ (0, _createClass2["default"])(DatoCMS, [{
20
+ key: "renameSEOMetaTags",
21
+ value: function renameSEOMetaTags(props) {
22
+ props.forEach(function (_, i, tags) {
23
+ tags[i].__typename = "SEOMetaTag";
24
+ });
25
+ }
26
+ }, {
27
+ key: "normalize",
28
+ value: function normalize(data) {
29
+ var _this = this;
30
+ if (data["_seoMetaTags"]) {
31
+ this.renameSEOMetaTags(data["_seoMetaTags"]);
32
+ }
33
+ Object.keys(data).forEach(function (key) {
34
+ if (Array.isArray(data[key])) {
35
+ data[key] = data[key].map(function (value) {
36
+ return _this.normalize(value);
37
+ });
38
+ }
39
+ if (!!data[key] && (0, _typeof2["default"])(data[key]) === "object") {
40
+ data[key] = _this.normalize(data[key]);
41
+ }
42
+ });
43
+ return data;
44
+ }
45
+ }]);
46
+ return DatoCMS;
47
+ }();
@@ -0,0 +1,8 @@
1
+ import Backend from './Backend';
2
+ export default class StrapiCMS implements Backend {
3
+ token: string;
4
+ uri: string;
5
+ constructor(token: string, strapiUrl: string);
6
+ renameSEOMetaTags(props: any): void;
7
+ normalize(data: any): any;
8
+ }
@@ -0,0 +1,53 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = void 0;
8
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
9
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
10
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
11
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
12
+ var _dotenv = _interopRequireDefault(require("dotenv"));
13
+ _dotenv["default"].config();
14
+ var StrapiCMS = exports["default"] = /*#__PURE__*/function () {
15
+ function StrapiCMS(token, strapiUrl) {
16
+ (0, _classCallCheck2["default"])(this, StrapiCMS);
17
+ (0, _defineProperty2["default"])(this, "token", '');
18
+ (0, _defineProperty2["default"])(this, "uri", '');
19
+ this.token = token;
20
+ this.uri = strapiUrl;
21
+ }
22
+ (0, _createClass2["default"])(StrapiCMS, [{
23
+ key: "renameSEOMetaTags",
24
+ value: function renameSEOMetaTags(props) {
25
+ props.forEach(function (_, i, tags) {
26
+ tags[i].__typename = 'SEOMetaTag';
27
+ });
28
+ }
29
+ }, {
30
+ key: "normalize",
31
+ value: function normalize(data) {
32
+ var _this = this;
33
+ if (!data) {
34
+ return data;
35
+ }
36
+ if (data['_seoMetaTags']) {
37
+ this.renameSEOMetaTags(data['_seoMetaTags']);
38
+ }
39
+ Object.keys(data).forEach(function (key) {
40
+ if (Array.isArray(data[key])) {
41
+ data[key] = data[key].map(function (value) {
42
+ return _this.normalize(value);
43
+ });
44
+ }
45
+ if (!!data[key] && (0, _typeof2["default"])(data[key]) === 'object') {
46
+ data[key] = _this.normalize(data[key]);
47
+ }
48
+ });
49
+ return data;
50
+ }
51
+ }]);
52
+ return StrapiCMS;
53
+ }();
@@ -0,0 +1,3 @@
1
+ import DatoCMS from './DatoCMS';
2
+ import StrapiCMS from './StrapiCMS';
3
+ export { DatoCMS, StrapiCMS };
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ Object.defineProperty(exports, "DatoCMS", {
8
+ enumerable: true,
9
+ get: function get() {
10
+ return _DatoCMS["default"];
11
+ }
12
+ });
13
+ Object.defineProperty(exports, "StrapiCMS", {
14
+ enumerable: true,
15
+ get: function get() {
16
+ return _StrapiCMS["default"];
17
+ }
18
+ });
19
+ var _DatoCMS = _interopRequireDefault(require("./DatoCMS"));
20
+ var _StrapiCMS = _interopRequireDefault(require("./StrapiCMS"));
@@ -0,0 +1,2 @@
1
+ /// <reference types="react" />
2
+ export default function DodoComponent(props: any): JSX.Element;
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof3 = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = DodoComponent;
9
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
10
+ var React = _interopRequireWildcard(require("react"));
11
+ var _material = require("@mui/material");
12
+ var _ExpandMore = _interopRequireDefault(require("@mui/icons-material/ExpandMore"));
13
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
14
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof3(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
15
+ function renderArray(key, value, i) {
16
+ return /*#__PURE__*/React.createElement(_material.Accordion, {
17
+ key: "".concat(key, "_").concat(i),
18
+ style: {
19
+ width: "100%"
20
+ }
21
+ }, /*#__PURE__*/React.createElement(_material.AccordionSummary, {
22
+ style: {
23
+ padding: 0
24
+ },
25
+ expandIcon: /*#__PURE__*/React.createElement(_ExpandMore["default"], null)
26
+ }, key, ": Array[", value.length, "]"), /*#__PURE__*/React.createElement(_material.AccordionDetails, null, value.map(function (element, i) {
27
+ return renderData('', element, i);
28
+ })));
29
+ }
30
+ function renderObject(key, value, i) {
31
+ return /*#__PURE__*/React.createElement(_material.Accordion, {
32
+ key: "".concat(key, "_").concat(i),
33
+ style: {
34
+ width: "100%"
35
+ }
36
+ }, /*#__PURE__*/React.createElement(_material.AccordionSummary, {
37
+ expandIcon: /*#__PURE__*/React.createElement(_ExpandMore["default"], null)
38
+ }, key), /*#__PURE__*/React.createElement(_material.AccordionDetails, null, Object.entries(value).map(function (entry, i) {
39
+ return renderData(entry[0], entry[1], i);
40
+ })));
41
+ }
42
+ function renderSimple(key, value, i) {
43
+ return /*#__PURE__*/React.createElement("div", {
44
+ key: "".concat(key, "_").concat(i)
45
+ }, key, ": ", "".concat(value));
46
+ }
47
+ function renderData(key, value, i) {
48
+ var _value$__typename;
49
+ if (Array.isArray(value)) return renderArray(key, value, i);
50
+ if (!value || ['string', 'number'].includes((0, _typeof2["default"])(value))) return renderSimple(key, value, i);
51
+ if (typeof value === 'boolean') return renderSimple(key, value ? 'true' : 'false', i);
52
+ var objectKey = "".concat(key ? key + ': ' : '').concat((_value$__typename = value.__typename) !== null && _value$__typename !== void 0 ? _value$__typename : 'object');
53
+ return renderObject(objectKey, value, i);
54
+ }
55
+ function DodoComponent(props) {
56
+ if ((0, _typeof2["default"])(props.data) === "object") {
57
+ return /*#__PURE__*/React.createElement(_material.Paper, {
58
+ style: {
59
+ margin: ".5em",
60
+ width: "calc(100% - 1em)"
61
+ }
62
+ }, renderData('', props.data, 1));
63
+ }
64
+ return null;
65
+ }
@@ -0,0 +1,2 @@
1
+ /// <reference types="react" />
2
+ export declare function QueenofheartsRenderComponent(props: any): JSX.Element;
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.QueenofheartsRenderComponent = QueenofheartsRenderComponent;
8
+ var _index = require("../index");
9
+ var _react = _interopRequireDefault(require("react"));
10
+ function QueenofheartsRenderComponent(props) {
11
+ if (props.data && _index.QueenofheartsService.getInstance()) {
12
+ if (Array.isArray(props.data)) {
13
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, props.data.map(function (item, index) {
14
+ return _index.QueenofheartsService.getInstance().createComponent({
15
+ data: item,
16
+ key: index
17
+ });
18
+ }));
19
+ }
20
+ return _index.QueenofheartsService.getInstance().createComponent(props);
21
+ } else if (!_index.QueenofheartsService.getInstance()) {
22
+ return /*#__PURE__*/_react["default"].createElement("div", null, "QueenofheartsService is not initialised");
23
+ }
24
+ return /*#__PURE__*/_react["default"].createElement("div", null, "QueenofheartsRenderComponent: Invalid Data received");
25
+ }
@@ -0,0 +1 @@
1
+ "use strict";
package/lib/index.d.ts ADDED
@@ -0,0 +1,4 @@
1
+ export * from "./components/QueenofheartsRenderComponent";
2
+ export * from "./QueenofheartsService";
3
+ export * from "./backend";
4
+ export * from "./ApiError";
package/lib/index.js ADDED
@@ -0,0 +1,49 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ var _QueenofheartsRenderComponent = require("./components/QueenofheartsRenderComponent");
7
+ Object.keys(_QueenofheartsRenderComponent).forEach(function (key) {
8
+ if (key === "default" || key === "__esModule") return;
9
+ if (key in exports && exports[key] === _QueenofheartsRenderComponent[key]) return;
10
+ Object.defineProperty(exports, key, {
11
+ enumerable: true,
12
+ get: function get() {
13
+ return _QueenofheartsRenderComponent[key];
14
+ }
15
+ });
16
+ });
17
+ var _QueenofheartsService = require("./QueenofheartsService");
18
+ Object.keys(_QueenofheartsService).forEach(function (key) {
19
+ if (key === "default" || key === "__esModule") return;
20
+ if (key in exports && exports[key] === _QueenofheartsService[key]) return;
21
+ Object.defineProperty(exports, key, {
22
+ enumerable: true,
23
+ get: function get() {
24
+ return _QueenofheartsService[key];
25
+ }
26
+ });
27
+ });
28
+ var _backend = require("./backend");
29
+ Object.keys(_backend).forEach(function (key) {
30
+ if (key === "default" || key === "__esModule") return;
31
+ if (key in exports && exports[key] === _backend[key]) return;
32
+ Object.defineProperty(exports, key, {
33
+ enumerable: true,
34
+ get: function get() {
35
+ return _backend[key];
36
+ }
37
+ });
38
+ });
39
+ var _ApiError = require("./ApiError");
40
+ Object.keys(_ApiError).forEach(function (key) {
41
+ if (key === "default" || key === "__esModule") return;
42
+ if (key in exports && exports[key] === _ApiError[key]) return;
43
+ Object.defineProperty(exports, key, {
44
+ enumerable: true,
45
+ get: function get() {
46
+ return _ApiError[key];
47
+ }
48
+ });
49
+ });
package/package.json ADDED
@@ -0,0 +1,57 @@
1
+ {
2
+ "name": "@qoh/core-react",
3
+ "description": "Queen of hearts Core API",
4
+ "version": "0.0.1",
5
+ "license": "MIT",
6
+ "main": "lib/index.js",
7
+ "module": "lib/index.js",
8
+ "types": "lib/index.d.ts",
9
+ "files": [
10
+ "/lib",
11
+ "/*.md"
12
+ ],
13
+ "private": false,
14
+ "scripts": {
15
+ "test": "jest --passWithNoTests",
16
+ "build:prod": "babel src --out-dir lib --extensions \".ts,.tsx\" --presets minify",
17
+ "build": "npm run build:types && npm run build:dev",
18
+ "build:dev": "babel src --out-dir lib --extensions \".ts,.tsx\"",
19
+ "build:types": "tsc --project tsconfig.json"
20
+ },
21
+ "dependencies": {
22
+ "@babel/cli": "^7.21.0",
23
+ "@babel/core": "^7.21.4",
24
+ "@mui/icons-material": "^5.11.16",
25
+ "babel-plugin-transform-scss": "^1.2.0",
26
+ "cross-env": "^7.0.3",
27
+ "mobx": "^6.3.0",
28
+ "mobx-react": "^7.1.0",
29
+ "uuid": "^9.0.0"
30
+ },
31
+ "devDependencies": {
32
+ "@babel/plugin-proposal-class-properties": "^7.13.0",
33
+ "@babel/plugin-proposal-decorators": "^7.14.2",
34
+ "@babel/plugin-transform-runtime": "^7.21.0",
35
+ "@babel/preset-env": "^7.14.7",
36
+ "@babel/preset-react": "^7.23.3",
37
+ "@babel/preset-typescript": "^7.23.3",
38
+ "@mui/material": "^5.11.16",
39
+ "@types/react": "^18.0.33",
40
+ "babel-jest": "^26.6.3",
41
+ "babel-plugin-transform-react-jsx": "^6.24.1",
42
+ "babel-preset-minify": "^0.5.2",
43
+ "decamelize": "^1.2.0",
44
+ "i": "^0.3.7",
45
+ "identity-obj-proxy": "^3.0.0",
46
+ "is-ci": "^2.0.0",
47
+ "jest": "^26.6.3",
48
+ "npm": "^9.6.4",
49
+ "typescript": "^4.9.5",
50
+ "which-module": "^2.0.0"
51
+ },
52
+ "jest": {
53
+ "transform": {
54
+ "^.+\\.[t|j]sx?$": "babel-jest"
55
+ }
56
+ }
57
+ }