@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 +5 -0
- package/LICENSE.md +21 -0
- package/README.md +2 -0
- package/lib/ApiError.d.ts +9 -0
- package/lib/ApiError.js +33 -0
- package/lib/QueenofheartsService.d.ts +66 -0
- package/lib/QueenofheartsService.js +462 -0
- package/lib/backend/Backend.d.ts +5 -0
- package/lib/backend/Backend.js +1 -0
- package/lib/backend/DatoCMS.d.ts +8 -0
- package/lib/backend/DatoCMS.js +47 -0
- package/lib/backend/StrapiCMS.d.ts +8 -0
- package/lib/backend/StrapiCMS.js +53 -0
- package/lib/backend/index.d.ts +3 -0
- package/lib/backend/index.js +20 -0
- package/lib/components/Dodo.d.ts +2 -0
- package/lib/components/Dodo.js +65 -0
- package/lib/components/QueenofheartsRenderComponent.d.ts +2 -0
- package/lib/components/QueenofheartsRenderComponent.js +25 -0
- package/lib/declaration.d.js +1 -0
- package/lib/index.d.ts +4 -0
- package/lib/index.js +49 -0
- package/package.json +57 -0
package/CHANGELOG.md
ADDED
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
package/lib/ApiError.js
ADDED
|
@@ -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 @@
|
|
|
1
|
+
"use strict";
|
|
@@ -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,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,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,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,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
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
|
+
}
|