@ozdao/prometheus-framework 0.1.6 → 0.1.8
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/Breadcrumbs.vue_vue_type_style_index_0_lang-561d6db3.js +1 -0
- package/dist/Breadcrumbs.vue_vue_type_style_index_0_lang-9e474158.mjs +1945 -0
- package/dist/ButtonFollow-38d9a720.mjs +131 -0
- package/dist/ButtonFollow-9a33ab06.js +1 -0
- package/dist/CardOrganization-3049931d.mjs +230 -0
- package/dist/CardOrganization-8b376cbb.js +1 -0
- package/dist/Chips-03ff0c34.mjs +108 -0
- package/dist/Chips-4d8ac62e.js +1 -0
- package/dist/Feed-1d0d9853.js +1 -0
- package/dist/Feed-79839e67.mjs +368 -0
- package/dist/Feed-af94027c.js +1 -0
- package/dist/Feed-b616f102.mjs +439 -0
- package/dist/Image-75f5becb.js +9 -0
- package/dist/Image-be69af9c.mjs +477 -0
- package/dist/Popup-d7dbc670.mjs +76 -0
- package/dist/Popup-ee4bd834.js +1 -0
- package/dist/Product-8bee8d1c.mjs +838 -0
- package/dist/Product-a39f3ca3.js +7 -0
- package/dist/ProductEdit-052b0aef.mjs +350 -0
- package/dist/ProductEdit-a322f1ba.js +1 -0
- package/dist/ProfileBlogposts-08f784c3.mjs +64 -0
- package/dist/ProfileBlogposts-d6bba033.js +1 -0
- package/dist/ProfileComments-96f6cde8.mjs +44 -0
- package/dist/ProfileComments-dd923865.js +1 -0
- package/dist/ProfileEvents-1e0c1291.js +1 -0
- package/dist/ProfileEvents-26a72fe2.mjs +56 -0
- package/dist/ProfileLikes-b1060d1e.js +1 -0
- package/dist/ProfileLikes-c8dab14d.mjs +44 -0
- package/dist/ProfileOrganizations-3a879480.mjs +212 -0
- package/dist/ProfileOrganizations-78fef72e.js +1 -0
- package/dist/Publics-8bb9a680.js +1 -0
- package/dist/Publics-ffc08ad7.mjs +123 -0
- package/dist/UploadImage-6344f789.js +1 -0
- package/dist/UploadImage-f04e4bc0.mjs +83 -0
- package/dist/auth-60c81f40.mjs +1836 -0
- package/dist/auth-e8f6d979.js +8 -0
- package/dist/auth.client.cjs +4 -4
- package/dist/auth.client.js +247 -236
- package/dist/auth.server.js +72 -11
- package/dist/auth.server.mjs +72 -11
- package/dist/auth.validation-1d5f2990.mjs +20 -0
- package/dist/auth.validation-2dfb450f.js +1 -0
- package/dist/community.client.cjs +1 -1
- package/dist/community.client.js +11 -11
- package/dist/events.client.cjs +1 -1
- package/dist/events.client.js +9 -9
- package/dist/organizations-4157d81d.js +1 -0
- package/dist/organizations-52438d24.mjs +121 -0
- package/dist/organizations.client-16ee6b43.js +3 -0
- package/dist/organizations.client-cdbaf6aa.mjs +3017 -0
- package/dist/organizations.client.cjs +1 -1
- package/dist/organizations.client.js +11 -11
- package/dist/users.client.cjs +1 -1
- package/dist/users.client.js +258 -239
- package/dist/users.server.js +7 -0
- package/dist/users.server.mjs +7 -0
- package/package.json +1 -1
- package/src/components/CardHeader/CardHeader.vue +2 -1
- package/src/modules/auth/components/pages/SignIn.vue +48 -44
- package/src/modules/auth/controllers/auth.controller.js +42 -11
- package/src/modules/auth/store/auth.js +3 -10
- package/src/modules/auth/utils/server/verifyAppleIdToken.js +57 -0
- package/src/modules/users/components/pages/Profile.vue +20 -6
- package/src/modules/users/components/pages/ProfileEdit.vue +15 -5
- package/src/modules/users/models/user.model.js +9 -1
- package/src/modules/users/store/users.js +2 -1
@@ -0,0 +1,368 @@
|
|
1
|
+
import { ref as v, computed as m, openBlock as r, createElementBlock as i, normalizeClass as p, createVNode as T, unref as C, createElementVNode as f, createCommentVNode as l, createBlock as w, withModifiers as L, toDisplayString as g, renderSlot as O, createStaticVNode as R, reactive as N, watch as _, onMounted as j, TransitionGroup as z, withCtx as D, Fragment as I, renderList as F, Transition as V } from "vue";
|
2
|
+
import { _ as B } from "./EmptyState-34d85f10.mjs";
|
3
|
+
import { _ as H, a as Y } from "./Chips-03ff0c34.mjs";
|
4
|
+
import { I as q } from "./IconEdit-eacf3856.mjs";
|
5
|
+
import { a as A } from "./auth-60c81f40.mjs";
|
6
|
+
import { useRouter as G } from "vue-router";
|
7
|
+
import { _ as J } from "./_plugin-vue_export-helper-dad06003.mjs";
|
8
|
+
import { s as S } from "./globals-96ba60e4.mjs";
|
9
|
+
const K = {
|
10
|
+
key: 0,
|
11
|
+
class: "o-hidden pos-relative bg-grey mn-small w-100"
|
12
|
+
}, Q = ["src"], W = ["src"], X = { class: "w-max mn-r-thin pd-thin radius-small t-semi bg-main" }, Z = {
|
13
|
+
key: 0,
|
14
|
+
class: "t-semi"
|
15
|
+
}, ee = { class: "t-semi" }, te = {
|
16
|
+
key: 0,
|
17
|
+
class: "t-semi uppercase"
|
18
|
+
}, ae = {
|
19
|
+
key: 1,
|
20
|
+
class: "cursor-pointer mn-thin flex-nowrap flex w-100"
|
21
|
+
}, re = {
|
22
|
+
key: 0,
|
23
|
+
class: ""
|
24
|
+
}, ne = {
|
25
|
+
key: 1,
|
26
|
+
class: "pd-micro t-white uppercase t-semi p-small flex-center flex pd-r-small pd-l-small mn-l-thin w-min bg-second radius-extra"
|
27
|
+
}, se = {
|
28
|
+
key: 2,
|
29
|
+
class: "mn-small p-big"
|
30
|
+
}, le = {
|
31
|
+
__name: "CardEvent",
|
32
|
+
props: ["event", "user", "short", "type"],
|
33
|
+
setup(e) {
|
34
|
+
const t = e;
|
35
|
+
v(/* @__PURE__ */ new Date()), G(), m(() => t.event.content.find((a) => a.type.name === "ImageUpload")), m(() => t.event.content.find((a) => a.type.name === "Textarea"));
|
36
|
+
const s = m(() => {
|
37
|
+
const a = /* @__PURE__ */ new Date(), u = Date.UTC(a.getUTCFullYear(), a.getUTCMonth(), a.getUTCDate(), a.getUTCHours(), a.getUTCMinutes(), a.getUTCSeconds()), n = new Date(t.event.date.start), o = Date.UTC(n.getUTCFullYear(), n.getUTCMonth(), n.getUTCDate(), n.getUTCHours(), n.getUTCMinutes(), n.getUTCSeconds()) - u;
|
38
|
+
if (o < 0)
|
39
|
+
return "Finished";
|
40
|
+
if (o === 0)
|
41
|
+
return "Starting Now";
|
42
|
+
{
|
43
|
+
const k = Math.floor(o / 1e3), x = Math.floor(k / 60), $ = Math.floor(x / 60), M = Math.floor($ / 24);
|
44
|
+
return M > 0 ? `${M} days until event` : $ > 0 ? `${$} hours until event` : x > 0 ? `${x} minutes until event` : `${k} seconds until event`;
|
45
|
+
}
|
46
|
+
}), c = m(() => {
|
47
|
+
const a = new Date(t.event.date.start), u = { day: "2-digit", month: "2-digit" };
|
48
|
+
return a.toLocaleDateString(void 0, u);
|
49
|
+
}), d = m(() => {
|
50
|
+
console.log(t.event.date.start), console.log(t.event.date.end);
|
51
|
+
const a = new Date(t.event.date.start), u = new Date(t.event.date.end), n = new Intl.DateTimeFormat(void 0, { hour: "2-digit", minute: "2-digit", hourCycle: "h23" }).format(a), E = new Intl.DateTimeFormat(void 0, { hour: "2-digit", minute: "2-digit", hourCycle: "h23" }).format(u);
|
52
|
+
return `${n}-${E}`;
|
53
|
+
}), y = m(() => {
|
54
|
+
const a = t.event.name;
|
55
|
+
return a.length > 26 ? `${a.substring(0, 22)}…` : a;
|
56
|
+
});
|
57
|
+
return (a, u) => (r(), i("article", {
|
58
|
+
class: p([{
|
59
|
+
"flex-nowrap flex-v-center flex": e.type === "short"
|
60
|
+
}, "pos-relative"])
|
61
|
+
}, [
|
62
|
+
T(H, {
|
63
|
+
class: p({
|
64
|
+
"mn-small pd-medium": e.type !== "short",
|
65
|
+
"flex-child-order-last flex-child mn-l-small": e.type === "short"
|
66
|
+
}),
|
67
|
+
owner: e.event.owner,
|
68
|
+
creator: e.event.creator,
|
69
|
+
members: e.event.numberOfTickets,
|
70
|
+
membersPhotos: e.event.participantsPhotos,
|
71
|
+
type: e.type,
|
72
|
+
dateFormatted: C(s)
|
73
|
+
}, null, 8, ["class", "owner", "creator", "members", "membersPhotos", "type", "dateFormatted"]),
|
74
|
+
e.event.cover && e.type !== "short" ? (r(), i("div", K, [
|
75
|
+
f("img", {
|
76
|
+
src: (a.FILE_SERVER_URL || "") + e.event.cover,
|
77
|
+
alt: "Event image",
|
78
|
+
class: "pos-relative z-index-1 d-block mn-auto h-20r"
|
79
|
+
}, null, 8, Q),
|
80
|
+
f("img", {
|
81
|
+
src: (a.FILE_SERVER_URL || "") + e.event.cover,
|
82
|
+
alt: "Event Background",
|
83
|
+
class: "z-index-0 pos-absolute w-100 h-100 pos-t-0 pos-r-0",
|
84
|
+
style: { transform: "scale(1.5)", filter: "blur(2rem)", "-webkit-filter": "blur(2rem)" }
|
85
|
+
}, null, 8, W)
|
86
|
+
])) : l("", !0),
|
87
|
+
f("section", {
|
88
|
+
class: p(["pos-relative w-100", { "pd-t-zero pd-medium": e.type !== "short" }])
|
89
|
+
}, [
|
90
|
+
e.user === e.event.creator.target._id ? (r(), w(q, {
|
91
|
+
key: 0,
|
92
|
+
onClick: u[0] || (u[0] = L((n) => a.$router.push({
|
93
|
+
name: "Edit Event",
|
94
|
+
params: {
|
95
|
+
url: e.event.url
|
96
|
+
}
|
97
|
+
}), ["stop"])),
|
98
|
+
class: "z-index-2 pos-absolute pos-t-regular pos-r-regular i-regular t-transp"
|
99
|
+
})) : l("", !0),
|
100
|
+
f("div", {
|
101
|
+
class: p([{ "mn-small": e.type !== "short" }, "flex-v-center flex-nowrap flex"])
|
102
|
+
}, [
|
103
|
+
f("div", X, [
|
104
|
+
e.type !== "short" ? (r(), i("span", Z, g(C(c)) + " | ", 1)) : l("", !0),
|
105
|
+
f("span", ee, g(C(d)), 1)
|
106
|
+
]),
|
107
|
+
e.type === "short" ? (r(), i("span", te, g(C(y)), 1)) : l("", !0)
|
108
|
+
], 2),
|
109
|
+
e.type !== "short" ? (r(), i("div", ae, [
|
110
|
+
e.type !== "short" ? (r(), i("h3", re, g(e.event.name), 1)) : l("", !0),
|
111
|
+
e.event.status === "draft" ? (r(), i("div", ne, g(e.event.status), 1)) : l("", !0)
|
112
|
+
])) : l("", !0),
|
113
|
+
e.type !== "short" ? (r(), i("p", se, g(e.event.description), 1)) : l("", !0),
|
114
|
+
O(a.$slots, "default"),
|
115
|
+
e.type !== "short" && e.event.tags.length > 0 ? (r(), w(Y, {
|
116
|
+
key: 3,
|
117
|
+
chips: e.event.tags
|
118
|
+
}, null, 8, ["chips"])) : l("", !0)
|
119
|
+
], 2)
|
120
|
+
], 2));
|
121
|
+
}
|
122
|
+
}, ie = {}, ce = {
|
123
|
+
width: "100%",
|
124
|
+
height: "20rem",
|
125
|
+
xmlns: "http://www.w3.org/2000/svg"
|
126
|
+
}, ue = /* @__PURE__ */ R('<rect x="0" y="0" rx="5" ry="5" width="100%" height="100%" fill="rgb(var(--grey))"></rect><rect x="15" y="15" rx="4" ry="4" width="40%" height="20" fill="rgba(var(--black),0.05)"></rect><rect x="15" y="45" rx="5" ry="5" width="70%" height="50" fill="rgba(var(--black),0.05)"></rect><rect x="15" y="110" rx="3" ry="3" width="90%" height="6" fill="rgba(var(--black),0.05)"></rect><rect x="15" y="130" rx="3" ry="3" width="70%" height="6" fill="rgba(var(--black),0.05)"></rect><rect x="-25%" y="0" width="25%" height="100%" fill="#fff" mask="url(#myMask)" opacity="0.3"><animate attributeName="x" from="-25%" to="100%" dur="2s" repeatCount="indefinite"></animate></rect>', 6), oe = [
|
127
|
+
ue
|
128
|
+
];
|
129
|
+
function de(e, t) {
|
130
|
+
return r(), i("svg", ce, oe);
|
131
|
+
}
|
132
|
+
const me = /* @__PURE__ */ J(ie, [["render", de]]), U = A.create({ baseURL: process.env.API_URL, withCredentials: !0 }), h = N({
|
133
|
+
all: [],
|
134
|
+
filter: {
|
135
|
+
// query
|
136
|
+
tags: [],
|
137
|
+
period: "",
|
138
|
+
date: null
|
139
|
+
// pagination
|
140
|
+
},
|
141
|
+
pagination: {
|
142
|
+
page: 1,
|
143
|
+
perPage: 18
|
144
|
+
},
|
145
|
+
// Sort
|
146
|
+
sort: {
|
147
|
+
current: "popularity",
|
148
|
+
ascending: !1
|
149
|
+
},
|
150
|
+
current: {
|
151
|
+
_id: "",
|
152
|
+
cover: "",
|
153
|
+
url: "",
|
154
|
+
status: "",
|
155
|
+
name: "",
|
156
|
+
tags: [],
|
157
|
+
date: {
|
158
|
+
start: null,
|
159
|
+
false: null
|
160
|
+
},
|
161
|
+
views: 0,
|
162
|
+
content: []
|
163
|
+
}
|
164
|
+
});
|
165
|
+
async function P(e = {}) {
|
166
|
+
e.params = e.params || {}, e.params.skip = e.skip || 0, e.params.limit = e.limit || 9, e.params.tags = e.tags || [], e.status && (e.params = { status: e.status }), e.url && (e.params = { url: e.url }), e.period && (e.params.period = e.period), e.category && (e.params.category = e.category), e.organization && (e.params.organization = e.organization), e.date && (e.params.date = e.date), e.participant && (e.params.participant = e.participant), e.owner && (e.params.owner = e.owner), e.creator && (e.params.creator = e.creator), e.user && (e.params.user = e.user), e.sortOrder && (e.params.sortOrder = e.sortOrder), e.sortParam && (e.params.sortParam = e.sortParam), e.params.skip = e.skip || 0, e.params.limit = e.limit || 10;
|
167
|
+
try {
|
168
|
+
console.log("Request params:" + e.params);
|
169
|
+
const t = await U.get("/api/events/read", { params: e.params });
|
170
|
+
return console.log(e.params), e.url ? b(t.data, "current") : b(t.data, "all"), Promise.resolve(t.data);
|
171
|
+
} catch (t) {
|
172
|
+
return S(t), Promise.reject(t);
|
173
|
+
}
|
174
|
+
}
|
175
|
+
async function fe(e) {
|
176
|
+
return U.post("/api/events/create", e).then(
|
177
|
+
(t) => (b(t.data, "current"), Promise.resolve(t.data)),
|
178
|
+
(t) => (S(t), Promise.reject(t))
|
179
|
+
);
|
180
|
+
}
|
181
|
+
async function ge(e) {
|
182
|
+
return U.post("/api/events/update", e).then(
|
183
|
+
(t) => (b(t.data, "current"), Promise.resolve(t.data)),
|
184
|
+
(t) => (S(t), Promise.reject(t))
|
185
|
+
);
|
186
|
+
}
|
187
|
+
async function ve(e) {
|
188
|
+
return await U.post("/api/events/delete", { _id: e }).then(
|
189
|
+
(t) => {
|
190
|
+
const s = h.all.findIndex((c) => c._id === e);
|
191
|
+
return s !== -1 && h.all.splice(s, 1), Promise.resolve(t.data);
|
192
|
+
},
|
193
|
+
(t) => (S(t), Promise.reject(t))
|
194
|
+
);
|
195
|
+
}
|
196
|
+
function b(e, t) {
|
197
|
+
h[t] = e;
|
198
|
+
}
|
199
|
+
function he() {
|
200
|
+
h.current = {
|
201
|
+
_id: "",
|
202
|
+
cover: "",
|
203
|
+
url: "",
|
204
|
+
status: "",
|
205
|
+
name: "",
|
206
|
+
tags: [],
|
207
|
+
date: {
|
208
|
+
start: null,
|
209
|
+
false: null
|
210
|
+
},
|
211
|
+
views: 0,
|
212
|
+
content: []
|
213
|
+
};
|
214
|
+
}
|
215
|
+
_(h, (e, t) => {
|
216
|
+
});
|
217
|
+
const Ue = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
|
218
|
+
__proto__: null,
|
219
|
+
clean: he,
|
220
|
+
create: fe,
|
221
|
+
read: P,
|
222
|
+
remove: ve,
|
223
|
+
set: b,
|
224
|
+
state: h,
|
225
|
+
update: ge
|
226
|
+
}, Symbol.toStringTag, { value: "Module" })), ye = { class: "feed" }, Ee = {
|
227
|
+
__name: "Feed",
|
228
|
+
props: {
|
229
|
+
category: {
|
230
|
+
type: String,
|
231
|
+
default: null
|
232
|
+
},
|
233
|
+
selectedDate: {
|
234
|
+
type: String,
|
235
|
+
default: null
|
236
|
+
},
|
237
|
+
organization: {
|
238
|
+
type: String,
|
239
|
+
default: null
|
240
|
+
},
|
241
|
+
owner: {
|
242
|
+
type: String,
|
243
|
+
default: null
|
244
|
+
},
|
245
|
+
creator: {
|
246
|
+
type: String,
|
247
|
+
default: null
|
248
|
+
},
|
249
|
+
user: {
|
250
|
+
type: [String, Number],
|
251
|
+
default: null
|
252
|
+
},
|
253
|
+
sortOrder: {
|
254
|
+
type: String,
|
255
|
+
default: "desc"
|
256
|
+
},
|
257
|
+
participant: {
|
258
|
+
type: String,
|
259
|
+
default: null
|
260
|
+
},
|
261
|
+
period: {
|
262
|
+
type: String,
|
263
|
+
default: null
|
264
|
+
},
|
265
|
+
status: {
|
266
|
+
type: String,
|
267
|
+
default: null
|
268
|
+
}
|
269
|
+
},
|
270
|
+
setup(e) {
|
271
|
+
const t = e, s = v([]), c = v(!1), d = v(!0), y = v(0), a = v(20), u = async () => {
|
272
|
+
if (c.value) {
|
273
|
+
y.value += a.value;
|
274
|
+
const n = await P({
|
275
|
+
skip: y.value,
|
276
|
+
limit: a.value,
|
277
|
+
category: t.category,
|
278
|
+
sortOrder: t.sortOrder,
|
279
|
+
participant: t.participant,
|
280
|
+
creator: t.creator,
|
281
|
+
user: t.user,
|
282
|
+
date: t.selectedDate,
|
283
|
+
owner: t.owner,
|
284
|
+
organization: t.organization,
|
285
|
+
period: t.period,
|
286
|
+
status: t.status
|
287
|
+
});
|
288
|
+
n.length === 0 ? c.value = !1 : c.value = !0, s.value = [...s.value, ...n];
|
289
|
+
}
|
290
|
+
};
|
291
|
+
return j(async () => {
|
292
|
+
d.value = !0, console.log(t.selectedDate);
|
293
|
+
const n = await P({
|
294
|
+
skip: y.value,
|
295
|
+
limit: a.value,
|
296
|
+
category: t.category,
|
297
|
+
participant: t.participant,
|
298
|
+
sortOrder: t.sortOrder,
|
299
|
+
user: t.user,
|
300
|
+
owner: t.owner,
|
301
|
+
creator: t.creator,
|
302
|
+
date: t.selectedDate,
|
303
|
+
organization: t.organization,
|
304
|
+
period: t.period,
|
305
|
+
status: t.status
|
306
|
+
});
|
307
|
+
n.length === 0 ? c.value = !1 : c.value = !0, s.value = n, d.value = !1;
|
308
|
+
}), (n, E) => (r(), i("section", ye, [
|
309
|
+
T(z, {
|
310
|
+
tag: "ul",
|
311
|
+
name: "fade",
|
312
|
+
class: "o-hidden bg-grey radius-big"
|
313
|
+
}, {
|
314
|
+
default: D(() => [
|
315
|
+
d.value ? (r(!0), i(I, { key: 0 }, F(a.value, (o) => (r(), w(me, { key: o }))), 128)) : l("", !0)
|
316
|
+
]),
|
317
|
+
_: 1
|
318
|
+
}),
|
319
|
+
T(V, { name: "fade" }, {
|
320
|
+
default: D(() => [
|
321
|
+
!d.value && s.value.length < 1 ? (r(), w(B, {
|
322
|
+
key: 0,
|
323
|
+
title: "No Events Found",
|
324
|
+
description: "Currently, there are no events available. Please check back later.",
|
325
|
+
class: "pd-medium mn-thin bg-grey radius-big"
|
326
|
+
})) : l("", !0)
|
327
|
+
]),
|
328
|
+
_: 1
|
329
|
+
}),
|
330
|
+
T(z, {
|
331
|
+
tag: "ul",
|
332
|
+
name: "fade",
|
333
|
+
class: "container"
|
334
|
+
}, {
|
335
|
+
default: D(() => [
|
336
|
+
!d.value && s.value.length > 0 ? (r(!0), i(I, { key: 0 }, F(s.value, (o, k) => (r(), w(le, {
|
337
|
+
onClick: (x) => n.$router.push({ name: "Event", params: { url: o.url } }),
|
338
|
+
key: o._id,
|
339
|
+
event: o,
|
340
|
+
owner: e.user,
|
341
|
+
type: "normal",
|
342
|
+
class: p(["bg-grey radius-big mn-medium", {
|
343
|
+
"br-b br-solid br-black-transp-10": k !== s.value.length - 1
|
344
|
+
}])
|
345
|
+
}, null, 8, ["onClick", "event", "owner", "class"]))), 128)) : l("", !0),
|
346
|
+
c.value && s.value.length > 0 ? (r(), i("button", {
|
347
|
+
key: 1,
|
348
|
+
onClick: u,
|
349
|
+
class: "w-100 bg-main button"
|
350
|
+
}, "Load more")) : l("", !0)
|
351
|
+
]),
|
352
|
+
_: 1
|
353
|
+
})
|
354
|
+
]));
|
355
|
+
}
|
356
|
+
};
|
357
|
+
export {
|
358
|
+
me as S,
|
359
|
+
Ee as _,
|
360
|
+
le as a,
|
361
|
+
fe as b,
|
362
|
+
he as c,
|
363
|
+
ve as d,
|
364
|
+
Ue as e,
|
365
|
+
P as r,
|
366
|
+
h as s,
|
367
|
+
ge as u
|
368
|
+
};
|
@@ -0,0 +1 @@
|
|
1
|
+
"use strict";const e=require("vue"),V=require("./EmptyState-7658d7d6.js"),S=require("./_plugin-vue_export-helper-f246444f.js"),h=require("./Chips-4d8ac62e.js"),$=require("vue-router"),w=require("./auth-e8f6d979.js"),u=require("./globals-928eb13c.js"),R=require("./IconEdit-4cfe2115.js"),f=w.axios.create({baseURL:process.env.API_URL,withCredentials:!0});f.defaults.withCredentials=!0;const i=e.reactive({all:[],filter:{tags:[],period:""},pagination:{page:1,perPage:18},sort:{current:"popularity",ascending:!1},current:{_id:"",url:"",status:"",name:"",tags:[],owner:{},date:"",views:0,content:[]}});async function k(t={}){t.params=t.params||{},t.params.skip=t.skip||0,t.params.limit=t.limit||9,t.params.tags=t.tags||[],t.period&&(t.params.period=t.period),t.url&&(t.params={url:t.url}),t.category&&(t.params.category=t.category),t.organization&&(t.params.organization=t.organization),t.owner&&(t.params.owner=t.owner),t.creator&&(t.params.creator=t.creator),t.status&&(t.params.status=t.status),t.user&&(t.params.user=t.user),t.params.skip=t.skip||0,t.params.limit=t.limit||10;try{console.log("Request params:"+t.params);const r=await f.get("/api/blog/read",{params:t.params});return t.url?g(r.data,"current"):g(r.data,"all"),Promise.resolve(r.data)}catch(r){return u.setError(r),Promise.reject(r)}}async function B(t){return f.post("/api/blog/create",t).then(r=>(g(r.data,"current"),Promise.resolve(r.data)),r=>(u.setError(r),Promise.reject(r)))}async function E(t){return f.post("/api/blog/update",t).then(r=>(g(r.data,"current"),Promise.resolve(r.data)),r=>(u.setError(r),Promise.reject(r)))}async function _(t){return await f.delete(`/api/blog/delete/${t}`).then(r=>{const o=i.all.findIndex(a=>a._id===t);return o!==-1&&i.all.splice(o,1),Promise.resolve(r.data)},r=>(u.setError(r),Promise.reject(r)))}function g(t,r){i[r]=t}function P(){i.current={_id:"",url:"",status:"",name:"",tags:[],author:"",owner:"",date:"",views:0,content:[]}}function j(t){const r={order:i.project.content.length+1,type:t.type,data:t.data,class:t.class,content:t.content};i.project.content.push(r)}e.watch(i,(t,r)=>{});const I=Object.freeze(Object.defineProperty({__proto__:null,blockAdd:j,clean:P,create:B,read:k,remove:_,set:g,state:i,update:E},Symbol.toStringTag,{value:"Module"})),L={props:{progress:{type:Number,default:null},status:{type:String,default:null}}},z={class:"circular-loader"},D=e.createElementVNode("svg",{viewBox:"25 25 50 50"},[e.createElementVNode("circle",{cx:"50",cy:"50",r:"20",fill:"none","stroke-width":"4","stroke-miterlimit":"10"})],-1),q={key:0,class:"progress-text"},T={key:1,class:"uppercase t-semi w-m-10r status-text"};function O(t,r,o,a,s,l){return e.openBlock(),e.createElementBlock("div",z,[D,o.progress?(e.openBlock(),e.createElementBlock("div",q,e.toDisplayString(o.progress),1)):e.createCommentVNode("",!0),o.status?(e.openBlock(),e.createElementBlock("div",T,e.toDisplayString(o.status),1)):e.createCommentVNode("",!0)])}const x=S._export_sfc(L,[["render",O]]),y=w.axios.create({baseURL:process.env.API_URL,withCredentials:!0}),d=e.reactive({reactions:[],error:null}),b={async read({user:t,type:r,target:o,role:a}){try{const s=await y.get("/api/reactions",{params:{user:t,type:r,target:o,role:a}});return d.error=null,d.reactions=s.data,Promise.resolve(s.data)}catch(s){return u.setError(s),Promise.reject(s)}},async create(t){try{const r=await y.post("/api/reactions/create",t);return d.error=null,Promise.resolve(r.data)}catch(r){return console.log(r),u.setError(r),Promise.reject(r)}},async update(t){try{const r=await y.post("/api/reactions/update",t);return d.error=null,Promise.resolve(r.data)}catch(r){return u.setError(r),Promise.reject(r)}},async delete(t){try{const r=await y.post("/api/reactions/delete",t);return d.error=null,Promise.resolve(r.data)}catch(r){return u.setError(r),Promise.reject(r)}}},U={handleReactionUpdate(t,r,o){let a;if(Array.isArray(t)?a=t.find(s=>s._id===r.target):typeof t=="object"&&t._id===r.target&&(a=t),a)if(a.hasReaction=o,o)a.reactions.push(r),a.numberOfReactions+=1;else{const s=a.reactions.findIndex(l=>l._id===r._id);s!==-1&&(a.reactions.splice(s,1),a.numberOfReactions-=1)}}};e.watch(d,t=>{});const A=Object.freeze(Object.defineProperty({__proto__:null,actions:b,mutations:U,state:d},Symbol.toStringTag,{value:"Module"})),M={class:"t-semi br-top-dark flex-nowrap flex-nojustify flex"},F=e.createElementVNode("span",{class:"mn-r-small mn-l-small d-block"},"·",-1),H={class:"cursor-pointer"},G=e.createElementVNode("span",{class:"mn-r-small mn-l-small d-block"},"·",-1),N={__name:"FooterBlogpost",props:["blogpost","owner","user"],setup(t){const r=t,o=e.ref(r.blogpost.numberOfReactions),a=e.ref(r.blogpost.isReacted),s=e.ref(r.blogpost.reactionId);async function l(m){if(!r.user){alert("Please login to add a reaction");return}try{const n={target:r.blogpost._id,type:"blogpost",user:r.user,class:"like"},p=await b.create(n);p.reaction.class==="like"&&(o.value+=1,a.value=!0,s.value=p.reaction._id)}catch(n){console.error(n),alert("Error adding reaction. Please try again later.")}}async function c(m){if(!r.user){alert("Please login to add a reaction");return}try{const n={_id:s.value};await b.delete(n),o.value-=1,a.value=!1,s.value=null}catch{alert("Error adding reaction. Please try again later.")}}return(m,n)=>(e.openBlock(),e.createElementBlock("footer",M,[e.createTextVNode(" 👁️ "+e.toDisplayString(t.blogpost.views)+" ",1),F,e.createElementVNode("div",H,[a.value?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("div",{key:0,class:"cursor-pointer",onClick:n[0]||(n[0]=p=>l())}," 👍 "+e.toDisplayString(o.value),1)),a.value?(e.openBlock(),e.createElementBlock("div",{key:1,class:"cursor-pointer",onClick:n[1]||(n[1]=p=>c())}," 👍 "+e.toDisplayString(o.value),1)):e.createCommentVNode("",!0)]),G,e.createTextVNode(" 💬 "+e.toDisplayString(t.blogpost.numberOfComments),1)]))}},J={class:"pos-relative bg-grey radius-big"},K=["src"],Q={class:"pd-t-zero pd-medium"},W={key:0,class:"cursor-pointer mn-thin flex-nowrap flex w-100"},X={key:0,class:"pd-micro t-white uppercase t-semi p-small flex-center flex pd-r-small pd-l-small mn-l-thin w-min bg-second radius-extra"},Y={key:1,class:"mn-small t-transp p-big"},Z={key:2,class:"mn-small h2"},C={__name:"CardBlogpost",props:["blogpost","user","type"],setup(t){const r=t,o=$.useRouter(),a=e.computed(()=>r.blogpost.content.find(l=>l.type==="ImageUpload")),s=e.computed(()=>r.blogpost.content.find(l=>l.type==="Textarea"));return(l,c)=>(e.openBlock(),e.createElementBlock("article",J,[t.user===t.blogpost.creator.target._id?(e.openBlock(),e.createBlock(R.IconEdit,{key:0,onClick:c[0]||(c[0]=e.withModifiers(m=>l.$router.push({name:"Edit BlogPost",params:{url:t.blogpost.url}}),["stop"])),class:"z-index-2 pos-absolute pos-t-regular pos-r-regular i-regular t-transp"})):e.createCommentVNode("",!0),e.createVNode(h._sfc_main,{class:e.normalizeClass({"mn-small pd-medium":t.type!=="short","flex-child-order-last flex-child mn-l-small":t.type==="short"}),owner:t.blogpost.owner,creator:t.blogpost.creator,date:t.blogpost.createdAt},null,8,["class","owner","creator","date"]),e.unref(a)&&e.unref(a).content&&t.type!=="blogpostPage"?(e.openBlock(),e.createElementBlock("img",{key:1,src:(l.FILE_SERVER_URL||"")+e.unref(a).content,alt:"Blog post image",class:"mn-medium object-fit-cover w-100 h-20r"},null,8,K)):e.createCommentVNode("",!0),e.createElementVNode("section",Q,[t.type!=="blogpostPage"?(e.openBlock(),e.createElementBlock("div",W,[e.createElementVNode("h3",{onClick:c[1]||(c[1]=m=>e.unref(o).push({name:"BlogPost",params:{url:t.blogpost.url}})),class:""},e.toDisplayString(t.blogpost.name),1),t.blogpost.status==="draft"?(e.openBlock(),e.createElementBlock("div",X,e.toDisplayString(t.blogpost.status),1)):e.createCommentVNode("",!0)])):e.createCommentVNode("",!0),e.unref(s)&&e.unref(s).content&&t.type!=="blogpostPage"?(e.openBlock(),e.createElementBlock("p",Y,e.toDisplayString(e.unref(s).content.slice(0,120))+"... ",1)):e.createCommentVNode("",!0),t.type==="blogpostPage"?(e.openBlock(),e.createElementBlock("h3",Z,e.toDisplayString(t.blogpost.name),1)):e.createCommentVNode("",!0),e.renderSlot(l.$slots,"default"),t.type!=="short"&&t.blogpost.tags.length>0?(e.openBlock(),e.createBlock(h._sfc_main$1,{key:3,chips:t.blogpost.tags},null,8,["chips"])):e.createCommentVNode("",!0)]),e.createVNode(N,{class:"pd-t-zero pd-medium",blogpost:t.blogpost,user:t.user},null,8,["blogpost","user"])]))}},ee={class:"feed"},te={key:1},re={__name:"Feed",props:{category:{type:String,default:null},owner:{type:String,default:null},creator:{type:String,default:null},status:{type:String,default:"published"},user:{type:[String,Number],default:null},period:{type:String,default:null}},setup(t){const r=t,o=e.ref([]),a=e.ref(!0);let s=e.ref(!0),l=e.ref(0),c=e.ref(7);const m=async()=>{if(a.value){l.value+=c.value;const n=await k({skip:l.value,limit:c.value,category:r.category,user:r.user,owner:r.owner,status:r.status,creator:r.creator,period:r.period});n.length===0&&(a.value=!1),o.value=[...o.value,...n]}};return e.onMounted(async()=>{const n=await k({skip:l.value,limit:c.value,category:r.category,user:r.user,owner:r.owner,status:r.status,creator:r.creator,period:r.period});n.length===0?a.value=!1:a.value=!0,o.value=n,s.value=!1}),(n,p)=>(e.openBlock(),e.createElementBlock("section",ee,[e.createVNode(e.Transition,{name:"fade"},{default:e.withCtx(()=>[e.unref(s)?(e.openBlock(),e.createBlock(x,{key:0,class:"z-index-5 pos-t-50 left-t-50 pos-absolute"})):e.createCommentVNode("",!0)]),_:1}),e.createVNode(e.Transition,{name:"fade"},{default:e.withCtx(()=>[!e.unref(s)&&o.value.length<1?(e.openBlock(),e.createBlock(V._sfc_main,{key:0,title:"No Blog Posts Found",description:"Currently, there are no posts available in this blog. Please check back later.",class:"pd-medium mn-thin bg-grey radius-big"})):(e.openBlock(),e.createElementBlock("div",te,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(o.value,v=>(e.openBlock(),e.createBlock(C,{key:v._id,blogpost:v,user:t.user,class:"mn-medium"},null,8,["blogpost","user"]))),128)),e.createVNode(e.Transition,{name:"fade"},{default:e.withCtx(()=>[a.value&&o.value.length>0?(e.openBlock(),e.createElementBlock("button",{key:0,onClick:m,class:"w-100 bg-main button"}," Load more ")):e.createCommentVNode("",!0)]),_:1})]))]),_:1})]))}};exports.Loader=x;exports._sfc_main=re;exports._sfc_main$1=C;exports._sfc_main$2=N;exports.blogposts=I;exports.clean=P;exports.create=B;exports.reactions=A;exports.read=k;exports.remove=_;exports.state=i;exports.update=E;
|