auto-component 0.0.39 → 0.0.41

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/lib/index.js ADDED
@@ -0,0 +1,391 @@
1
+ "use strict";
2
+
3
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = void 0;
8
+ var _react = _interopRequireWildcard(require("react"));
9
+ var _reactJsxParser = _interopRequireDefault(require("react-jsx-parser"));
10
+ require("./auto-component.css");
11
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
12
+ 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); }
13
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(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; }
14
+ function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return e; }; var t, e = {}, r = Object.prototype, n = r.hasOwnProperty, o = Object.defineProperty || function (t, e, r) { t[e] = r.value; }, i = "function" == typeof Symbol ? Symbol : {}, a = i.iterator || "@@iterator", c = i.asyncIterator || "@@asyncIterator", u = i.toStringTag || "@@toStringTag"; function define(t, e, r) { return Object.defineProperty(t, e, { value: r, enumerable: !0, configurable: !0, writable: !0 }), t[e]; } try { define({}, ""); } catch (t) { define = function define(t, e, r) { return t[e] = r; }; } function wrap(t, e, r, n) { var i = e && e.prototype instanceof Generator ? e : Generator, a = Object.create(i.prototype), c = new Context(n || []); return o(a, "_invoke", { value: makeInvokeMethod(t, r, c) }), a; } function tryCatch(t, e, r) { try { return { type: "normal", arg: t.call(e, r) }; } catch (t) { return { type: "throw", arg: t }; } } e.wrap = wrap; var h = "suspendedStart", l = "suspendedYield", f = "executing", s = "completed", y = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var p = {}; define(p, a, function () { return this; }); var d = Object.getPrototypeOf, v = d && d(d(values([]))); v && v !== r && n.call(v, a) && (p = v); var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p); function defineIteratorMethods(t) { ["next", "throw", "return"].forEach(function (e) { define(t, e, function (t) { return this._invoke(e, t); }); }); } function AsyncIterator(t, e) { function invoke(r, o, i, a) { var c = tryCatch(t[r], t, o); if ("throw" !== c.type) { var u = c.arg, h = u.value; return h && "object" == _typeof(h) && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) { invoke("next", t, i, a); }, function (t) { invoke("throw", t, i, a); }) : e.resolve(h).then(function (t) { u.value = t, i(u); }, function (t) { return invoke("throw", t, i, a); }); } a(c.arg); } var r; o(this, "_invoke", { value: function value(t, n) { function callInvokeWithMethodAndArg() { return new e(function (e, r) { invoke(t, n, e, r); }); } return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(e, r, n) { var o = h; return function (i, a) { if (o === f) throw new Error("Generator is already running"); if (o === s) { if ("throw" === i) throw a; return { value: t, done: !0 }; } for (n.method = i, n.arg = a;;) { var c = n.delegate; if (c) { var u = maybeInvokeDelegate(c, n); if (u) { if (u === y) continue; return u; } } if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) { if (o === h) throw o = s, n.arg; n.dispatchException(n.arg); } else "return" === n.method && n.abrupt("return", n.arg); o = f; var p = tryCatch(e, r, n); if ("normal" === p.type) { if (o = n.done ? s : l, p.arg === y) continue; return { value: p.arg, done: n.done }; } "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg); } }; } function maybeInvokeDelegate(e, r) { var n = r.method, o = e.iterator[n]; if (o === t) return r.delegate = null, "throw" === n && e.iterator["return"] && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y; var i = tryCatch(o, e.iterator, r.arg); if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y; var a = i.arg; return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y); } function pushTryEntry(t) { var e = { tryLoc: t[0] }; 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e); } function resetTryEntry(t) { var e = t.completion || {}; e.type = "normal", delete e.arg, t.completion = e; } function Context(t) { this.tryEntries = [{ tryLoc: "root" }], t.forEach(pushTryEntry, this), this.reset(!0); } function values(e) { if (e || "" === e) { var r = e[a]; if (r) return r.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) { var o = -1, i = function next() { for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next; return next.value = t, next.done = !0, next; }; return i.next = i; } } throw new TypeError(_typeof(e) + " is not iterable"); } return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), o(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) { var e = "function" == typeof t && t.constructor; return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name)); }, e.mark = function (t) { return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t; }, e.awrap = function (t) { return { __await: t }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () { return this; }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) { void 0 === i && (i = Promise); var a = new AsyncIterator(wrap(t, r, n, o), i); return e.isGeneratorFunction(r) ? a : a.next().then(function (t) { return t.done ? t.value : a.next(); }); }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () { return this; }), define(g, "toString", function () { return "[object Generator]"; }), e.keys = function (t) { var e = Object(t), r = []; for (var n in e) r.push(n); return r.reverse(), function next() { for (; r.length;) { var t = r.pop(); if (t in e) return next.value = t, next.done = !1, next; } return next.done = !0, next; }; }, e.values = values, Context.prototype = { constructor: Context, reset: function reset(e) { if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t); }, stop: function stop() { this.done = !0; var t = this.tryEntries[0].completion; if ("throw" === t.type) throw t.arg; return this.rval; }, dispatchException: function dispatchException(e) { if (this.done) throw e; var r = this; function handle(n, o) { return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o; } for (var o = this.tryEntries.length - 1; o >= 0; --o) { var i = this.tryEntries[o], a = i.completion; if ("root" === i.tryLoc) return handle("end"); if (i.tryLoc <= this.prev) { var c = n.call(i, "catchLoc"), u = n.call(i, "finallyLoc"); if (c && u) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } else if (c) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); } else { if (!u) throw new Error("try statement without catch or finally"); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } } } }, abrupt: function abrupt(t, e) { for (var r = this.tryEntries.length - 1; r >= 0; --r) { var o = this.tryEntries[r]; if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) { var i = o; break; } } i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null); var a = i ? i.completion : {}; return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a); }, complete: function complete(t, e) { if ("throw" === t.type) throw t.arg; return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y; }, finish: function finish(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y; } }, "catch": function _catch(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.tryLoc === t) { var n = r.completion; if ("throw" === n.type) { var o = n.arg; resetTryEntry(r); } return o; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(e, r, n) { return this.delegate = { iterator: values(e), resultName: r, nextLoc: n }, "next" === this.method && (this.arg = t), y; } }, e; }
15
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
16
+ function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
17
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
18
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
19
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
20
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
21
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
22
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } /* eslint-disable no-unused-vars */ /* eslint-disable react-hooks/exhaustive-deps */ // import beautify from 'js-beautify';
23
+ var AutoComponent = function AutoComponent() {
24
+ //**-----------**/
25
+ // ** State ** //
26
+ //**---------**/
27
+ var _useState = (0, _react.useState)(''),
28
+ _useState2 = _slicedToArray(_useState, 2),
29
+ currentHtml = _useState2[0],
30
+ setHtml = _useState2[1];
31
+ var _useState3 = (0, _react.useState)(''),
32
+ _useState4 = _slicedToArray(_useState3, 2),
33
+ currentStyle = _useState4[0],
34
+ setStyles = _useState4[1];
35
+ var _useState5 = (0, _react.useState)(''),
36
+ _useState6 = _slicedToArray(_useState5, 2),
37
+ currentRequest = _useState6[0],
38
+ setRequest = _useState6[1];
39
+ var _useState7 = (0, _react.useState)(''),
40
+ _useState8 = _slicedToArray(_useState7, 2),
41
+ user = _useState8[0],
42
+ setUser = _useState8[1];
43
+ var _useState9 = (0, _react.useState)(''),
44
+ _useState10 = _slicedToArray(_useState9, 2),
45
+ responseData = _useState10[0],
46
+ setResponseData = _useState10[1];
47
+ var _useState11 = (0, _react.useState)(null),
48
+ _useState12 = _slicedToArray(_useState11, 2),
49
+ requestData = _useState12[0],
50
+ setRequestData = _useState12[1];
51
+ var _useState13 = (0, _react.useState)(''),
52
+ _useState14 = _slicedToArray(_useState13, 2),
53
+ activeTab = _useState14[0],
54
+ setActiveTab = _useState14[1];
55
+ var _useState15 = (0, _react.useState)(["No History"]),
56
+ _useState16 = _slicedToArray(_useState15, 2),
57
+ history = _useState16[0],
58
+ setHistory = _useState16[1];
59
+
60
+ //**-------------------------**/
61
+ // ** HTML/CSS Formatting ** //
62
+ //**-----------------------**/
63
+ // get the html/style for the current page and set state
64
+ var htmlContent = function htmlContent() {
65
+ var body = document.querySelector('body');
66
+ var htmlContent = body ? body.innerHTML : '';
67
+ var cssStyles = document.documentElement.innerHTML;
68
+ var cleanedHtml = cleanExclusions(htmlContent);
69
+ var cleanedStyles = cleanStyles(cssStyles);
70
+ setHtml(cleanedHtml);
71
+ setStyles(cleanedStyles);
72
+ };
73
+
74
+ // format html for display (breaks/indentation)
75
+ // const formatHtml = (html) => {
76
+ // return beautify.html(html, {
77
+ // indent_size: 2,
78
+ // wrap_line_length: 80,
79
+ // max_preserve_newlines: 1,
80
+ // })
81
+ // }
82
+
83
+ // clean html of exclusions:
84
+ // if an element className includes 'exclude'
85
+ // (partial) the element wrapper remains, but contents removed
86
+ // OR, (full) the element and it's content are excluded from output
87
+
88
+ // partial exclusion
89
+
90
+ var cleanExclusions = function cleanExclusions(html) {
91
+ var parser = new DOMParser();
92
+ var doc = parser.parseFromString(html, 'text/html');
93
+ var elementsToClean = doc.querySelectorAll('.exclude');
94
+ elementsToClean.forEach(function (element) {
95
+ removeAllChildNodes(element);
96
+ });
97
+ return doc.documentElement.outerHTML;
98
+ };
99
+ var removeAllChildNodes = function removeAllChildNodes(element) {
100
+ Array.from(element.childNodes).forEach(function (child) {
101
+ if (child.nodeType === Node.ELEMENT_NODE) {
102
+ removeAllChildNodes(child);
103
+ } else {
104
+ element.removeChild(child);
105
+ }
106
+ });
107
+ };
108
+
109
+ // full exclusion
110
+ // const cleanExclusions = (html) => {
111
+ // const parser = new DOMParser();
112
+ // const doc = parser.parseFromString(html, 'text/html');
113
+ //
114
+ // const elementsToExclude = doc.querySelectorAll('.exclude');
115
+ //
116
+ // elementsToExclude.forEach((element) => {
117
+ // element.parentNode.removeChild(element);
118
+ // });
119
+ //
120
+ // return doc.documentElement.outerHTML;
121
+ // };
122
+
123
+ // exclude non <style> data and remove comments
124
+ var cleanStyles = function cleanStyles(css) {
125
+ var styleRegex = /<style\b[^>]*>([\s\S]*?)<\/style>/g;
126
+ var matches = css.match(styleRegex);
127
+ if (matches) {
128
+ var cleanedMatches = matches.map(function (match) {
129
+ return match.replace(/\/\*[\s\S]*?\*\//g, '');
130
+ });
131
+ return cleanedMatches;
132
+ }
133
+ return null;
134
+ };
135
+ var randomUser = function randomUser() {
136
+ setUser(Math.floor(Math.random() * 100000));
137
+ };
138
+ (0, _react.useEffect)(function () {
139
+ htmlContent();
140
+ randomUser();
141
+ }, []);
142
+
143
+ //**---------------------------**/
144
+ // ** API Requests/Response ** //
145
+ //**-------------------------**/
146
+
147
+ // TEMP FUNCTION FOR TESTING
148
+ // const sendRequest = (data) => {
149
+ // return(response)
150
+ // }
151
+
152
+ var sendRequest = /*#__PURE__*/function () {
153
+ var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
154
+ var url, res, jsonData;
155
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
156
+ while (1) switch (_context.prev = _context.next) {
157
+ case 0:
158
+ url = "https://server-auto-component-46830ff262f8.herokuapp.com/api";
159
+ _context.prev = 1;
160
+ _context.next = 4;
161
+ return fetch(url, {
162
+ method: 'POST',
163
+ headers: {
164
+ 'Content-Type': 'application/json'
165
+ },
166
+ body: JSON.stringify(requestData)
167
+ });
168
+ case 4:
169
+ res = _context.sent;
170
+ if (!res.ok) {
171
+ _context.next = 12;
172
+ break;
173
+ }
174
+ _context.next = 8;
175
+ return res.json();
176
+ case 8:
177
+ jsonData = _context.sent;
178
+ return _context.abrupt("return", jsonData);
179
+ case 12:
180
+ throw new Error("Invalid request!");
181
+ case 13:
182
+ _context.next = 18;
183
+ break;
184
+ case 15:
185
+ _context.prev = 15;
186
+ _context.t0 = _context["catch"](1);
187
+ console.log(_context.t0.message);
188
+ case 18:
189
+ case "end":
190
+ return _context.stop();
191
+ }
192
+ }, _callee, null, [[1, 15]]);
193
+ }));
194
+ return function sendRequest() {
195
+ return _ref.apply(this, arguments);
196
+ };
197
+ }();
198
+ var cleanId = function cleanId(html) {
199
+ var parser = new DOMParser();
200
+ var doc = parser.parseFromString(html, 'text/html');
201
+ var autoComponentContainer = doc.getElementById('auto-component-container');
202
+ if (autoComponentContainer) {
203
+ autoComponentContainer.removeAttribute('id');
204
+ }
205
+ return doc.documentElement.outerHTML;
206
+ };
207
+
208
+ // make API request with updated state data
209
+ var handleRequest = /*#__PURE__*/function () {
210
+ var _ref2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2() {
211
+ var resData;
212
+ return _regeneratorRuntime().wrap(function _callee2$(_context2) {
213
+ while (1) switch (_context2.prev = _context2.next) {
214
+ case 0:
215
+ _context2.prev = 0;
216
+ _context2.next = 3;
217
+ return sendRequest();
218
+ case 3:
219
+ resData = _context2.sent;
220
+ if (resData) {
221
+ setHistory(resData.history);
222
+ // setResponseData(formatHtml(resData.response.content));
223
+ // const outputHtml = cleanId(resData.response.content)
224
+ setResponseData(resData.response.content);
225
+ setActiveTab('response');
226
+ }
227
+ _context2.next = 10;
228
+ break;
229
+ case 7:
230
+ _context2.prev = 7;
231
+ _context2.t0 = _context2["catch"](0);
232
+ console.log(_context2.t0);
233
+ case 10:
234
+ case "end":
235
+ return _context2.stop();
236
+ }
237
+ }, _callee2, null, [[0, 7]]);
238
+ }));
239
+ return function handleRequest() {
240
+ return _ref2.apply(this, arguments);
241
+ };
242
+ }();
243
+
244
+ //**------------------------**/
245
+ // ** UI/Button Handling ** //
246
+ //**----------------------**/
247
+
248
+ var handleChange = function handleChange(e) {
249
+ e.preventDefault();
250
+ setRequest(e.target.value);
251
+ };
252
+ var handleGenerate = /*#__PURE__*/function () {
253
+ var _ref3 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee3(e) {
254
+ return _regeneratorRuntime().wrap(function _callee3$(_context3) {
255
+ while (1) switch (_context3.prev = _context3.next) {
256
+ case 0:
257
+ _context3.next = 2;
258
+ return setRequestData({
259
+ "userId": user,
260
+ "request": currentRequest,
261
+ "html": currentHtml
262
+ });
263
+ case 2:
264
+ case "end":
265
+ return _context3.stop();
266
+ }
267
+ }, _callee3);
268
+ }));
269
+ return function handleGenerate(_x) {
270
+ return _ref3.apply(this, arguments);
271
+ };
272
+ }();
273
+ (0, _react.useEffect)(function () {
274
+ if (requestData !== null) {
275
+ handleRequest();
276
+ }
277
+ }, [requestData]);
278
+ var handleReset = function handleReset() {
279
+ setRequest('');
280
+ setResponseData('');
281
+ randomUser();
282
+ setHistory([]);
283
+ };
284
+ var handleRequestTab = /*#__PURE__*/function () {
285
+ var _ref4 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee4() {
286
+ return _regeneratorRuntime().wrap(function _callee4$(_context4) {
287
+ while (1) switch (_context4.prev = _context4.next) {
288
+ case 0:
289
+ _context4.next = 2;
290
+ return setActiveTab(activeTab === 'response' || activeTab === '' ? 'request' : '');
291
+ case 2:
292
+ case "end":
293
+ return _context4.stop();
294
+ }
295
+ }, _callee4);
296
+ }));
297
+ return function handleRequestTab() {
298
+ return _ref4.apply(this, arguments);
299
+ };
300
+ }();
301
+ var handleResponseTab = /*#__PURE__*/function () {
302
+ var _ref5 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee5() {
303
+ return _regeneratorRuntime().wrap(function _callee5$(_context5) {
304
+ while (1) switch (_context5.prev = _context5.next) {
305
+ case 0:
306
+ _context5.next = 2;
307
+ return setActiveTab(activeTab === 'request' || activeTab === '' ? 'response' : '');
308
+ case 2:
309
+ case "end":
310
+ return _context5.stop();
311
+ }
312
+ }, _callee5);
313
+ }));
314
+ return function handleResponseTab() {
315
+ return _ref5.apply(this, arguments);
316
+ };
317
+ }();
318
+ var copyToClipboard = /*#__PURE__*/function () {
319
+ var _ref6 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee6() {
320
+ var text;
321
+ return _regeneratorRuntime().wrap(function _callee6$(_context6) {
322
+ while (1) switch (_context6.prev = _context6.next) {
323
+ case 0:
324
+ text = activeTab === 'response' ? responseData : requestData;
325
+ _context6.next = 3;
326
+ return navigator.clipboard.writeText(text);
327
+ case 3:
328
+ case "end":
329
+ return _context6.stop();
330
+ }
331
+ }, _callee6);
332
+ }));
333
+ return function copyToClipboard() {
334
+ return _ref6.apply(this, arguments);
335
+ };
336
+ }();
337
+
338
+ //**---------------**/
339
+ // ** Rendering ** //
340
+ //**-------------**/
341
+
342
+ var getLog = function getLog() {
343
+ return history.map(function (entry, index) {
344
+ return index !== 0 && entry.content.split('HTML Context:')[0] + (entry.content.includes("User Request") ? '\n' : '\n\n\n');
345
+ });
346
+ };
347
+ var requestHTML = currentHtml ? getLog() + "Review the details below for accuracy and privacy concerns.\nIf the contents of an element should be excluded, add the 'exclude' class to the element.\nClick Generate to send the request and receive the auto component AI generated code.\n\nUser ID:\n " + user + "\n\nUser Request:\n" + currentRequest + "\n\nUser HTML:\n" + currentHtml : 'There was an error collecting your HTML. Ensure no top level elements are assigned the class "exclude"';
348
+ console.log(responseData);
349
+ var responseHtml = responseData ? responseData : 'No response has been generated';
350
+ return /*#__PURE__*/_react["default"].createElement("div", {
351
+ className: "auto-component exclude"
352
+ }, /*#__PURE__*/_react["default"].createElement("div", null, responseData ?
353
+ /*#__PURE__*/
354
+ // Use {} to directly interpolate the JSX code
355
+ _react["default"].createElement(_reactJsxParser["default"], {
356
+ jsx: responseData
357
+ }) : '- auto component will be added here -'), /*#__PURE__*/_react["default"].createElement("div", {
358
+ id: "auto-component-ui"
359
+ }, /*#__PURE__*/_react["default"].createElement("div", {
360
+ id: "auto-component-code-container",
361
+ className: "".concat(!activeTab ? 'auto-component-hidden' : '', " auto-component-code")
362
+ }, /*#__PURE__*/_react["default"].createElement("pre", {
363
+ id: "auto-component-code"
364
+ }, activeTab === 'request' ? requestHTML : responseHtml), /*#__PURE__*/_react["default"].createElement("div", {
365
+ className: "auto-component-copy",
366
+ onClick: copyToClipboard,
367
+ style: activeTab !== 'response' ? {
368
+ display: 'none'
369
+ } : null
370
+ }, "copy")), /*#__PURE__*/_react["default"].createElement("div", {
371
+ id: "auto-component-entry"
372
+ }, /*#__PURE__*/_react["default"].createElement("input", {
373
+ type: "text",
374
+ value: currentRequest,
375
+ onChange: handleChange,
376
+ placeholder: "Enter a request"
377
+ }), /*#__PURE__*/_react["default"].createElement("button", {
378
+ onClick: handleGenerate
379
+ }, "Generate"), /*#__PURE__*/_react["default"].createElement("button", {
380
+ onClick: handleReset
381
+ }, "X")), /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement("div", {
382
+ id: "auto-component-tabs"
383
+ }, /*#__PURE__*/_react["default"].createElement("div", {
384
+ className: "".concat(activeTab === 'request' ? 'auto-component-selected' : '', " tab"),
385
+ onClick: handleRequestTab
386
+ }, "Request"), /*#__PURE__*/_react["default"].createElement("div", {
387
+ className: "".concat(activeTab === 'response' ? 'auto-component-selected' : '', " tab"),
388
+ onClick: handleResponseTab
389
+ }, "Response")))));
390
+ };
391
+ var _default = exports["default"] = AutoComponent;
package/package.json CHANGED
@@ -1,13 +1,24 @@
1
1
  {
2
2
  "name": "auto-component",
3
- "version": "0.0.39",
4
- "main": "src/index.jsx",
3
+ "version": "0.0.41",
4
+ "main": "lib/index.js",
5
5
  "peerDependencies": {
6
6
  "react": "^18.2.0",
7
7
  "react-dom": "*",
8
8
  "react-jsx-parser": "^1.29.0"
9
9
  },
10
+ "scripts": {
11
+ "transpile": "babel src -d lib --copy-files",
12
+ "prepublishOnly": "npm run transpile"
13
+ },
10
14
  "files": [
11
- "src"
12
- ]
15
+ "lib",
16
+ "README.md"
17
+ ],
18
+ "devDependencies": {
19
+ "@babel/cli": "^7.23.4",
20
+ "@babel/core": "^7.23.6",
21
+ "@babel/preset-env": "^7.23.6",
22
+ "@babel/preset-react": "^7.23.3"
23
+ }
13
24
  }
package/src/index.jsx DELETED
@@ -1,296 +0,0 @@
1
- /* eslint-disable no-unused-vars */
2
- /* eslint-disable react-hooks/exhaustive-deps */
3
- import { JSXParser } from 'react-jsx-parser'
4
- import { useState, useEffect } from 'react'
5
- // import beautify from 'js-beautify';
6
- import './auto-component.css'
7
-
8
- const AutoComponent = () => {
9
-
10
- //**-----------**/
11
- // ** State ** //
12
- //**---------**/
13
- const [ currentHtml, setHtml ] = useState('')
14
- const [ currentStyle, setStyles ] = useState('')
15
- const [ currentRequest, setRequest ] = useState('')
16
- const [ user, setUser ] = useState('')
17
-
18
- const [ responseData, setResponseData ] = useState('')
19
- const [ requestData, setRequestData ] = useState(null)
20
-
21
- const [ activeTab, setActiveTab ] = useState('')
22
- const [ history, setHistory ] = useState(["No History"])
23
-
24
- //**-------------------------**/
25
- // ** HTML/CSS Formatting ** //
26
- //**-----------------------**/
27
- // get the html/style for the current page and set state
28
- const htmlContent = () => {
29
- const body = document.querySelector('body')
30
- const htmlContent = body ? body.innerHTML : ''
31
- const cssStyles = document.documentElement.innerHTML
32
-
33
- const cleanedHtml = cleanExclusions(htmlContent)
34
- const cleanedStyles = cleanStyles(cssStyles)
35
-
36
- setHtml(cleanedHtml)
37
- setStyles(cleanedStyles)
38
- }
39
-
40
- // format html for display (breaks/indentation)
41
- // const formatHtml = (html) => {
42
- // return beautify.html(html, {
43
- // indent_size: 2,
44
- // wrap_line_length: 80,
45
- // max_preserve_newlines: 1,
46
- // })
47
- // }
48
-
49
- // clean html of exclusions:
50
- // if an element className includes 'exclude'
51
- // (partial) the element wrapper remains, but contents removed
52
- // OR, (full) the element and it's content are excluded from output
53
-
54
- // partial exclusion
55
-
56
- const cleanExclusions = (html) => {
57
- const parser = new DOMParser();
58
- const doc = parser.parseFromString(html, 'text/html');
59
-
60
- const elementsToClean = doc.querySelectorAll('.exclude');
61
-
62
- elementsToClean.forEach((element) => {
63
- removeAllChildNodes(element);
64
- });
65
-
66
- return doc.documentElement.outerHTML;
67
- };
68
-
69
- const removeAllChildNodes = (element) => {
70
- Array.from(element.childNodes).forEach((child) => {
71
- if (child.nodeType === Node.ELEMENT_NODE) {
72
- removeAllChildNodes(child);
73
- } else {
74
- element.removeChild(child);
75
- }
76
- });
77
- };
78
-
79
-
80
- // full exclusion
81
- // const cleanExclusions = (html) => {
82
- // const parser = new DOMParser();
83
- // const doc = parser.parseFromString(html, 'text/html');
84
- //
85
- // const elementsToExclude = doc.querySelectorAll('.exclude');
86
- //
87
- // elementsToExclude.forEach((element) => {
88
- // element.parentNode.removeChild(element);
89
- // });
90
- //
91
- // return doc.documentElement.outerHTML;
92
- // };
93
-
94
- // exclude non <style> data and remove comments
95
- const cleanStyles = (css) => {
96
- const styleRegex = /<style\b[^>]*>(.*?)<\/style>/gs
97
- const matches = css.match(styleRegex)
98
-
99
- if (matches) {
100
- const cleanedMatches = matches.map(match => match.replace(/\/\*[\s\S]*?\*\//g, ''))
101
- return cleanedMatches
102
- }
103
- return null
104
- }
105
-
106
- const randomUser = () => {
107
- setUser(Math.floor(Math.random()*100000))
108
- }
109
-
110
- useEffect(() => {
111
- htmlContent()
112
- randomUser()
113
- }, [])
114
-
115
- //**---------------------------**/
116
- // ** API Requests/Response ** //
117
- //**-------------------------**/
118
-
119
- // TEMP FUNCTION FOR TESTING
120
- // const sendRequest = (data) => {
121
- // return(response)
122
- // }
123
-
124
- const sendRequest = async () => {
125
- const url = "https://server-auto-component-46830ff262f8.herokuapp.com/api";
126
-
127
- try {
128
- const res = await fetch(url, {
129
- method: 'POST',
130
- headers: {
131
- 'Content-Type': 'application/json',
132
- },
133
- body: JSON.stringify(requestData),
134
- });
135
-
136
- if (res.ok) {
137
- const jsonData = await res.json();
138
- return jsonData;
139
- } else {
140
- throw new Error("Invalid request!");
141
- }
142
- } catch (err) {
143
- console.log(err.message);
144
- }
145
- };
146
-
147
- const cleanId = (html) => {
148
- const parser = new DOMParser();
149
- const doc = parser.parseFromString(html, 'text/html');
150
-
151
- const autoComponentContainer = doc.getElementById('auto-component-container');
152
-
153
- if (autoComponentContainer) {
154
- autoComponentContainer.removeAttribute('id');
155
- }
156
-
157
- return doc.documentElement.outerHTML;
158
- };
159
-
160
- // make API request with updated state data
161
- const handleRequest = async () => {
162
- try {
163
- const resData = await sendRequest();
164
-
165
- if (resData) {
166
- setHistory(resData.history)
167
- // setResponseData(formatHtml(resData.response.content));
168
- // const outputHtml = cleanId(resData.response.content)
169
- setResponseData(resData.response.content);
170
- setActiveTab('response');
171
- }
172
- } catch (err) {
173
- console.log(err);
174
- }
175
- // setIsLoading(false);
176
- };
177
-
178
- //**------------------------**/
179
- // ** UI/Button Handling ** //
180
- //**----------------------**/
181
-
182
- const handleChange = (e) => {
183
- e.preventDefault()
184
- setRequest(e.target.value)
185
- }
186
-
187
- const handleGenerate = async (e) => {
188
- await setRequestData({
189
- "userId": user,
190
- "request": currentRequest,
191
- "html": currentHtml
192
- })
193
- }
194
-
195
- useEffect(() => {
196
- if (requestData !== null) {
197
- handleRequest();
198
- }
199
- },[requestData])
200
-
201
- const handleReset = () => {
202
- setRequest('')
203
- setResponseData('')
204
- randomUser()
205
- setHistory([])
206
- }
207
-
208
- const handleRequestTab = async () => {
209
- await setActiveTab(activeTab === 'response' || activeTab === '' ? 'request' : '');
210
- }
211
-
212
- const handleResponseTab = async () => {
213
- await setActiveTab(activeTab === 'request' || activeTab === '' ? 'response' : '');
214
- }
215
-
216
- const copyToClipboard = async () => {
217
- const text = activeTab === 'response' ? responseData : requestData
218
- await navigator.clipboard.writeText(text)
219
- }
220
-
221
- //**---------------**/
222
- // ** Rendering ** //
223
- //**-------------**/
224
-
225
- const getLog = () => {
226
- return (
227
- history.map((entry, index) => (
228
-
229
- index !== 0 && entry.content.split('HTML Context:')[0] + (entry.content.includes("User Request") ? '\n' : '\n\n\n')
230
- )
231
- ))
232
- }
233
-
234
- const requestHTML = currentHtml ? (
235
- getLog() +
236
- `Review the details below for accuracy and privacy concerns.
237
- If the contents of an element should be excluded, add the 'exclude' class to the element.
238
- Click Generate to send the request and receive the auto component AI generated code.
239
-
240
- User ID:\n `
241
- + user
242
- + "\n\nUser Request:\n"
243
- + currentRequest
244
- + "\n\nUser HTML:\n"
245
- + currentHtml
246
- ) : 'There was an error collecting your HTML. Ensure no top level elements are assigned the class "exclude"'
247
-
248
-
249
- console.log(responseData)
250
- const responseHtml = responseData ? (
251
- responseData
252
- ) : 'No response has been generated'
253
-
254
- return (
255
-
256
- <div className='auto-component exclude'>
257
- <div>
258
- {responseData ? (
259
- // Use {} to directly interpolate the JSX code
260
- <JSXParser jsx={responseData} />
261
- ) : (
262
- '- auto component will be added here -'
263
- )}
264
- </div>
265
-
266
- <div id="auto-component-ui">
267
- <div id="auto-component-code-container" className={`${!activeTab ? 'auto-component-hidden' : ''} auto-component-code`}>
268
- <pre id="auto-component-code">
269
- {activeTab === 'request' ? requestHTML : responseHtml}
270
- </pre>
271
- <div className="auto-component-copy" onClick={copyToClipboard} style={activeTab !== 'response' ? { display: 'none' } : null}>
272
- copy
273
- </div>
274
- </div>
275
- <div id="auto-component-entry">
276
- <input type="text" value={currentRequest} onChange={handleChange} placeholder="Enter a request"></input>
277
- <button onClick={handleGenerate}>Generate</button>
278
- <button onClick={handleReset}>X</button>
279
- </div>
280
- <div>
281
- <div id='auto-component-tabs'>
282
- <div className={`${activeTab === 'request' ? 'auto-component-selected' : ''} tab`} onClick={handleRequestTab}>
283
- Request
284
- </div>
285
- <div className={`${activeTab === 'response' ? 'auto-component-selected' : ''} tab`} onClick={handleResponseTab}>
286
- Response
287
- </div>
288
- </div>
289
- </div>
290
- </div>
291
- </div>
292
- )
293
- }
294
-
295
- export default AutoComponent
296
-
File without changes