powr-sdk-web 1.0.11 → 1.1.0
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/dist/index.js +14 -0
- package/dist/reviews/index.js +110 -0
- package/dist/uploader/index.js +392 -0
- package/package.json +6 -3
package/dist/index.js
CHANGED
|
@@ -3,11 +3,25 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
+
Object.defineProperty(exports, "PowrBaseReviews", {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: function get() {
|
|
9
|
+
return _reviews["default"];
|
|
10
|
+
}
|
|
11
|
+
});
|
|
6
12
|
Object.defineProperty(exports, "PowrBaseSwiper", {
|
|
7
13
|
enumerable: true,
|
|
8
14
|
get: function get() {
|
|
9
15
|
return _swiper["default"];
|
|
10
16
|
}
|
|
11
17
|
});
|
|
18
|
+
Object.defineProperty(exports, "PowrBaseUploader", {
|
|
19
|
+
enumerable: true,
|
|
20
|
+
get: function get() {
|
|
21
|
+
return _uploader["default"];
|
|
22
|
+
}
|
|
23
|
+
});
|
|
12
24
|
var _swiper = _interopRequireDefault(require("./swiper"));
|
|
25
|
+
var _reviews = _interopRequireDefault(require("./reviews"));
|
|
26
|
+
var _uploader = _interopRequireDefault(require("./uploader"));
|
|
13
27
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
@@ -0,0 +1,110 @@
|
|
|
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 = _interopRequireDefault(require("react"));
|
|
9
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
10
|
+
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 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 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 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; }
|
|
11
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
12
|
+
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."); }
|
|
13
|
+
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); }
|
|
14
|
+
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; }
|
|
15
|
+
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; } }
|
|
16
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
17
|
+
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); } }
|
|
18
|
+
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); }); }; }
|
|
19
|
+
function getReviews(_x) {
|
|
20
|
+
return _getReviews.apply(this, arguments);
|
|
21
|
+
}
|
|
22
|
+
function _getReviews() {
|
|
23
|
+
_getReviews = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(params) {
|
|
24
|
+
var response, data;
|
|
25
|
+
return _regeneratorRuntime().wrap(function _callee2$(_context2) {
|
|
26
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
27
|
+
case 0:
|
|
28
|
+
_context2.prev = 0;
|
|
29
|
+
_context2.next = 3;
|
|
30
|
+
return fetch("https://api.powrbase.cloud/reviews", {
|
|
31
|
+
method: "POST",
|
|
32
|
+
headers: {
|
|
33
|
+
"Content-Type": "application/json"
|
|
34
|
+
},
|
|
35
|
+
body: JSON.stringify(params)
|
|
36
|
+
});
|
|
37
|
+
case 3:
|
|
38
|
+
response = _context2.sent;
|
|
39
|
+
if (response.ok) {
|
|
40
|
+
_context2.next = 6;
|
|
41
|
+
break;
|
|
42
|
+
}
|
|
43
|
+
throw new Error("Failed to fetch reviews");
|
|
44
|
+
case 6:
|
|
45
|
+
_context2.next = 8;
|
|
46
|
+
return response.json();
|
|
47
|
+
case 8:
|
|
48
|
+
data = _context2.sent;
|
|
49
|
+
return _context2.abrupt("return", data.reviews);
|
|
50
|
+
case 12:
|
|
51
|
+
_context2.prev = 12;
|
|
52
|
+
_context2.t0 = _context2["catch"](0);
|
|
53
|
+
console.error("Error fetching reviews:", _context2.t0);
|
|
54
|
+
return _context2.abrupt("return", []);
|
|
55
|
+
case 16:
|
|
56
|
+
case "end":
|
|
57
|
+
return _context2.stop();
|
|
58
|
+
}
|
|
59
|
+
}, _callee2, null, [[0, 12]]);
|
|
60
|
+
}));
|
|
61
|
+
return _getReviews.apply(this, arguments);
|
|
62
|
+
}
|
|
63
|
+
var PowrBaseReviews = function PowrBaseReviews(_ref) {
|
|
64
|
+
var title = _ref.title,
|
|
65
|
+
projectId = _ref.projectId,
|
|
66
|
+
entityId = _ref.entityId,
|
|
67
|
+
style = _ref.style;
|
|
68
|
+
var _useState = useState([]),
|
|
69
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
70
|
+
reviews = _useState2[0],
|
|
71
|
+
setReviews = _useState2[1];
|
|
72
|
+
useEffect(function () {
|
|
73
|
+
var fetchReviews = /*#__PURE__*/function () {
|
|
74
|
+
var _ref2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
|
|
75
|
+
var data;
|
|
76
|
+
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
77
|
+
while (1) switch (_context.prev = _context.next) {
|
|
78
|
+
case 0:
|
|
79
|
+
_context.next = 2;
|
|
80
|
+
return getReviews({
|
|
81
|
+
projectId: projectId,
|
|
82
|
+
entityId: entityId
|
|
83
|
+
});
|
|
84
|
+
case 2:
|
|
85
|
+
data = _context.sent;
|
|
86
|
+
setReviews(data);
|
|
87
|
+
case 4:
|
|
88
|
+
case "end":
|
|
89
|
+
return _context.stop();
|
|
90
|
+
}
|
|
91
|
+
}, _callee);
|
|
92
|
+
}));
|
|
93
|
+
return function fetchReviews() {
|
|
94
|
+
return _ref2.apply(this, arguments);
|
|
95
|
+
};
|
|
96
|
+
}();
|
|
97
|
+
fetchReviews();
|
|
98
|
+
}, []);
|
|
99
|
+
if (reviews.length === 0) {
|
|
100
|
+
return null; // Or a loading state
|
|
101
|
+
}
|
|
102
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
103
|
+
style: style
|
|
104
|
+
}, /*#__PURE__*/_react["default"].createElement("h2", null, title), reviews.map(function (review) {
|
|
105
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
106
|
+
key: review.id
|
|
107
|
+
}, /*#__PURE__*/_react["default"].createElement("h3", null, review.title), /*#__PURE__*/_react["default"].createElement("p", null, review.body));
|
|
108
|
+
}));
|
|
109
|
+
};
|
|
110
|
+
var _default = exports["default"] = PowrBaseReviews;
|
|
@@ -0,0 +1,392 @@
|
|
|
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 _propTypes = _interopRequireDefault(require("prop-types"));
|
|
10
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
11
|
+
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); }
|
|
12
|
+
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 && {}.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; }
|
|
13
|
+
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
|
14
|
+
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
15
|
+
function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
|
16
|
+
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
|
17
|
+
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 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 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 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; }
|
|
18
|
+
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); } }
|
|
19
|
+
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); }); }; }
|
|
20
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
21
|
+
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."); }
|
|
22
|
+
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); }
|
|
23
|
+
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; }
|
|
24
|
+
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; } }
|
|
25
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
26
|
+
var getFileIcon = function getFileIcon(mimeType) {
|
|
27
|
+
if (mimeType.startsWith('image/')) return '🖼️';
|
|
28
|
+
if (mimeType.startsWith('video/')) return '🎥';
|
|
29
|
+
if (mimeType.startsWith('audio/')) return '🎵';
|
|
30
|
+
if (mimeType.includes('pdf')) return '📄';
|
|
31
|
+
if (mimeType.includes('word') || mimeType.includes('document')) return '📝';
|
|
32
|
+
if (mimeType.includes('excel') || mimeType.includes('spreadsheet')) return '📊';
|
|
33
|
+
if (mimeType.includes('presentation') || mimeType.includes('powerpoint')) return '📑';
|
|
34
|
+
if (mimeType.includes('zip') || mimeType.includes('compressed')) return '📦';
|
|
35
|
+
if (mimeType.includes('text')) return '📃';
|
|
36
|
+
return '📎';
|
|
37
|
+
};
|
|
38
|
+
var PowrBaseUploader = function PowrBaseUploader(_ref) {
|
|
39
|
+
var projectId = _ref.projectId,
|
|
40
|
+
onUploadComplete = _ref.onUploadComplete,
|
|
41
|
+
onUploadError = _ref.onUploadError,
|
|
42
|
+
_ref$className = _ref.className,
|
|
43
|
+
className = _ref$className === void 0 ? '' : _ref$className,
|
|
44
|
+
_ref$style = _ref.style,
|
|
45
|
+
style = _ref$style === void 0 ? {} : _ref$style,
|
|
46
|
+
_ref$maxFiles = _ref.maxFiles,
|
|
47
|
+
maxFiles = _ref$maxFiles === void 0 ? 10 : _ref$maxFiles,
|
|
48
|
+
_ref$acceptedFileType = _ref.acceptedFileTypes,
|
|
49
|
+
acceptedFileTypes = _ref$acceptedFileType === void 0 ? '*' : _ref$acceptedFileType,
|
|
50
|
+
_ref$showPreview = _ref.showPreview,
|
|
51
|
+
showPreview = _ref$showPreview === void 0 ? true : _ref$showPreview,
|
|
52
|
+
_ref$showProgress = _ref.showProgress,
|
|
53
|
+
showProgress = _ref$showProgress === void 0 ? true : _ref$showProgress;
|
|
54
|
+
var _useState = (0, _react.useState)([]),
|
|
55
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
56
|
+
files = _useState2[0],
|
|
57
|
+
setFiles = _useState2[1];
|
|
58
|
+
var _useState3 = (0, _react.useState)(false),
|
|
59
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
60
|
+
isUploading = _useState4[0],
|
|
61
|
+
setIsUploading = _useState4[1];
|
|
62
|
+
var _useState5 = (0, _react.useState)(0),
|
|
63
|
+
_useState6 = _slicedToArray(_useState5, 2),
|
|
64
|
+
uploadProgress = _useState6[0],
|
|
65
|
+
setUploadProgress = _useState6[1];
|
|
66
|
+
var fileInputRef = (0, _react.useRef)(null);
|
|
67
|
+
var uploadFile = /*#__PURE__*/function () {
|
|
68
|
+
var _ref2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(file) {
|
|
69
|
+
var formData, response;
|
|
70
|
+
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
71
|
+
while (1) switch (_context.prev = _context.next) {
|
|
72
|
+
case 0:
|
|
73
|
+
formData = new FormData();
|
|
74
|
+
formData.append('file', file);
|
|
75
|
+
_context.prev = 2;
|
|
76
|
+
_context.next = 5;
|
|
77
|
+
return fetch("https://api.powrbase.cloud/files?projectId=".concat(projectId), {
|
|
78
|
+
method: 'POST',
|
|
79
|
+
body: formData
|
|
80
|
+
});
|
|
81
|
+
case 5:
|
|
82
|
+
response = _context.sent;
|
|
83
|
+
if (response.ok) {
|
|
84
|
+
_context.next = 8;
|
|
85
|
+
break;
|
|
86
|
+
}
|
|
87
|
+
throw new Error('Upload failed');
|
|
88
|
+
case 8:
|
|
89
|
+
_context.next = 10;
|
|
90
|
+
return response.json();
|
|
91
|
+
case 10:
|
|
92
|
+
return _context.abrupt("return", _context.sent);
|
|
93
|
+
case 13:
|
|
94
|
+
_context.prev = 13;
|
|
95
|
+
_context.t0 = _context["catch"](2);
|
|
96
|
+
console.error('Error uploading file:', _context.t0);
|
|
97
|
+
throw _context.t0;
|
|
98
|
+
case 17:
|
|
99
|
+
case "end":
|
|
100
|
+
return _context.stop();
|
|
101
|
+
}
|
|
102
|
+
}, _callee, null, [[2, 13]]);
|
|
103
|
+
}));
|
|
104
|
+
return function uploadFile(_x) {
|
|
105
|
+
return _ref2.apply(this, arguments);
|
|
106
|
+
};
|
|
107
|
+
}();
|
|
108
|
+
var handleFileUpload = /*#__PURE__*/function () {
|
|
109
|
+
var _ref3 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(filesList) {
|
|
110
|
+
var uploadedFiles, totalFiles, completedFiles, placeholderFiles, _loop, i, updatedFiles;
|
|
111
|
+
return _regeneratorRuntime().wrap(function _callee2$(_context3) {
|
|
112
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
113
|
+
case 0:
|
|
114
|
+
if (!(!filesList || isUploading)) {
|
|
115
|
+
_context3.next = 2;
|
|
116
|
+
break;
|
|
117
|
+
}
|
|
118
|
+
return _context3.abrupt("return");
|
|
119
|
+
case 2:
|
|
120
|
+
setIsUploading(true);
|
|
121
|
+
setUploadProgress(0);
|
|
122
|
+
_context3.prev = 4;
|
|
123
|
+
uploadedFiles = [];
|
|
124
|
+
totalFiles = filesList.length;
|
|
125
|
+
completedFiles = 0; // Add placeholder files first
|
|
126
|
+
placeholderFiles = Array.from(filesList).map(function (file) {
|
|
127
|
+
return {
|
|
128
|
+
url: URL.createObjectURL(file),
|
|
129
|
+
name: file.name,
|
|
130
|
+
type: file.type,
|
|
131
|
+
size: file.size,
|
|
132
|
+
isUploading: true
|
|
133
|
+
};
|
|
134
|
+
});
|
|
135
|
+
setFiles(function (prev) {
|
|
136
|
+
return [].concat(_toConsumableArray(prev), _toConsumableArray(placeholderFiles));
|
|
137
|
+
});
|
|
138
|
+
_loop = /*#__PURE__*/_regeneratorRuntime().mark(function _loop(i) {
|
|
139
|
+
var file, data, uploadedFile;
|
|
140
|
+
return _regeneratorRuntime().wrap(function _loop$(_context2) {
|
|
141
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
142
|
+
case 0:
|
|
143
|
+
file = filesList[i];
|
|
144
|
+
_context2.next = 3;
|
|
145
|
+
return uploadFile(file);
|
|
146
|
+
case 3:
|
|
147
|
+
data = _context2.sent;
|
|
148
|
+
uploadedFile = {
|
|
149
|
+
url: data.url,
|
|
150
|
+
name: data.originalname || file.name,
|
|
151
|
+
type: data.mimetype || file.type,
|
|
152
|
+
size: data.size || file.size,
|
|
153
|
+
isUploading: false
|
|
154
|
+
}; // Replace the placeholder with the actual file
|
|
155
|
+
setFiles(function (prev) {
|
|
156
|
+
return prev.map(function (f, index) {
|
|
157
|
+
return index === prev.length - filesList.length + i ? uploadedFile : f;
|
|
158
|
+
});
|
|
159
|
+
});
|
|
160
|
+
uploadedFiles.push(uploadedFile);
|
|
161
|
+
completedFiles++;
|
|
162
|
+
setUploadProgress(completedFiles / totalFiles * 100);
|
|
163
|
+
case 9:
|
|
164
|
+
case "end":
|
|
165
|
+
return _context2.stop();
|
|
166
|
+
}
|
|
167
|
+
}, _loop);
|
|
168
|
+
});
|
|
169
|
+
i = 0;
|
|
170
|
+
case 12:
|
|
171
|
+
if (!(i < filesList.length)) {
|
|
172
|
+
_context3.next = 17;
|
|
173
|
+
break;
|
|
174
|
+
}
|
|
175
|
+
return _context3.delegateYield(_loop(i), "t0", 14);
|
|
176
|
+
case 14:
|
|
177
|
+
i++;
|
|
178
|
+
_context3.next = 12;
|
|
179
|
+
break;
|
|
180
|
+
case 17:
|
|
181
|
+
updatedFiles = [].concat(_toConsumableArray(files.filter(function (f) {
|
|
182
|
+
return !f.isUploading;
|
|
183
|
+
})), uploadedFiles);
|
|
184
|
+
setFiles(updatedFiles);
|
|
185
|
+
onUploadComplete === null || onUploadComplete === void 0 || onUploadComplete(updatedFiles);
|
|
186
|
+
_context3.next = 27;
|
|
187
|
+
break;
|
|
188
|
+
case 22:
|
|
189
|
+
_context3.prev = 22;
|
|
190
|
+
_context3.t1 = _context3["catch"](4);
|
|
191
|
+
console.error('Error uploading files:', _context3.t1);
|
|
192
|
+
onUploadError === null || onUploadError === void 0 || onUploadError(_context3.t1);
|
|
193
|
+
|
|
194
|
+
// Remove failed uploads
|
|
195
|
+
setFiles(function (prev) {
|
|
196
|
+
return prev.filter(function (f) {
|
|
197
|
+
return !f.isUploading;
|
|
198
|
+
});
|
|
199
|
+
});
|
|
200
|
+
case 27:
|
|
201
|
+
_context3.prev = 27;
|
|
202
|
+
setIsUploading(false);
|
|
203
|
+
setTimeout(function () {
|
|
204
|
+
return setUploadProgress(0);
|
|
205
|
+
}, 1000);
|
|
206
|
+
return _context3.finish(27);
|
|
207
|
+
case 31:
|
|
208
|
+
case "end":
|
|
209
|
+
return _context3.stop();
|
|
210
|
+
}
|
|
211
|
+
}, _callee2, null, [[4, 22, 27, 31]]);
|
|
212
|
+
}));
|
|
213
|
+
return function handleFileUpload(_x2) {
|
|
214
|
+
return _ref3.apply(this, arguments);
|
|
215
|
+
};
|
|
216
|
+
}();
|
|
217
|
+
var handleDrop = function handleDrop(e) {
|
|
218
|
+
e.preventDefault();
|
|
219
|
+
e.stopPropagation();
|
|
220
|
+
handleFileUpload(e.dataTransfer.files);
|
|
221
|
+
};
|
|
222
|
+
var handleDragOver = function handleDragOver(e) {
|
|
223
|
+
e.preventDefault();
|
|
224
|
+
e.stopPropagation();
|
|
225
|
+
};
|
|
226
|
+
var handleRemoveFile = function handleRemoveFile(fileIndex) {
|
|
227
|
+
setFiles(function (prev) {
|
|
228
|
+
return prev.filter(function (_, index) {
|
|
229
|
+
return index !== fileIndex;
|
|
230
|
+
});
|
|
231
|
+
});
|
|
232
|
+
};
|
|
233
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
234
|
+
className: className,
|
|
235
|
+
style: style
|
|
236
|
+
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
237
|
+
className: "border-2 border-dashed rounded-lg ".concat(files.length ? 'p-4' : 'p-6', " hover:border-primary transition-colors"),
|
|
238
|
+
onDrop: handleDrop,
|
|
239
|
+
onDragOver: handleDragOver
|
|
240
|
+
}, files.length > 0 ? /*#__PURE__*/_react["default"].createElement("div", {
|
|
241
|
+
className: "space-y-4"
|
|
242
|
+
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
243
|
+
className: "text-xs text-muted-foreground text-center pb-4 border-b border-border/50"
|
|
244
|
+
}, "Drag and drop files anywhere in this area, or click the plus button to add files"), /*#__PURE__*/_react["default"].createElement("div", {
|
|
245
|
+
className: "grid grid-cols-4 sm:grid-cols-6 md:grid-cols-8 gap-2"
|
|
246
|
+
}, files.map(function (file, index) {
|
|
247
|
+
var isImage = file.type.startsWith('image/');
|
|
248
|
+
var fileIcon = getFileIcon(file.type);
|
|
249
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
250
|
+
key: index,
|
|
251
|
+
className: "group relative aspect-square bg-muted/50 rounded-md overflow-hidden border border-border hover:border-primary transition-colors"
|
|
252
|
+
}, isImage && showPreview ? /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("img", {
|
|
253
|
+
src: file.url,
|
|
254
|
+
alt: file.name,
|
|
255
|
+
className: "w-full h-full object-cover ".concat(file.isUploading ? 'opacity-50' : '')
|
|
256
|
+
}), file.isUploading && /*#__PURE__*/_react["default"].createElement("div", {
|
|
257
|
+
className: "absolute inset-0 flex items-center justify-center bg-background/20"
|
|
258
|
+
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
259
|
+
className: "animate-spin rounded-full h-8 w-8 border-2 border-primary border-t-transparent"
|
|
260
|
+
}))) : /*#__PURE__*/_react["default"].createElement("div", {
|
|
261
|
+
className: "w-full h-full flex flex-col items-center justify-center p-2"
|
|
262
|
+
}, file.isUploading ? /*#__PURE__*/_react["default"].createElement("div", {
|
|
263
|
+
className: "animate-spin rounded-full h-8 w-8 border-2 border-primary border-t-transparent"
|
|
264
|
+
}) : /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("div", {
|
|
265
|
+
className: "text-2xl text-muted-foreground mb-1"
|
|
266
|
+
}, fileIcon), /*#__PURE__*/_react["default"].createElement("div", {
|
|
267
|
+
className: "text-[10px] text-muted-foreground text-center truncate w-full"
|
|
268
|
+
}, file.name))), !file.isUploading && /*#__PURE__*/_react["default"].createElement("div", {
|
|
269
|
+
className: "absolute inset-0 bg-black/60 opacity-0 group-hover:opacity-100 transition-opacity flex items-center justify-center gap-2"
|
|
270
|
+
}, /*#__PURE__*/_react["default"].createElement("a", {
|
|
271
|
+
href: file.url,
|
|
272
|
+
target: "_blank",
|
|
273
|
+
rel: "noopener noreferrer",
|
|
274
|
+
className: "text-white hover:text-primary-foreground p-1.5 rounded-full hover:bg-primary/20 transition-colors",
|
|
275
|
+
onClick: function onClick(e) {
|
|
276
|
+
return e.stopPropagation();
|
|
277
|
+
}
|
|
278
|
+
}, /*#__PURE__*/_react["default"].createElement("svg", {
|
|
279
|
+
className: "w-4 h-4",
|
|
280
|
+
fill: "none",
|
|
281
|
+
stroke: "currentColor",
|
|
282
|
+
viewBox: "0 0 24 24"
|
|
283
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
284
|
+
strokeLinecap: "round",
|
|
285
|
+
strokeLinejoin: "round",
|
|
286
|
+
strokeWidth: 2,
|
|
287
|
+
d: "M15 12a3 3 0 11-6 0 3 3 0 016 0z"
|
|
288
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
289
|
+
strokeLinecap: "round",
|
|
290
|
+
strokeLinejoin: "round",
|
|
291
|
+
strokeWidth: 2,
|
|
292
|
+
d: "M2.458 12C3.732 7.943 7.523 5 12 5c4.478 0 8.268 2.943 9.542 7-1.274 4.057-5.064 7-9.542 7-4.477 0-8.268-2.943-9.542-7z"
|
|
293
|
+
}))), /*#__PURE__*/_react["default"].createElement("button", {
|
|
294
|
+
className: "text-white hover:text-destructive p-1.5 rounded-full hover:bg-destructive/20 transition-colors",
|
|
295
|
+
onClick: function onClick(e) {
|
|
296
|
+
e.stopPropagation();
|
|
297
|
+
handleRemoveFile(index);
|
|
298
|
+
}
|
|
299
|
+
}, /*#__PURE__*/_react["default"].createElement("svg", {
|
|
300
|
+
className: "w-4 h-4",
|
|
301
|
+
fill: "none",
|
|
302
|
+
stroke: "currentColor",
|
|
303
|
+
viewBox: "0 0 24 24"
|
|
304
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
305
|
+
strokeLinecap: "round",
|
|
306
|
+
strokeLinejoin: "round",
|
|
307
|
+
strokeWidth: 2,
|
|
308
|
+
d: "M19 7l-.867 12.142A2 2 0 0116.138 21H7.862a2 2 0 01-1.995-1.858L5 7m5 4v6m4-6v6m1-10V4a1 1 0 00-1-1h-4a1 1 0 00-1 1v3M4 7h16"
|
|
309
|
+
})))));
|
|
310
|
+
}), files.length < maxFiles && /*#__PURE__*/_react["default"].createElement("div", {
|
|
311
|
+
className: "aspect-square bg-muted/30 rounded-md border-2 border-dashed border-border hover:border-primary transition-colors cursor-pointer flex flex-col items-center justify-center p-2",
|
|
312
|
+
onClick: function onClick() {
|
|
313
|
+
var _fileInputRef$current;
|
|
314
|
+
return (_fileInputRef$current = fileInputRef.current) === null || _fileInputRef$current === void 0 ? void 0 : _fileInputRef$current.click();
|
|
315
|
+
}
|
|
316
|
+
}, /*#__PURE__*/_react["default"].createElement("input", {
|
|
317
|
+
type: "file",
|
|
318
|
+
ref: fileInputRef,
|
|
319
|
+
className: "hidden",
|
|
320
|
+
multiple: true,
|
|
321
|
+
accept: acceptedFileTypes,
|
|
322
|
+
onChange: function onChange(e) {
|
|
323
|
+
return handleFileUpload(e.target.files);
|
|
324
|
+
}
|
|
325
|
+
}), /*#__PURE__*/_react["default"].createElement("svg", {
|
|
326
|
+
className: "w-6 h-6 text-muted-foreground mb-1",
|
|
327
|
+
fill: "none",
|
|
328
|
+
stroke: "currentColor",
|
|
329
|
+
viewBox: "0 0 24 24"
|
|
330
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
331
|
+
strokeLinecap: "round",
|
|
332
|
+
strokeLinejoin: "round",
|
|
333
|
+
strokeWidth: 2,
|
|
334
|
+
d: "M12 4v16m8-8H4"
|
|
335
|
+
})), /*#__PURE__*/_react["default"].createElement("div", {
|
|
336
|
+
className: "text-[10px] text-muted-foreground text-center"
|
|
337
|
+
}, "Add Files")))) : /*#__PURE__*/_react["default"].createElement("div", {
|
|
338
|
+
className: "text-center cursor-pointer",
|
|
339
|
+
onClick: function onClick() {
|
|
340
|
+
var _fileInputRef$current2;
|
|
341
|
+
return (_fileInputRef$current2 = fileInputRef.current) === null || _fileInputRef$current2 === void 0 ? void 0 : _fileInputRef$current2.click();
|
|
342
|
+
}
|
|
343
|
+
}, /*#__PURE__*/_react["default"].createElement("input", {
|
|
344
|
+
type: "file",
|
|
345
|
+
ref: fileInputRef,
|
|
346
|
+
className: "hidden",
|
|
347
|
+
multiple: true,
|
|
348
|
+
accept: acceptedFileTypes,
|
|
349
|
+
onChange: function onChange(e) {
|
|
350
|
+
return handleFileUpload(e.target.files);
|
|
351
|
+
}
|
|
352
|
+
}), /*#__PURE__*/_react["default"].createElement("div", {
|
|
353
|
+
className: "space-y-2"
|
|
354
|
+
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
355
|
+
className: "flex items-center justify-center"
|
|
356
|
+
}, /*#__PURE__*/_react["default"].createElement("svg", {
|
|
357
|
+
className: "w-8 h-8 text-muted-foreground",
|
|
358
|
+
fill: "none",
|
|
359
|
+
stroke: "currentColor",
|
|
360
|
+
viewBox: "0 0 24 24"
|
|
361
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
362
|
+
strokeLinecap: "round",
|
|
363
|
+
strokeLinejoin: "round",
|
|
364
|
+
strokeWidth: 2,
|
|
365
|
+
d: "M7 16a4 4 0 01-.88-7.903A5 5 0 1115.9 6L16 6a5 5 0 011 9.9M15 13l-3-3m0 0l-3 3m3-3v12"
|
|
366
|
+
}))), /*#__PURE__*/_react["default"].createElement("div", {
|
|
367
|
+
className: "text-sm text-muted-foreground"
|
|
368
|
+
}, "Drag and drop files here, or click to select files")))), showProgress && isUploading && /*#__PURE__*/_react["default"].createElement("div", {
|
|
369
|
+
className: "space-y-2 mt-4"
|
|
370
|
+
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
371
|
+
className: "flex items-center justify-end text-xs text-muted-foreground"
|
|
372
|
+
}, /*#__PURE__*/_react["default"].createElement("span", null, Math.round(uploadProgress), "%")), /*#__PURE__*/_react["default"].createElement("div", {
|
|
373
|
+
className: "w-full bg-muted rounded-full h-1.5"
|
|
374
|
+
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
375
|
+
className: "bg-primary h-1.5 rounded-full transition-all duration-300",
|
|
376
|
+
style: {
|
|
377
|
+
width: "".concat(uploadProgress, "%")
|
|
378
|
+
}
|
|
379
|
+
}))));
|
|
380
|
+
};
|
|
381
|
+
PowrBaseUploader.propTypes = {
|
|
382
|
+
projectId: _propTypes["default"].string.isRequired,
|
|
383
|
+
onUploadComplete: _propTypes["default"].func,
|
|
384
|
+
onUploadError: _propTypes["default"].func,
|
|
385
|
+
className: _propTypes["default"].string,
|
|
386
|
+
style: _propTypes["default"].object,
|
|
387
|
+
maxFiles: _propTypes["default"].number,
|
|
388
|
+
acceptedFileTypes: _propTypes["default"].string,
|
|
389
|
+
showPreview: _propTypes["default"].bool,
|
|
390
|
+
showProgress: _propTypes["default"].bool
|
|
391
|
+
};
|
|
392
|
+
var _default = exports["default"] = PowrBaseUploader;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "powr-sdk-web",
|
|
3
|
-
"version": "1.0
|
|
3
|
+
"version": "1.1.0",
|
|
4
4
|
"main": "dist/index.js",
|
|
5
5
|
"scripts": {
|
|
6
6
|
"build": "babel src -d dist --copy-files",
|
|
@@ -9,7 +9,9 @@
|
|
|
9
9
|
"keywords": [
|
|
10
10
|
"react",
|
|
11
11
|
"component",
|
|
12
|
-
"npm"
|
|
12
|
+
"npm",
|
|
13
|
+
"file-upload",
|
|
14
|
+
"powrbase"
|
|
13
15
|
],
|
|
14
16
|
"author": "Lawazia Tech",
|
|
15
17
|
"license": "MIT",
|
|
@@ -25,7 +27,8 @@
|
|
|
25
27
|
"@babel/cli": "^7.24.1",
|
|
26
28
|
"@babel/core": "^7.24.4",
|
|
27
29
|
"@babel/preset-env": "^7.24.4",
|
|
28
|
-
"@babel/preset-react": "^7.24.1"
|
|
30
|
+
"@babel/preset-react": "^7.24.1",
|
|
31
|
+
"prop-types": "^15.8.1"
|
|
29
32
|
},
|
|
30
33
|
"dependencies": {
|
|
31
34
|
"swiper": "^11.2.2"
|