@pristy/pristy-libvue 2.9.0 → 2.10.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/ActivityHistory-hEggqvVi.js +197 -0
- package/dist/ActivityHistory-hEggqvVi.js.map +1 -0
- package/dist/BookmarksComponent-uxfOgWPU.js +44 -0
- package/dist/BookmarksComponent-uxfOgWPU.js.map +1 -0
- package/dist/ChartWrapper-mNaipbXn.js +59 -0
- package/dist/ChartWrapper-mNaipbXn.js.map +1 -0
- package/dist/DisplayFileInDashboardComponent-BL-ooE6T.js +104 -0
- package/dist/DisplayFileInDashboardComponent-BL-ooE6T.js.map +1 -0
- package/dist/ExternalApps-C24Qf4mq.js +90 -0
- package/dist/ExternalApps-C24Qf4mq.js.map +1 -0
- package/dist/FavoriteList-CxDxCNii.js +361 -0
- package/dist/FavoriteList-CxDxCNii.js.map +1 -0
- package/dist/MarkdownComponent-jHr71rfh.js +56 -0
- package/dist/MarkdownComponent-jHr71rfh.js.map +1 -0
- package/dist/SearchInput-DojcDnQU.js +58 -0
- package/dist/SearchInput-DojcDnQU.js.map +1 -0
- package/dist/UnknownBlockType-Pc9ihwij.js +22 -0
- package/dist/UnknownBlockType-Pc9ihwij.js.map +1 -0
- package/dist/index-DxH0-3Sq.js +38076 -0
- package/dist/index-DxH0-3Sq.js.map +1 -0
- package/dist/pristy-libvue.css +1 -1
- package/dist/pristy-libvue.es.js +197 -33098
- package/dist/pristy-libvue.es.js.map +1 -1
- package/dist/pristy-libvue.umd.js +112 -15
- package/dist/pristy-libvue.umd.js.map +1 -1
- package/dist/src/components/CodeMirrorBase.vue.d.ts +34 -0
- package/dist/src/components/CodeMirrorBase.vue.d.ts.map +1 -0
- package/dist/src/components/CodeMirrorEditor.vue.d.ts.map +1 -1
- package/dist/src/components/IconPickerDialog.vue.d.ts +63 -0
- package/dist/src/components/IconPickerDialog.vue.d.ts.map +1 -0
- package/dist/src/components/breadcrumb/ComplexBreadcrumb.vue.d.ts.map +1 -1
- package/dist/src/components/classification/AdminClassificationPage.vue.d.ts +32 -3
- package/dist/src/components/classification/AdminClassificationPage.vue.d.ts.map +1 -1
- package/dist/src/components/classification/EmplacementForm.vue.d.ts +7 -0
- package/dist/src/components/classification/EmplacementForm.vue.d.ts.map +1 -1
- package/dist/src/components/classification/MetadataFormFields.vue.d.ts +6 -2551
- package/dist/src/components/classification/NatureForm.vue.d.ts +7 -0
- package/dist/src/components/classification/NatureForm.vue.d.ts.map +1 -1
- package/dist/src/components/classification/NatureSelector.vue.d.ts +15 -2551
- package/dist/src/components/classification/UploadPlanPopup.vue.d.ts +2 -0
- package/dist/src/components/classification/UploadPlanPopup.vue.d.ts.map +1 -1
- package/dist/src/components/dashboard/DashboardAdminPage.vue.d.ts +2007 -0
- package/dist/src/components/dashboard/DashboardAdminPage.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/DashboardComponent.vue.d.ts +702 -0
- package/dist/src/components/dashboard/DashboardComponent.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/BlockConfigEditor.vue.d.ts +877 -0
- package/dist/src/components/dashboard/editor/BlockConfigEditor.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/DashboardEditor.vue.d.ts +1893 -0
- package/dist/src/components/dashboard/editor/DashboardEditor.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/FieldLabel.vue.d.ts +42 -0
- package/dist/src/components/dashboard/editor/FieldLabel.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/JsonEditorDialog.vue.d.ts +80 -0
- package/dist/src/components/dashboard/editor/JsonEditorDialog.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/MarkdownEditorDialog.vue.d.ts +77 -0
- package/dist/src/components/dashboard/editor/MarkdownEditorDialog.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/VersionHistoryDialog.vue.d.ts +53 -0
- package/dist/src/components/dashboard/editor/VersionHistoryDialog.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/block-configs/BookmarksConfig.vue.d.ts +61 -0
- package/dist/src/components/dashboard/editor/block-configs/BookmarksConfig.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/block-configs/ChartConfig.vue.d.ts +76 -0
- package/dist/src/components/dashboard/editor/block-configs/ChartConfig.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/block-configs/ExternalAppsConfig.vue.d.ts +221 -0
- package/dist/src/components/dashboard/editor/block-configs/ExternalAppsConfig.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/block-configs/FavoritesConfig.vue.d.ts +76 -0
- package/dist/src/components/dashboard/editor/block-configs/FavoritesConfig.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/block-configs/MarkdownConfig.vue.d.ts +72 -0
- package/dist/src/components/dashboard/editor/block-configs/MarkdownConfig.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/block-configs/NoConfig.vue.d.ts +4 -0
- package/dist/src/components/dashboard/editor/block-configs/NoConfig.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/block-configs/PdfImageConfig.vue.d.ts +60 -0
- package/dist/src/components/dashboard/editor/block-configs/PdfImageConfig.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/grid/BasketPanel.vue.d.ts +38 -0
- package/dist/src/components/dashboard/editor/grid/BasketPanel.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/grid/BlockTypeSelector.vue.d.ts +36 -0
- package/dist/src/components/dashboard/editor/grid/BlockTypeSelector.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/grid/GridBlock.vue.d.ts +73 -0
- package/dist/src/components/dashboard/editor/grid/GridBlock.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/grid/GridEditor.vue.d.ts +141 -0
- package/dist/src/components/dashboard/editor/grid/GridEditor.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/grid/MinimapPanel.vue.d.ts +44 -0
- package/dist/src/components/dashboard/editor/grid/MinimapPanel.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/editor/validators.d.ts +24 -0
- package/dist/src/components/dashboard/editor/validators.d.ts.map +1 -0
- package/dist/src/components/dashboard/widgets/ActivityHistory.vue.d.ts +32 -0
- package/dist/src/components/dashboard/widgets/ActivityHistory.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/widgets/BookmarksComponent.vue.d.ts +27 -0
- package/dist/src/components/dashboard/widgets/BookmarksComponent.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/widgets/ChartWrapper.vue.d.ts +41 -0
- package/dist/src/components/dashboard/widgets/ChartWrapper.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/widgets/DisplayFileInDashboardComponent.vue.d.ts +337 -0
- package/dist/src/components/dashboard/widgets/DisplayFileInDashboardComponent.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/widgets/ExternalApps.vue.d.ts +32 -0
- package/dist/src/components/dashboard/widgets/ExternalApps.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/widgets/FavoriteFileList.vue.d.ts +36 -0
- package/dist/src/components/dashboard/widgets/FavoriteFileList.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/widgets/FavoriteFolderList.vue.d.ts +35 -0
- package/dist/src/components/dashboard/widgets/FavoriteFolderList.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/widgets/FavoriteList.vue.d.ts +131 -0
- package/dist/src/components/dashboard/widgets/FavoriteList.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/widgets/FavoriteSiteList.vue.d.ts +28 -0
- package/dist/src/components/dashboard/widgets/FavoriteSiteList.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/widgets/MarkdownComponent.vue.d.ts +31 -0
- package/dist/src/components/dashboard/widgets/MarkdownComponent.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/widgets/OnlyImageDisplayed.vue.d.ts +26 -0
- package/dist/src/components/dashboard/widgets/OnlyImageDisplayed.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/widgets/SearchInput.vue.d.ts +30 -0
- package/dist/src/components/dashboard/widgets/SearchInput.vue.d.ts.map +1 -0
- package/dist/src/components/dashboard/widgets/UnknownBlockType.vue.d.ts +14 -0
- package/dist/src/components/dashboard/widgets/UnknownBlockType.vue.d.ts.map +1 -0
- package/dist/src/components/layouts/AppLayout.vue.d.ts +2 -2
- package/dist/src/components/layouts/AppLayout.vue.d.ts.map +1 -1
- package/dist/src/components/layouts/AppTopbar.vue.d.ts +1 -1
- package/dist/src/components/navigation/ContentCompactTableView.vue.d.ts.map +1 -1
- package/dist/src/components/navigation/ContentTableView.vue.d.ts.map +1 -1
- package/dist/src/components/views/PredefinedViewsPanel.vue.d.ts.map +1 -1
- package/dist/src/components/workspace/WorkspaceList.vue.d.ts +1 -1
- package/dist/src/composables/useDragDrop.d.ts +17 -0
- package/dist/src/composables/useDragDrop.d.ts.map +1 -0
- package/dist/src/composables/useGridValidation.d.ts +12 -0
- package/dist/src/composables/useGridValidation.d.ts.map +1 -0
- package/dist/src/composables/useResize.d.ts +13 -0
- package/dist/src/composables/useResize.d.ts.map +1 -0
- package/dist/src/i18n/index.d.ts +554 -0
- package/dist/src/i18n/index.d.ts.map +1 -1
- package/dist/src/index.d.ts +10 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/services/DashboardService.d.ts +77 -0
- package/dist/src/services/DashboardService.d.ts.map +1 -0
- package/dist/src/stores/config.d.ts +12 -3
- package/dist/src/stores/config.d.ts.map +1 -1
- package/package.json +4 -4
|
@@ -0,0 +1,197 @@
|
|
|
1
|
+
import { _ as h, c as y, f as b, b as _ } from "./index-DxH0-3Sq.js";
|
|
2
|
+
import { mapState as T } from "pinia";
|
|
3
|
+
import w from "primevue/dataview";
|
|
4
|
+
import H from "primevue/tooltip";
|
|
5
|
+
import { resolveComponent as S, resolveDirective as A, openBlock as l, createElementBlock as d, createVNode as I, withCtx as v, createElementVNode as a, Fragment as N, renderList as k, normalizeClass as O, withDirectives as E, createTextVNode as p, toDisplayString as m, createCommentVNode as j } from "vue";
|
|
6
|
+
const P = {
|
|
7
|
+
name: "ActivityHistory",
|
|
8
|
+
components: {
|
|
9
|
+
PrimeDataView: w
|
|
10
|
+
},
|
|
11
|
+
directives: {
|
|
12
|
+
tooltip: H
|
|
13
|
+
},
|
|
14
|
+
data() {
|
|
15
|
+
return {
|
|
16
|
+
activities: null,
|
|
17
|
+
visibleRows: 5,
|
|
18
|
+
resizeObserver: null
|
|
19
|
+
};
|
|
20
|
+
},
|
|
21
|
+
computed: {
|
|
22
|
+
...T(_, ["ESPACES_HOST"]),
|
|
23
|
+
groupedActivities() {
|
|
24
|
+
if (!this.activities)
|
|
25
|
+
return [];
|
|
26
|
+
const e = [];
|
|
27
|
+
for (const t of this.activities) {
|
|
28
|
+
const s = e[e.length - 1];
|
|
29
|
+
s && this.isSameGroup(s.entry, t.entry) ? s.count++ : e.push({ entry: t.entry, count: 1 });
|
|
30
|
+
}
|
|
31
|
+
return e;
|
|
32
|
+
}
|
|
33
|
+
},
|
|
34
|
+
mounted() {
|
|
35
|
+
this.getActivity(), this.resizeObserver = new ResizeObserver(() => this.computeVisibleRows()), this.resizeObserver.observe(this.$refs.container);
|
|
36
|
+
},
|
|
37
|
+
beforeUnmount() {
|
|
38
|
+
this.resizeObserver && this.resizeObserver.disconnect();
|
|
39
|
+
},
|
|
40
|
+
methods: {
|
|
41
|
+
isSameGroup(e, t) {
|
|
42
|
+
return e.postPersonId === t.postPersonId && e.activitySummary?.objectId === t.activitySummary?.objectId && e.activitySummary?.objectId !== void 0;
|
|
43
|
+
},
|
|
44
|
+
computeVisibleRows() {
|
|
45
|
+
const e = this.$refs.container;
|
|
46
|
+
if (!e)
|
|
47
|
+
return;
|
|
48
|
+
const t = 52, r = e.clientHeight - 50, o = Math.max(3, Math.floor(r / t));
|
|
49
|
+
this.visibleRows = o;
|
|
50
|
+
},
|
|
51
|
+
reloadData() {
|
|
52
|
+
this.getActivity();
|
|
53
|
+
},
|
|
54
|
+
formatDateTime(e) {
|
|
55
|
+
return b.formatDateTime(e);
|
|
56
|
+
},
|
|
57
|
+
getIcon(e) {
|
|
58
|
+
if (!e)
|
|
59
|
+
return "ri-information-line";
|
|
60
|
+
const t = {
|
|
61
|
+
"org.alfresco.documentlibrary.file-downloaded": "ri-download-line",
|
|
62
|
+
"org.alfresco.documentlibrary.file-added": "ri-add-circle-line",
|
|
63
|
+
"org.alfresco.site.user-joined": "ri-user-add-line",
|
|
64
|
+
"org.alfresco.site.user-left": "ri-user-unfollow-line",
|
|
65
|
+
"org.alfresco.site.user-role-changed": "ri-user-settings-line",
|
|
66
|
+
"org.alfresco.calendar.event-created": "ri-calendar-check-line",
|
|
67
|
+
"org.alfresco.calendar.event-updated": "ri-calendar-line",
|
|
68
|
+
"org.alfresco.calendar.event-deleted": "ri-calendar-close-line",
|
|
69
|
+
"org.alfresco.blog.post-created": "ri-article-line",
|
|
70
|
+
"org.alfresco.blog.post-updated": "ri-article-line",
|
|
71
|
+
"org.alfresco.blog.post-deleted": "ri-delete-bin-line",
|
|
72
|
+
"org.alfresco.links.link-created": "ri-link",
|
|
73
|
+
"org.alfresco.links.link-updated": "ri-link",
|
|
74
|
+
"org.alfresco.links.link-deleted": "ri-delete-bin-line"
|
|
75
|
+
};
|
|
76
|
+
return t[e] ? t[e] : e.includes("deleted") ? "ri-delete-bin-line" : e.includes("added") || e.includes("created") ? "ri-add-circle-line" : e.includes("updated") || e.includes("edited") ? "ri-edit-line" : e.includes("downloaded") ? "ri-download-line" : e.includes("comment") ? "ri-chat-3-line" : e.includes("discussion") || e.includes("reply") ? "ri-discuss-line" : e.includes("user-joined") ? "ri-user-add-line" : e.includes("user-left") ? "ri-user-unfollow-line" : e.includes("role-changed") ? "ri-user-settings-line" : "ri-information-line";
|
|
77
|
+
},
|
|
78
|
+
getUserDisplayName(e) {
|
|
79
|
+
const t = e.activitySummary || {};
|
|
80
|
+
if (e.activityType.includes("user-role-changed") || e.activityType.includes("user-joined") || e.activityType.includes("user-left")) {
|
|
81
|
+
const o = t.memberFirstName || t.firstName || "", i = t.memberLastName || t.lastName || "";
|
|
82
|
+
return (o + " " + i).trim() || e.postPersonId;
|
|
83
|
+
}
|
|
84
|
+
const s = t.firstName || "", r = t.lastName || "";
|
|
85
|
+
return (s + " " + r).trim() || e.postPersonId;
|
|
86
|
+
},
|
|
87
|
+
getObjectUrl(e) {
|
|
88
|
+
const t = e.activitySummary || {};
|
|
89
|
+
return !t.objectId || !this.ESPACES_HOST ? null : e.activityType.includes("folder") ? `${this.ESPACES_HOST}/espaces/mes-espaces/dossier/${t.objectId}` : `${this.ESPACES_HOST}/espaces/pdf/${t.objectId}`;
|
|
90
|
+
},
|
|
91
|
+
escapeHtml(e) {
|
|
92
|
+
const t = document.createElement("div");
|
|
93
|
+
return t.textContent = e, t.innerHTML;
|
|
94
|
+
},
|
|
95
|
+
getActivitiesMessages() {
|
|
96
|
+
const e = this.$tm("activities");
|
|
97
|
+
if (e && typeof e == "object") {
|
|
98
|
+
const t = {};
|
|
99
|
+
for (const s of Object.keys(e)) {
|
|
100
|
+
const r = e[s];
|
|
101
|
+
t[s] = typeof r == "string" ? r : r?.toString?.() || String(r);
|
|
102
|
+
}
|
|
103
|
+
return t;
|
|
104
|
+
}
|
|
105
|
+
return {};
|
|
106
|
+
},
|
|
107
|
+
getActivityMessageHtml(e) {
|
|
108
|
+
const t = e.activitySummary || {}, s = t.title || "", r = this.getActivitiesMessages(), o = {
|
|
109
|
+
title: s,
|
|
110
|
+
firstName: t.firstName || "",
|
|
111
|
+
siteName: t.siteName || "",
|
|
112
|
+
newTitle: t.newTitle || "",
|
|
113
|
+
role: this.$t(`role.${t.role}`, t.role || ""),
|
|
114
|
+
type: e.activityType
|
|
115
|
+
};
|
|
116
|
+
let i = r[e.activityType] || r.unknown;
|
|
117
|
+
if (!i)
|
|
118
|
+
return this.escapeHtml(e.activityType);
|
|
119
|
+
if (Object.keys(o).forEach((c) => {
|
|
120
|
+
c !== "title" && (i = i.replace(
|
|
121
|
+
new RegExp(`\\{${c}\\}`, "g"),
|
|
122
|
+
this.escapeHtml(o[c])
|
|
123
|
+
));
|
|
124
|
+
}), s) {
|
|
125
|
+
const c = this.getObjectUrl(e), u = this.escapeHtml(s), f = c ? `<a href="${this.escapeHtml(c)}" target="_blank" rel="noopener noreferrer" class="activity-link">${u}</a>` : `<strong>${u}</strong>`;
|
|
126
|
+
i = i.split("{title}").map((g) => this.escapeHtml(g)).join(f);
|
|
127
|
+
} else
|
|
128
|
+
i = this.escapeHtml(i);
|
|
129
|
+
return i;
|
|
130
|
+
},
|
|
131
|
+
getActivity() {
|
|
132
|
+
let e = {};
|
|
133
|
+
return y.listActivitiesForPerson("-me-", e).then((t) => {
|
|
134
|
+
this.activities = t.list.entries;
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
}, D = {
|
|
139
|
+
ref: "container",
|
|
140
|
+
class: "activity-container"
|
|
141
|
+
}, $ = { class: "activity-content" }, C = { class: "activity-text" }, M = { class: "cursor-default" }, R = ["innerHTML"], V = {
|
|
142
|
+
key: 0,
|
|
143
|
+
class: "activity-count"
|
|
144
|
+
}, x = { class: "activity-date" };
|
|
145
|
+
function z(e, t, s, r, o, i) {
|
|
146
|
+
const c = S("PrimeDataView"), u = A("tooltip");
|
|
147
|
+
return l(), d("div", D, [
|
|
148
|
+
I(c, {
|
|
149
|
+
value: i.groupedActivities,
|
|
150
|
+
paginator: "",
|
|
151
|
+
rows: o.visibleRows,
|
|
152
|
+
layout: "list"
|
|
153
|
+
}, {
|
|
154
|
+
empty: v(() => [
|
|
155
|
+
p(m(e.$t("emptyActivityHistory")), 1)
|
|
156
|
+
]),
|
|
157
|
+
list: v((f) => [
|
|
158
|
+
a("div", null, [
|
|
159
|
+
(l(!0), d(N, null, k(f.items, (n) => (l(), d("div", {
|
|
160
|
+
key: n.entry.id,
|
|
161
|
+
class: "activity-row"
|
|
162
|
+
}, [
|
|
163
|
+
a("i", {
|
|
164
|
+
class: O([i.getIcon(n.entry.activityType), "activity-icon"]),
|
|
165
|
+
"aria-hidden": "true"
|
|
166
|
+
}, null, 2),
|
|
167
|
+
a("div", $, [
|
|
168
|
+
a("p", C, [
|
|
169
|
+
E((l(), d("strong", M, [
|
|
170
|
+
p(m(i.getUserDisplayName(n.entry)), 1)
|
|
171
|
+
])), [
|
|
172
|
+
[
|
|
173
|
+
u,
|
|
174
|
+
n.entry.postPersonId,
|
|
175
|
+
void 0,
|
|
176
|
+
{ bottom: !0 }
|
|
177
|
+
]
|
|
178
|
+
]),
|
|
179
|
+
a("span", {
|
|
180
|
+
innerHTML: " " + i.getActivityMessageHtml(n.entry)
|
|
181
|
+
}, null, 8, R),
|
|
182
|
+
n.count > 1 ? (l(), d("span", V, " (+" + m(n.count - 1) + ") ", 1)) : j("", !0)
|
|
183
|
+
]),
|
|
184
|
+
a("p", x, m(i.formatDateTime(n.entry.postedAt)), 1)
|
|
185
|
+
])
|
|
186
|
+
]))), 128))
|
|
187
|
+
])
|
|
188
|
+
]),
|
|
189
|
+
_: 1
|
|
190
|
+
}, 8, ["value", "rows"])
|
|
191
|
+
], 512);
|
|
192
|
+
}
|
|
193
|
+
const W = /* @__PURE__ */ h(P, [["render", z], ["__scopeId", "data-v-87398df3"]]);
|
|
194
|
+
export {
|
|
195
|
+
W as default
|
|
196
|
+
};
|
|
197
|
+
//# sourceMappingURL=ActivityHistory-hEggqvVi.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ActivityHistory-hEggqvVi.js","sources":["../src/components/dashboard/widgets/ActivityHistory.vue"],"sourcesContent":["<!--\n Copyright (C) 2022 - Jeci SARL - https://jeci.fr\n\n This program is free software: you can redistribute it and/or modify\n it under the terms of the GNU Affero General Public License as\n published by the Free Software Foundation, either version 3 of the\n License, or (at your option) any later version.\n\n This program is distributed in the hope that it will be useful,\n but WITHOUT ANY WARRANTY; without even the implied warranty of\n MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n GNU Affero General Public License for more details.\n\n You should have received a copy of the GNU Affero General Public License\n along with this program. If not, see https://www.gnu.org/licenses/agpl-3.0.html.\n-->\n<template>\n <div ref=\"container\" class=\"activity-container\">\n <PrimeDataView\n :value=\"groupedActivities\"\n paginator\n :rows=\"visibleRows\"\n layout=\"list\"\n >\n <template #empty>\n {{ $t(\"emptyActivityHistory\") }}\n </template>\n <template #list=\"slotProps\">\n <div>\n <div\n v-for=\"group in slotProps.items\"\n :key=\"group.entry.id\"\n class=\"activity-row\"\n >\n <i\n :class=\"getIcon(group.entry.activityType)\"\n class=\"activity-icon\"\n aria-hidden=\"true\"\n ></i>\n\n <div class=\"activity-content\">\n <p class=\"activity-text\">\n <strong\n v-tooltip.bottom=\"group.entry.postPersonId\"\n class=\"cursor-default\"\n >\n {{ getUserDisplayName(group.entry) }}\n </strong>\n <!-- eslint-disable-next-line vue/no-v-html -- Activity messages contain safe HTML with escaped user content -->\n <span v-html=\"' ' + getActivityMessageHtml(group.entry)\"></span>\n <span v-if=\"group.count > 1\" class=\"activity-count\">\n (+{{ group.count - 1 }})\n </span>\n </p>\n <p class=\"activity-date\">\n {{ formatDateTime(group.entry.postedAt) }}\n </p>\n </div>\n </div>\n </div>\n </template>\n </PrimeDataView>\n </div>\n</template>\n\n<script>\nimport { activitiesApi } from \"@/AlfrescoApi.js\";\nimport formatService from \"@/services/FormatService.js\";\nimport { useConfigStore } from \"@/stores/config\";\nimport { mapState } from \"pinia\";\nimport DataView from \"primevue/dataview\";\nimport Tooltip from \"primevue/tooltip\";\n\nexport default {\n name: \"ActivityHistory\",\n components: {\n PrimeDataView: DataView,\n },\n directives: {\n tooltip: Tooltip,\n },\n data() {\n return {\n activities: null,\n visibleRows: 5,\n resizeObserver: null,\n };\n },\n computed: {\n ...mapState(useConfigStore, [\"ESPACES_HOST\"]),\n groupedActivities() {\n if (!this.activities) {\n return [];\n }\n const groups = [];\n for (const activity of this.activities) {\n const prev = groups[groups.length - 1];\n if (prev && this.isSameGroup(prev.entry, activity.entry)) {\n prev.count++;\n } else {\n groups.push({ entry: activity.entry, count: 1 });\n }\n }\n return groups;\n },\n },\n mounted() {\n this.getActivity();\n this.resizeObserver = new ResizeObserver(() => this.computeVisibleRows());\n this.resizeObserver.observe(this.$refs.container);\n },\n beforeUnmount() {\n if (this.resizeObserver) {\n this.resizeObserver.disconnect();\n }\n },\n methods: {\n isSameGroup(a, b) {\n return (\n a.postPersonId === b.postPersonId &&\n a.activitySummary?.objectId === b.activitySummary?.objectId &&\n a.activitySummary?.objectId !== undefined\n );\n },\n computeVisibleRows() {\n const container = this.$refs.container;\n if (!container) {\n return;\n }\n const ROW_HEIGHT = 52;\n const PAGINATOR_HEIGHT = 50;\n const available = container.clientHeight - PAGINATOR_HEIGHT;\n const rows = Math.max(3, Math.floor(available / ROW_HEIGHT));\n this.visibleRows = rows;\n },\n reloadData() {\n this.getActivity();\n },\n formatDateTime(date) {\n return formatService.formatDateTime(date);\n },\n getIcon(type) {\n if (!type) {\n return \"ri-information-line\";\n }\n\n const exactIconMap = {\n \"org.alfresco.documentlibrary.file-downloaded\": \"ri-download-line\",\n \"org.alfresco.documentlibrary.file-added\": \"ri-add-circle-line\",\n \"org.alfresco.site.user-joined\": \"ri-user-add-line\",\n \"org.alfresco.site.user-left\": \"ri-user-unfollow-line\",\n \"org.alfresco.site.user-role-changed\": \"ri-user-settings-line\",\n \"org.alfresco.calendar.event-created\": \"ri-calendar-check-line\",\n \"org.alfresco.calendar.event-updated\": \"ri-calendar-line\",\n \"org.alfresco.calendar.event-deleted\": \"ri-calendar-close-line\",\n \"org.alfresco.blog.post-created\": \"ri-article-line\",\n \"org.alfresco.blog.post-updated\": \"ri-article-line\",\n \"org.alfresco.blog.post-deleted\": \"ri-delete-bin-line\",\n \"org.alfresco.links.link-created\": \"ri-link\",\n \"org.alfresco.links.link-updated\": \"ri-link\",\n \"org.alfresco.links.link-deleted\": \"ri-delete-bin-line\",\n };\n\n if (exactIconMap[type]) {\n return exactIconMap[type];\n }\n\n if (type.includes(\"deleted\")) {\n return \"ri-delete-bin-line\";\n }\n if (type.includes(\"added\") || type.includes(\"created\")) {\n return \"ri-add-circle-line\";\n }\n if (type.includes(\"updated\") || type.includes(\"edited\")) {\n return \"ri-edit-line\";\n }\n if (type.includes(\"downloaded\")) {\n return \"ri-download-line\";\n }\n if (type.includes(\"comment\")) {\n return \"ri-chat-3-line\";\n }\n if (type.includes(\"discussion\") || type.includes(\"reply\")) {\n return \"ri-discuss-line\";\n }\n if (type.includes(\"user-joined\")) {\n return \"ri-user-add-line\";\n }\n if (type.includes(\"user-left\")) {\n return \"ri-user-unfollow-line\";\n }\n if (type.includes(\"role-changed\")) {\n return \"ri-user-settings-line\";\n }\n\n return \"ri-information-line\";\n },\n getUserDisplayName(entry) {\n const summary = entry.activitySummary || {};\n if (\n entry.activityType.includes(\"user-role-changed\") ||\n entry.activityType.includes(\"user-joined\") ||\n entry.activityType.includes(\"user-left\")\n ) {\n const first = summary.memberFirstName || summary.firstName || \"\";\n const last = summary.memberLastName || summary.lastName || \"\";\n return (first + \" \" + last).trim() || entry.postPersonId;\n }\n const first = summary.firstName || \"\";\n const last = summary.lastName || \"\";\n return (first + \" \" + last).trim() || entry.postPersonId;\n },\n getObjectUrl(entry) {\n const summary = entry.activitySummary || {};\n if (!summary.objectId || !this.ESPACES_HOST) {\n return null;\n }\n // Folder activities\n if (entry.activityType.includes(\"folder\")) {\n return `${this.ESPACES_HOST}/espaces/mes-espaces/dossier/${summary.objectId}`;\n }\n // File activities — open as PDF by default\n return `${this.ESPACES_HOST}/espaces/pdf/${summary.objectId}`;\n },\n escapeHtml(text) {\n const div = document.createElement(\"div\");\n div.textContent = text;\n return div.innerHTML;\n },\n getActivitiesMessages() {\n // Activity type keys contain dots (e.g. \"org.alfresco.documentlibrary.file-added\")\n // which $t() interprets as nested path separators.\n // Use $tm() to get the raw message object for the \"activities\" key.\n const raw = this.$tm(\"activities\");\n if (raw && typeof raw === \"object\") {\n // $tm() returns reactive message objects; convert values to plain strings\n const messages = {};\n for (const key of Object.keys(raw)) {\n const val = raw[key];\n messages[key] =\n typeof val === \"string\" ? val : val?.toString?.() || String(val);\n }\n return messages;\n }\n return {};\n },\n getActivityMessageHtml(entry) {\n const summary = entry.activitySummary || {};\n const title = summary.title || \"\";\n const activities = this.getActivitiesMessages();\n\n const params = {\n title: title,\n firstName: summary.firstName || \"\",\n siteName: summary.siteName || \"\",\n newTitle: summary.newTitle || \"\",\n role: this.$t(`role.${summary.role}`, summary.role || \"\"),\n type: entry.activityType,\n };\n\n let message = activities[entry.activityType] || activities[\"unknown\"];\n if (!message) {\n return this.escapeHtml(entry.activityType);\n }\n\n // Interpolate all params except title\n Object.keys(params).forEach((key) => {\n if (key === \"title\") {\n return;\n }\n message = message.replace(\n new RegExp(`\\\\{${key}\\\\}`, \"g\"),\n this.escapeHtml(params[key]),\n );\n });\n\n // Escape the rest of the message\n // Split around {title} placeholders, escape each part, then rejoin with the link\n if (title) {\n const url = this.getObjectUrl(entry);\n const escapedTitle = this.escapeHtml(title);\n const titleHtml = url\n ? `<a href=\"${this.escapeHtml(url)}\" target=\"_blank\" rel=\"noopener noreferrer\" class=\"activity-link\">${escapedTitle}</a>`\n : `<strong>${escapedTitle}</strong>`;\n const parts = message.split(\"{title}\");\n message = parts.map((p) => this.escapeHtml(p)).join(titleHtml);\n } else {\n message = this.escapeHtml(message);\n }\n\n return message;\n },\n getActivity() {\n let opts = {};\n return activitiesApi\n .listActivitiesForPerson(\"-me-\", opts)\n .then((data) => {\n this.activities = data.list.entries;\n });\n },\n },\n};\n</script>\n\n<style scoped>\n.activity-container {\n height: 100%;\n}\n\n.activity-row {\n display: flex;\n gap: 0.75rem;\n padding: 0.5rem 0;\n}\n\n.activity-icon {\n font-size: 1.25rem;\n color: var(--p-primary-color);\n margin-top: 0.25rem;\n}\n\n.activity-content {\n flex: 1;\n min-width: 0;\n}\n\n.activity-text {\n font-size: 0.875rem;\n margin: 0;\n}\n\n.activity-count {\n margin-left: 0.25rem;\n font-size: 0.75rem;\n color: var(--p-text-muted-color);\n}\n\n.activity-date {\n font-size: 0.75rem;\n color: var(--p-text-muted-color);\n margin: 0;\n margin-top: 0.25rem;\n}\n\n.cursor-default {\n cursor: default;\n}\n\n:deep(.activity-link) {\n color: var(--p-primary-color);\n text-decoration: none;\n font-weight: 600;\n}\n\n:deep(.activity-link:hover) {\n text-decoration: underline;\n}\n\n:deep(.activity-link:focus-visible) {\n outline: 2px solid var(--p-primary-color);\n outline-offset: 2px;\n border-radius: 2px;\n}\n</style>\n"],"names":["_sfc_main","DataView","Tooltip","mapState","useConfigStore","groups","activity","prev","a","b","container","ROW_HEIGHT","available","rows","date","formatService","type","exactIconMap","entry","summary","first","last","text","div","raw","messages","key","val","title","activities","params","message","url","escapedTitle","titleHtml","p","opts","activitiesApi","data","_hoisted_2","_hoisted_3","_hoisted_4","_hoisted_7","_openBlock","_createElementBlock","_hoisted_1","_createVNode","_component_PrimeDataView","$options","$data","_ctx","_withCtx","slotProps","_createElementVNode","_Fragment","_renderList","group","_normalizeClass","_withDirectives","_hoisted_6","_toDisplayString"],"mappings":"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"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { openBlock as o, createElementBlock as t, createElementVNode as s, Fragment as i, renderList as c, normalizeClass as m, toDisplayString as k } from "vue";
|
|
2
|
+
import { _ } from "./index-DxH0-3Sq.js";
|
|
3
|
+
const d = {
|
|
4
|
+
name: "BookmarksComponent",
|
|
5
|
+
props: {
|
|
6
|
+
bookmarks: {
|
|
7
|
+
type: Array,
|
|
8
|
+
default: () => []
|
|
9
|
+
},
|
|
10
|
+
urlResolver: {
|
|
11
|
+
type: Function,
|
|
12
|
+
default: null
|
|
13
|
+
}
|
|
14
|
+
},
|
|
15
|
+
methods: {
|
|
16
|
+
navigateTo(n) {
|
|
17
|
+
this.urlResolver && this.urlResolver(n);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
}, p = { class: "bookmarks-container" }, u = { class: "bookmarks-list" }, f = ["onClick"], h = { class: "bookmark-name" };
|
|
21
|
+
function v(n, y, r, b, C, a) {
|
|
22
|
+
return o(), t("div", p, [
|
|
23
|
+
s("ul", u, [
|
|
24
|
+
(o(!0), t(i, null, c(r.bookmarks, (e, l) => (o(), t("li", {
|
|
25
|
+
key: l,
|
|
26
|
+
onClick: (g) => a.navigateTo(e),
|
|
27
|
+
class: "bookmark-item"
|
|
28
|
+
}, [
|
|
29
|
+
s("i", {
|
|
30
|
+
class: m([
|
|
31
|
+
e.type === "folder" ? "ri-folder-line" : "ri-file-line",
|
|
32
|
+
"bookmark-icon"
|
|
33
|
+
])
|
|
34
|
+
}, null, 2),
|
|
35
|
+
s("span", h, k(e.name), 1)
|
|
36
|
+
], 8, f))), 128))
|
|
37
|
+
])
|
|
38
|
+
]);
|
|
39
|
+
}
|
|
40
|
+
const R = /* @__PURE__ */ _(d, [["render", v], ["__scopeId", "data-v-48871645"]]);
|
|
41
|
+
export {
|
|
42
|
+
R as default
|
|
43
|
+
};
|
|
44
|
+
//# sourceMappingURL=BookmarksComponent-uxfOgWPU.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BookmarksComponent-uxfOgWPU.js","sources":["../src/components/dashboard/widgets/BookmarksComponent.vue"],"sourcesContent":["<!--\n Copyright (C) 2022 - Jeci SARL - https://jeci.fr\n\n This program is free software: you can redistribute it and/or modify\n it under the terms of the GNU Affero General Public License as\n published by the Free Software Foundation, either version 3 of the\n License, or (at your option) any later version.\n\n This program is distributed in the hope that it will be useful,\n but WITHOUT ANY WARRANTY; without even the implied warranty of\n MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n GNU Affero General Public License for more details.\n\n You should have received a copy of the GNU Affero General Public License\n along with this program. If not, see https://www.gnu.org/licenses/agpl-3.0.html.\n-->\n\n<template>\n <div class=\"bookmarks-container\">\n <ul class=\"bookmarks-list\">\n <li\n v-for=\"(bookmark, index) in bookmarks\"\n :key=\"index\"\n @click=\"navigateTo(bookmark)\"\n class=\"bookmark-item\"\n >\n <i\n :class=\"\n bookmark.type === 'folder' ? 'ri-folder-line' : 'ri-file-line'\n \"\n class=\"bookmark-icon\"\n ></i>\n <span class=\"bookmark-name\">\n {{ bookmark.name }}\n </span>\n </li>\n </ul>\n </div>\n</template>\n\n<script>\nexport default {\n name: \"BookmarksComponent\",\n props: {\n bookmarks: {\n type: Array,\n default: () => [],\n },\n urlResolver: {\n type: Function,\n default: null,\n },\n },\n methods: {\n navigateTo(bookmark) {\n if (this.urlResolver) {\n this.urlResolver(bookmark);\n }\n },\n },\n};\n</script>\n\n<style scoped>\n.bookmarks-container {\n width: 100%;\n}\n\n.bookmarks-list {\n list-style: none;\n padding: 0;\n margin: 0;\n}\n\n.bookmark-item {\n display: flex;\n align-items: center;\n gap: 0.75rem;\n padding: 0.5rem 0.75rem;\n border-radius: 0.5rem;\n cursor: pointer;\n transition:\n background-color 0.2s,\n color 0.2s;\n}\n\n.bookmark-item:hover {\n background: var(--p-highlight-background);\n color: var(--p-primary-color);\n}\n\n.bookmark-icon {\n font-size: 1.125rem;\n flex-shrink: 0;\n color: var(--p-primary-color);\n}\n\n.bookmark-name {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n font-weight: 500;\n}\n</style>\n"],"names":["_sfc_main","bookmark","_hoisted_1","_hoisted_2","_hoisted_4","_openBlock","_createElementBlock","_createElementVNode","_Fragment","_renderList","$props","index","$event","$options","_normalizeClass","_toDisplayString"],"mappings":";;AAyCA,MAAKA,IAAU;AAAA,EACb,MAAM;AAAA,EACN,OAAO;AAAA,IACL,WAAW;AAAA,MACT,MAAM;AAAA,MACN,SAAS,MAAM,CAAA;AAAA;IAEjB,aAAa;AAAA,MACX,MAAM;AAAA,MACN,SAAS;AAAA;;EAGb,SAAS;AAAA,IACP,WAAWC,GAAU;AACnB,MAAI,KAAK,eACP,KAAK,YAAYA,CAAQ;AAAA,IAE7B;AAAA;AAEJ,GA1COC,IAAA,EAAA,OAAM,sBAAqB,GAC1BC,IAAA,EAAA,OAAM,iBAAgB,oBAahBC,IAAA,EAAA,OAAM,gBAAe;;AAdjC,SAAAC,EAAA,GAAAC,EAmBM,OAnBNJ,GAmBM;AAAA,IAlBJK,EAiBK,MAjBLJ,GAiBK;AAAA,OAhBHE,EAAA,EAAA,GAAAC,EAeKE,GAAA,MAAAC,EAdyBC,EAAA,WAAS,CAA7BT,GAAUU,YADpBL,EAeK,MAAA;AAAA,QAbF,KAAKK;AAAA,QACL,SAAK,CAAAC,MAAEC,EAAA,WAAWZ,CAAQ;AAAA,QAC3B,OAAM;AAAA;QAENM,EAKK,KAAA;AAAA,UAJF,OAAKO,EAAA;AAAA,YAAeb,EAAS,SAAI,WAAA,mBAAA;AAAA,YAG5B;AAAA,UAAe,CAAA;AAAA;QAEvBM,EAEO,QAFPH,GAEOW,EADFd,EAAS,IAAI,GAAA,CAAA;AAAA;;;;;"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import r from "primevue/chart";
|
|
2
|
+
import { resolveComponent as n, openBlock as p, createElementBlock as a, createVNode as s } from "vue";
|
|
3
|
+
import { _ as i } from "./index-DxH0-3Sq.js";
|
|
4
|
+
const l = {
|
|
5
|
+
name: "ChartWrapper",
|
|
6
|
+
components: {
|
|
7
|
+
PrimeChart: r
|
|
8
|
+
},
|
|
9
|
+
props: {
|
|
10
|
+
type: {
|
|
11
|
+
type: String,
|
|
12
|
+
required: !0
|
|
13
|
+
},
|
|
14
|
+
data: {
|
|
15
|
+
type: Object,
|
|
16
|
+
required: !0
|
|
17
|
+
},
|
|
18
|
+
options: {
|
|
19
|
+
type: Object,
|
|
20
|
+
default: () => ({})
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
computed: {
|
|
24
|
+
textColor() {
|
|
25
|
+
return getComputedStyle(document.documentElement).getPropertyValue("--p-text-color").trim();
|
|
26
|
+
},
|
|
27
|
+
mergedOptions() {
|
|
28
|
+
return {
|
|
29
|
+
...this.options,
|
|
30
|
+
plugins: {
|
|
31
|
+
...this.options?.plugins,
|
|
32
|
+
legend: {
|
|
33
|
+
...this.options?.plugins?.legend,
|
|
34
|
+
labels: {
|
|
35
|
+
...this.options?.plugins?.legend?.labels,
|
|
36
|
+
color: this.textColor
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}, c = { class: "chart-wrapper" };
|
|
44
|
+
function d(m, u, t, h, _, e) {
|
|
45
|
+
const o = n("PrimeChart");
|
|
46
|
+
return p(), a("div", c, [
|
|
47
|
+
s(o, {
|
|
48
|
+
class: "chart-full-width",
|
|
49
|
+
type: t.type,
|
|
50
|
+
data: t.data,
|
|
51
|
+
options: e.mergedOptions
|
|
52
|
+
}, null, 8, ["type", "data", "options"])
|
|
53
|
+
]);
|
|
54
|
+
}
|
|
55
|
+
const y = /* @__PURE__ */ i(l, [["render", d], ["__scopeId", "data-v-e0f7b28a"]]);
|
|
56
|
+
export {
|
|
57
|
+
y as default
|
|
58
|
+
};
|
|
59
|
+
//# sourceMappingURL=ChartWrapper-mNaipbXn.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChartWrapper-mNaipbXn.js","sources":["../src/components/dashboard/widgets/ChartWrapper.vue"],"sourcesContent":["<!--\n Copyright (C) 2022 - Jeci SARL - https://jeci.fr\n\n This program is free software: you can redistribute it and/or modify\n it under the terms of the GNU Affero General Public License as\n published by the Free Software Foundation, either version 3 of the\n License, or (at your option) any later version.\n\n This program is distributed in the hope that it will be useful,\n but WITHOUT ANY WARRANTY; without even the implied warranty of\n MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n GNU Affero General Public License for more details.\n\n You should have received a copy of the GNU Affero General Public License\n along with this program. If not, see https://www.gnu.org/licenses/agpl-3.0.html.\n-->\n<template>\n <div class=\"chart-wrapper\">\n <PrimeChart\n class=\"chart-full-width\"\n :type=\"type\"\n :data=\"data\"\n :options=\"mergedOptions\"\n />\n </div>\n</template>\n\n<script>\nimport Chart from \"primevue/chart\";\n\nexport default {\n name: \"ChartWrapper\",\n components: {\n PrimeChart: Chart,\n },\n props: {\n type: {\n type: String,\n required: true,\n },\n data: {\n type: Object,\n required: true,\n },\n options: {\n type: Object,\n default: () => ({}),\n },\n },\n computed: {\n textColor() {\n return getComputedStyle(document.documentElement)\n .getPropertyValue(\"--p-text-color\")\n .trim();\n },\n mergedOptions() {\n return {\n ...this.options,\n plugins: {\n ...this.options?.plugins,\n legend: {\n ...this.options?.plugins?.legend,\n labels: {\n ...this.options?.plugins?.legend?.labels,\n color: this.textColor,\n },\n },\n },\n };\n },\n },\n};\n</script>\n\n<style scoped>\n.chart-wrapper {\n display: flex;\n justify-content: center;\n}\n\n.chart-full-width {\n width: 100%;\n}\n</style>\n"],"names":["_sfc_main","Chart","_hoisted_1","_openBlock","_createElementBlock","_createVNode","_component_PrimeChart","$props","$options"],"mappings":";;;AA8BA,MAAKA,IAAU;AAAA,EACb,MAAM;AAAA,EACN,YAAY;AAAA,IACV,YAAYC;AAAA;EAEd,OAAO;AAAA,IACL,MAAM;AAAA,MACJ,MAAM;AAAA,MACN,UAAU;AAAA;IAEZ,MAAM;AAAA,MACJ,MAAM;AAAA,MACN,UAAU;AAAA;IAEZ,SAAS;AAAA,MACP,MAAM;AAAA,MACN,SAAS,OAAO,CAAA;AAAA;;EAGpB,UAAU;AAAA,IACR,YAAY;AACV,aAAO,iBAAiB,SAAS,eAAe,EAC7C,iBAAiB,gBAAgB,EACjC,KAAI;AAAA,IACT;AAAA,IACA,gBAAgB;AACd,aAAO;AAAA,QACL,GAAG,KAAK;AAAA,QACR,SAAS;AAAA,UACP,GAAG,KAAK,SAAS;AAAA,UACjB,QAAQ;AAAA,YACN,GAAG,KAAK,SAAS,SAAS;AAAA,YAC1B,QAAQ;AAAA,cACN,GAAG,KAAK,SAAS,SAAS,QAAQ;AAAA,cAClC,OAAO,KAAK;AAAA;;;;IAKtB;AAAA;AAEJ,GAtDOC,IAAA,EAAA,OAAM,gBAAe;;;AAA1B,SAAAC,EAAA,GAAAC,EAOM,OAPNF,GAOM;AAAA,IANJG,EAKEC,GAAA;AAAA,MAJA,OAAM;AAAA,MACL,MAAMC,EAAA;AAAA,MACN,MAAMA,EAAA;AAAA,MACN,SAASC,EAAA;AAAA;;;;"}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { _ as l, e as m } from "./index-DxH0-3Sq.js";
|
|
2
|
+
import g from "primevue/image";
|
|
3
|
+
import { resolveComponent as d, openBlock as t, createBlock as y, createCommentVNode as p, createElementBlock as s, createVNode as c, Fragment as h, renderList as D, createElementVNode as I, toDisplayString as F } from "vue";
|
|
4
|
+
import { VuePDF as P, usePDF as k } from "@tato30/vue-pdf";
|
|
5
|
+
const v = {
|
|
6
|
+
name: "OnlyImageDisplayed",
|
|
7
|
+
components: {
|
|
8
|
+
PrimeImage: g
|
|
9
|
+
},
|
|
10
|
+
props: {
|
|
11
|
+
id: {
|
|
12
|
+
type: String,
|
|
13
|
+
default: ""
|
|
14
|
+
}
|
|
15
|
+
},
|
|
16
|
+
data() {
|
|
17
|
+
return {
|
|
18
|
+
contentUrl: null
|
|
19
|
+
};
|
|
20
|
+
},
|
|
21
|
+
mounted() {
|
|
22
|
+
this.loadImage();
|
|
23
|
+
},
|
|
24
|
+
methods: {
|
|
25
|
+
loadImage() {
|
|
26
|
+
this.contentUrl = m.getContentUrl(this.id);
|
|
27
|
+
}
|
|
28
|
+
},
|
|
29
|
+
computed: {
|
|
30
|
+
hasContentUrl() {
|
|
31
|
+
return this.contentUrl !== "";
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
function C(n, r, o, u, e, f) {
|
|
36
|
+
const a = d("PrimeImage");
|
|
37
|
+
return o.id ? (t(), y(a, {
|
|
38
|
+
key: 0,
|
|
39
|
+
src: e.contentUrl,
|
|
40
|
+
imageClass: "image-displayed"
|
|
41
|
+
}, null, 8, ["src"])) : p("", !0);
|
|
42
|
+
}
|
|
43
|
+
const U = /* @__PURE__ */ l(v, [["render", C], ["__scopeId", "data-v-ca506b36"]]), V = {
|
|
44
|
+
name: "DisplayFileInDashboardComponent",
|
|
45
|
+
components: { VuePDF: P, OnlyImageDisplayed: U },
|
|
46
|
+
props: {
|
|
47
|
+
type: {
|
|
48
|
+
type: String,
|
|
49
|
+
default: "pdf"
|
|
50
|
+
},
|
|
51
|
+
id: {
|
|
52
|
+
type: String,
|
|
53
|
+
default: ""
|
|
54
|
+
}
|
|
55
|
+
},
|
|
56
|
+
data() {
|
|
57
|
+
return {
|
|
58
|
+
pdf: null,
|
|
59
|
+
pages: 0,
|
|
60
|
+
rotation: 0,
|
|
61
|
+
scale: 1
|
|
62
|
+
};
|
|
63
|
+
},
|
|
64
|
+
mounted() {
|
|
65
|
+
this.type === "pdf" && this.loadPDF();
|
|
66
|
+
},
|
|
67
|
+
methods: {
|
|
68
|
+
loadPDF() {
|
|
69
|
+
let n = m.getContentUrl(this.id);
|
|
70
|
+
if (!n) {
|
|
71
|
+
console.error("URL is not defined");
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
const r = k(n);
|
|
75
|
+
this.pdf = r.pdf, this.pages = r.pages;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
}, S = { key: 0 }, O = { key: 1 }, b = {
|
|
79
|
+
key: 0,
|
|
80
|
+
class: "pdf-pages-container"
|
|
81
|
+
}, x = { class: "pdf-pagination" };
|
|
82
|
+
function B(n, r, o, u, e, f) {
|
|
83
|
+
const a = d("OnlyImageDisplayed"), _ = d("VuePDF");
|
|
84
|
+
return o.type === "image" ? (t(), s("div", S, [
|
|
85
|
+
c(a, { id: o.id }, null, 8, ["id"])
|
|
86
|
+
])) : o.type === "pdf" ? (t(), s("div", O, [
|
|
87
|
+
e.pdf ? (t(), s("div", b, [
|
|
88
|
+
(t(!0), s(h, null, D(e.pages, (i) => (t(), s("div", { key: i }, [
|
|
89
|
+
c(_, {
|
|
90
|
+
pdf: e.pdf,
|
|
91
|
+
page: i,
|
|
92
|
+
rotation: e.rotation,
|
|
93
|
+
scale: e.scale
|
|
94
|
+
}, null, 8, ["pdf", "page", "rotation", "scale"]),
|
|
95
|
+
I("span", x, F(n.$t("pdf.currentPagination", { page: i, pages: e.pages })), 1)
|
|
96
|
+
]))), 128))
|
|
97
|
+
])) : p("", !0)
|
|
98
|
+
])) : p("", !0);
|
|
99
|
+
}
|
|
100
|
+
const j = /* @__PURE__ */ l(V, [["render", B], ["__scopeId", "data-v-3430e09a"]]);
|
|
101
|
+
export {
|
|
102
|
+
j as default
|
|
103
|
+
};
|
|
104
|
+
//# sourceMappingURL=DisplayFileInDashboardComponent-BL-ooE6T.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DisplayFileInDashboardComponent-BL-ooE6T.js","sources":["../src/components/dashboard/widgets/OnlyImageDisplayed.vue","../src/components/dashboard/widgets/DisplayFileInDashboardComponent.vue"],"sourcesContent":["<!--\n Copyright (C) 2022 - Jeci SARL - https://jeci.fr\n\n This program is free software: you can redistribute it and/or modify\n it under the terms of the GNU Affero General Public License as\n published by the Free Software Foundation, either version 3 of the\n License, or (at your option) any later version.\n\n This program is distributed in the hope that it will be useful,\n but WITHOUT ANY WARRANTY; without even the implied warranty of\n MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n GNU Affero General Public License for more details.\n\n You should have received a copy of the GNU Affero General Public License\n along with this program. If not, see https://www.gnu.org/licenses/agpl-3.0.html.\n-->\n<template>\n <PrimeImage v-if=\"id\" :src=\"contentUrl\" imageClass=\"image-displayed\" />\n</template>\n<script>\nimport Image from \"primevue/image\";\nimport alfrescoFileService from \"@/services/AlfrescoFileService.js\";\n\nexport default {\n name: \"OnlyImageDisplayed\",\n components: {\n PrimeImage: Image,\n },\n props: {\n id: {\n type: String,\n default: \"\",\n },\n },\n data() {\n return {\n contentUrl: null,\n };\n },\n mounted() {\n this.loadImage();\n },\n methods: {\n loadImage() {\n this.contentUrl = alfrescoFileService.getContentUrl(this.id);\n },\n },\n computed: {\n hasContentUrl() {\n return this.contentUrl !== \"\";\n },\n },\n};\n</script>\n<style scoped>\n:deep(.image-displayed) {\n max-width: 100%;\n max-height: 100%;\n width: auto;\n height: auto;\n display: block;\n}\n</style>\n","<!--\n Copyright (C) 2022 - Jeci SARL - https://jeci.fr\n\n This program is free software: you can redistribute it and/or modify\n it under the terms of the GNU Affero General Public License as\n published by the Free Software Foundation, either version 3 of the\n License, or (at your option) any later version.\n\n This program is distributed in the hope that it will be useful,\n but WITHOUT ANY WARRANTY; without even the implied warranty of\n MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n GNU Affero General Public License for more details.\n\n You should have received a copy of the GNU Affero General Public License\n along with this program. If not, see https://www.gnu.org/licenses/agpl-3.0.html.\n-->\n<template>\n <div v-if=\"type === 'image'\">\n <OnlyImageDisplayed :id=\"id\" />\n </div>\n <div v-else-if=\"type === 'pdf'\">\n <div v-if=\"pdf\" class=\"pdf-pages-container\">\n <div v-for=\"page in pages\" :key=\"page\">\n <VuePDF :pdf=\"pdf\" :page=\"page\" :rotation=\"rotation\" :scale=\"scale\" />\n <span class=\"pdf-pagination\">\n {{ $t(\"pdf.currentPagination\", { page: page, pages: pages }) }}</span\n >\n </div>\n </div>\n </div>\n</template>\n\n<script>\nimport alfrescoFileService from \"@/services/AlfrescoFileService.js\";\nimport OnlyImageDisplayed from \"@/components/dashboard/widgets/OnlyImageDisplayed.vue\";\nimport { usePDF, VuePDF } from \"@tato30/vue-pdf\";\n\nexport default {\n name: \"DisplayFileInDashboardComponent\",\n components: { VuePDF, OnlyImageDisplayed },\n props: {\n type: {\n type: String,\n default: \"pdf\",\n },\n id: {\n type: String,\n default: \"\",\n },\n },\n data() {\n return {\n pdf: null,\n pages: 0,\n rotation: 0,\n scale: 1,\n };\n },\n mounted() {\n if (this.type === \"pdf\") {\n this.loadPDF();\n }\n },\n methods: {\n loadPDF() {\n let url = alfrescoFileService.getContentUrl(this.id);\n if (!url) {\n console.error(\"URL is not defined\");\n return;\n }\n const document = usePDF(url);\n this.pdf = document.pdf;\n this.pages = document.pages;\n },\n },\n};\n</script>\n\n<style scoped>\n.pdf-pages-container {\n display: flex;\n flex-wrap: wrap;\n justify-content: center;\n gap: 1rem;\n}\n\n.pdf-pagination {\n display: flex;\n justify-content: center;\n padding: 1rem;\n}\n</style>\n"],"names":["_sfc_main","Image","alfrescoFileService","$props","_createBlock","_component_PrimeImage","$data","VuePDF","OnlyImageDisplayed","url","document","usePDF","_hoisted_4","_createElementBlock","_hoisted_1","_createVNode","_component_OnlyImageDisplayed","_hoisted_2","_openBlock","_hoisted_3","_Fragment","_renderList","page","_component_VuePDF","_createElementVNode","_toDisplayString","_ctx"],"mappings":";;;;AAuBA,MAAKA,IAAU;AAAA,EACb,MAAM;AAAA,EACN,YAAY;AAAA,IACV,YAAYC;AAAA;EAEd,OAAO;AAAA,IACL,IAAI;AAAA,MACF,MAAM;AAAA,MACN,SAAS;AAAA;;EAGb,OAAO;AACL,WAAO;AAAA,MACL,YAAY;AAAA;EAEhB;AAAA,EACA,UAAU;AACR,SAAK,UAAS;AAAA,EAChB;AAAA,EACA,SAAS;AAAA,IACP,YAAY;AACV,WAAK,aAAaC,EAAoB,cAAc,KAAK,EAAE;AAAA,IAC7D;AAAA;EAEF,UAAU;AAAA,IACR,gBAAgB;AACd,aAAO,KAAK,eAAe;AAAA,IAC7B;AAAA;AAEJ;;;SAnCoBC,EAAA,WAAlBC,EAAuEC,GAAA;AAAA;IAAhD,KAAKC,EAAA;AAAA,IAAY,YAAW;AAAA;;mFCoBhDN,IAAU;AAAA,EACb,MAAM;AAAA,EACN,YAAY,EAAE,QAAAO,GAAQ,oBAAAC;EACtB,OAAO;AAAA,IACL,MAAM;AAAA,MACJ,MAAM;AAAA,MACN,SAAS;AAAA;IAEX,IAAI;AAAA,MACF,MAAM;AAAA,MACN,SAAS;AAAA;;EAGb,OAAO;AACL,WAAO;AAAA,MACL,KAAK;AAAA,MACL,OAAO;AAAA,MACP,UAAU;AAAA,MACV,OAAO;AAAA;EAEX;AAAA,EACA,UAAU;AACR,IAAI,KAAK,SAAS,SAChB,KAAK,QAAO;AAAA,EAEhB;AAAA,EACA,SAAS;AAAA,IACP,UAAU;AACR,UAAIC,IAAMP,EAAoB,cAAc,KAAK,EAAE;AACnD,UAAI,CAACO,GAAK;AACR,gBAAQ,MAAM,oBAAoB;AAClC;AAAA,MACF;AACA,YAAMC,IAAWC,EAAOF,CAAG;AAC3B,WAAK,MAAMC,EAAS,KACpB,KAAK,QAAQA,EAAS;AAAA,IACxB;AAAA;AAEJ;;EAtDoB,OAAM;GAGZE,IAAA,EAAA,OAAM,iBAAgB;;;SAPvBT,EAAA,SAAI,gBAAfU,EAEM,OAAAC,GAAA;AAAA,IADJC,EAA+BC,GAAA,EAAV,IAAIb,EAAA,GAAE,GAAA,MAAA,GAAA,CAAA,IAAA,CAAA;AAAA,QAEbA,EAAA,SAAI,cAApBU,EASM,OAAAI,GAAA;AAAA,IAROX,EAAA,OAAXY,KAAAL,EAOM,OAPNM,GAOM;AAAA,cANJN,EAKMO,GAAA,MAAAC,EALcf,EAAA,OAAK,CAAbgB,YAAZT,EAKM,OAAA,EALsB,KAAKS,KAAI;AAAA,QACnCP,EAAsEQ,GAAA;AAAA,UAA7D,KAAKjB,EAAA;AAAA,UAAM,MAAMgB;AAAA,UAAO,UAAUhB,EAAA;AAAA,UAAW,OAAOA,EAAA;AAAA;QAC7DkB,EAEC,QAFDZ,GAECa,EADIC,KAAE,yBAAA,EAAA,MAAkCJ,UAAahB,EAAA,MAAK,CAAA,CAAA,GAAA,CAAA;AAAA;;;;;"}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { openBlock as o, createElementBlock as a, Fragment as t, renderList as r, normalizeStyle as s, normalizeClass as p, createElementVNode as d, toDisplayString as u } from "vue";
|
|
2
|
+
import { _ as h } from "./index-DxH0-3Sq.js";
|
|
3
|
+
const b = {
|
|
4
|
+
name: "ExternalApps",
|
|
5
|
+
props: {
|
|
6
|
+
config: {
|
|
7
|
+
type: Array,
|
|
8
|
+
required: !0,
|
|
9
|
+
default: () => []
|
|
10
|
+
},
|
|
11
|
+
useFavicon: {
|
|
12
|
+
type: Boolean,
|
|
13
|
+
default: !1
|
|
14
|
+
}
|
|
15
|
+
},
|
|
16
|
+
computed: {
|
|
17
|
+
mappedItems() {
|
|
18
|
+
const e = {
|
|
19
|
+
calendar: { label: "Calendar", icon: "ri-calendar-line" },
|
|
20
|
+
chat: { label: "Chat", icon: "ri-chat-3-line" },
|
|
21
|
+
contacts: { label: "Contacts", icon: "ri-contacts-line" },
|
|
22
|
+
docs: { label: "Docs", icon: "ri-file-text-line" },
|
|
23
|
+
email: { label: "Email", icon: "ri-mail-line" },
|
|
24
|
+
storage: { label: "File storage", icon: "ri-folder-line" },
|
|
25
|
+
iam: { label: "IAM", icon: "ri-home-5-line" },
|
|
26
|
+
notes: { label: "Notes", icon: "ri-edit-line" },
|
|
27
|
+
projects: { label: "Projects", icon: "ri-focus-2-line" },
|
|
28
|
+
tasks: { label: "Tasks", icon: "ri-list-check-2" },
|
|
29
|
+
video: { label: "Video calls", icon: "ri-video-chat-line" },
|
|
30
|
+
wiki: { label: "Wiki", icon: "ri-lightbulb-line" },
|
|
31
|
+
other: { label: "Other", icon: "ri-question-line" }
|
|
32
|
+
};
|
|
33
|
+
return this.config.map((l) => {
|
|
34
|
+
const i = e[l.type] || {
|
|
35
|
+
label: l.type,
|
|
36
|
+
icon: "ri-question-line"
|
|
37
|
+
};
|
|
38
|
+
return {
|
|
39
|
+
...l,
|
|
40
|
+
label: l.value || i.label,
|
|
41
|
+
icon: i.icon,
|
|
42
|
+
customIcon: l.icon,
|
|
43
|
+
// User-selected icon
|
|
44
|
+
color: l.color
|
|
45
|
+
// User-selected color
|
|
46
|
+
};
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
},
|
|
50
|
+
methods: {
|
|
51
|
+
handleClick(e) {
|
|
52
|
+
window.open(e.link, "_blank");
|
|
53
|
+
},
|
|
54
|
+
getFaviconUrl(e) {
|
|
55
|
+
return `${new URL(
|
|
56
|
+
e.startsWith("http") ? e : window.location.origin + e
|
|
57
|
+
).origin}/favicon.ico`;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}, _ = { class: "external-apps-grid" }, f = ["onClick"], g = ["src"], k = { class: "external-app-label" };
|
|
61
|
+
function m(e, l, i, v, y, c) {
|
|
62
|
+
return o(), a("div", _, [
|
|
63
|
+
(o(!0), a(t, null, r(c.mappedItems, (n) => (o(), a("div", {
|
|
64
|
+
key: n.type,
|
|
65
|
+
class: "external-app-card",
|
|
66
|
+
onClick: (x) => c.handleClick(n)
|
|
67
|
+
}, [
|
|
68
|
+
i.useFavicon ? (o(), a("img", {
|
|
69
|
+
key: 0,
|
|
70
|
+
src: c.getFaviconUrl(n.link),
|
|
71
|
+
alt: "favicon",
|
|
72
|
+
class: "external-app-favicon",
|
|
73
|
+
width: "32",
|
|
74
|
+
height: "32"
|
|
75
|
+
}, null, 8, g)) : (o(), a("i", {
|
|
76
|
+
key: 1,
|
|
77
|
+
class: p([n.customIcon || n.icon, "external-app-icon"]),
|
|
78
|
+
style: s({
|
|
79
|
+
color: n.color ? `#${n.color}` : "var(--p-text-color)"
|
|
80
|
+
})
|
|
81
|
+
}, null, 6)),
|
|
82
|
+
d("span", k, u(n.label), 1)
|
|
83
|
+
], 8, f))), 128))
|
|
84
|
+
]);
|
|
85
|
+
}
|
|
86
|
+
const F = /* @__PURE__ */ h(b, [["render", m], ["__scopeId", "data-v-a950f8e4"]]);
|
|
87
|
+
export {
|
|
88
|
+
F as default
|
|
89
|
+
};
|
|
90
|
+
//# sourceMappingURL=ExternalApps-C24Qf4mq.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ExternalApps-C24Qf4mq.js","sources":["../src/components/dashboard/widgets/ExternalApps.vue"],"sourcesContent":["<!--\n Copyright (C) 2022 - Jeci SARL - https://jeci.fr\n\n This program is free software: you can redistribute it and/or modify\n it under the terms of the GNU Affero General Public License as\n published by the Free Software Foundation, either version 3 of the\n License, or (at your option) any later version.\n\n This program is distributed in the hope that it will be useful,\n but WITHOUT ANY WARRANTY; without even the implied warranty of\n MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n GNU Affero General Public License for more details.\n\n You should have received a copy of the GNU Affero General Public License\n along with this program. If not, see https://www.gnu.org/licenses/agpl-3.0.html.\n-->\n\n<template>\n <div class=\"external-apps-grid\">\n <div\n v-for=\"item in mappedItems\"\n :key=\"item.type\"\n class=\"external-app-card\"\n @click=\"handleClick(item)\"\n >\n <template v-if=\"useFavicon\">\n <img\n :src=\"getFaviconUrl(item.link)\"\n alt=\"favicon\"\n class=\"external-app-favicon\"\n width=\"32\"\n height=\"32\"\n />\n </template>\n <template v-else>\n <i\n :class=\"item.customIcon || item.icon\"\n class=\"external-app-icon\"\n :style=\"{\n color: item.color ? `#${item.color}` : 'var(--p-text-color)',\n }\"\n ></i>\n </template>\n <span class=\"external-app-label\">{{ item.label }}</span>\n </div>\n </div>\n</template>\n\n<script>\nexport default {\n name: \"ExternalApps\",\n props: {\n config: {\n type: Array,\n required: true,\n default: () => [],\n },\n useFavicon: {\n type: Boolean,\n default: false,\n },\n },\n computed: {\n mappedItems() {\n const typeMap = {\n calendar: { label: \"Calendar\", icon: \"ri-calendar-line\" },\n chat: { label: \"Chat\", icon: \"ri-chat-3-line\" },\n contacts: { label: \"Contacts\", icon: \"ri-contacts-line\" },\n docs: { label: \"Docs\", icon: \"ri-file-text-line\" },\n email: { label: \"Email\", icon: \"ri-mail-line\" },\n storage: { label: \"File storage\", icon: \"ri-folder-line\" },\n iam: { label: \"IAM\", icon: \"ri-home-5-line\" },\n notes: { label: \"Notes\", icon: \"ri-edit-line\" },\n projects: { label: \"Projects\", icon: \"ri-focus-2-line\" },\n tasks: { label: \"Tasks\", icon: \"ri-list-check-2\" },\n video: { label: \"Video calls\", icon: \"ri-video-chat-line\" },\n wiki: { label: \"Wiki\", icon: \"ri-lightbulb-line\" },\n other: { label: \"Other\", icon: \"ri-question-line\" },\n };\n\n return this.config.map((item) => {\n const mapping = typeMap[item.type] || {\n label: item.type,\n icon: \"ri-question-line\",\n };\n return {\n ...item,\n label: item.value || mapping.label,\n icon: mapping.icon,\n customIcon: item.icon, // User-selected icon\n color: item.color, // User-selected color\n };\n });\n },\n },\n methods: {\n handleClick(item) {\n window.open(item.link, \"_blank\");\n },\n getFaviconUrl(link) {\n const url = new URL(\n link.startsWith(\"http\") ? link : window.location.origin + link,\n );\n return `${url.origin}/favicon.ico`;\n },\n },\n};\n</script>\n\n<style scoped>\n.external-apps-grid {\n display: flex;\n flex-wrap: wrap;\n justify-content: center;\n gap: 0.75rem;\n}\n\n.external-app-card {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n border-radius: 0.5rem;\n padding: 0.5rem;\n background: var(--p-content-background);\n border: 1px solid var(--p-content-border-color);\n cursor: pointer;\n transition: transform 0.2s;\n width: 7rem;\n height: 7rem;\n}\n\n.external-app-card:hover {\n background: var(--p-highlight-background);\n}\n\n.external-app-favicon {\n margin-bottom: 0.5rem;\n object-fit: contain;\n}\n\n.external-app-icon {\n font-size: 1.75rem;\n margin-bottom: 0.5rem;\n}\n\n.external-app-label {\n font-size: 1rem;\n text-align: center;\n}\n</style>\n"],"names":["_sfc_main","typeMap","item","mapping","link","_hoisted_1","_hoisted_4","_openBlock","_createElementBlock","_Fragment","_renderList","$options","$event","$props","_normalizeClass","_normalizeStyle","_createElementVNode","_toDisplayString"],"mappings":";;AAiDA,MAAKA,IAAU;AAAA,EACb,MAAM;AAAA,EACN,OAAO;AAAA,IACL,QAAQ;AAAA,MACN,MAAM;AAAA,MACN,UAAU;AAAA,MACV,SAAS,MAAM,CAAA;AAAA;IAEjB,YAAY;AAAA,MACV,MAAM;AAAA,MACN,SAAS;AAAA;;EAGb,UAAU;AAAA,IACR,cAAc;AACZ,YAAMC,IAAU;AAAA,QACd,UAAU,EAAE,OAAO,YAAY,MAAM,mBAAiB;AAAA,QACtD,MAAM,EAAE,OAAO,QAAQ,MAAM;QAC7B,UAAU,EAAE,OAAO,YAAY,MAAM,mBAAiB;AAAA,QACtD,MAAM,EAAE,OAAO,QAAQ,MAAM;QAC7B,OAAO,EAAE,OAAO,SAAS,MAAM;QAC/B,SAAS,EAAE,OAAO,gBAAgB,MAAM,iBAAe;AAAA,QACvD,KAAK,EAAE,OAAO,OAAO,MAAM;QAC3B,OAAO,EAAE,OAAO,SAAS,MAAM;QAC/B,UAAU,EAAE,OAAO,YAAY,MAAM,kBAAgB;AAAA,QACrD,OAAO,EAAE,OAAO,SAAS,MAAM;QAC/B,OAAO,EAAE,OAAO,eAAe,MAAM,qBAAmB;AAAA,QACxD,MAAM,EAAE,OAAO,QAAQ,MAAM;QAC7B,OAAO,EAAE,OAAO,SAAS,MAAM;;AAGjC,aAAO,KAAK,OAAO,IAAI,CAACC,MAAS;AAC/B,cAAMC,IAAUF,EAAQC,EAAK,IAAI,KAAK;AAAA,UACpC,OAAOA,EAAK;AAAA,UACZ,MAAM;AAAA;AAER,eAAO;AAAA,UACL,GAAGA;AAAA,UACH,OAAOA,EAAK,SAASC,EAAQ;AAAA,UAC7B,MAAMA,EAAQ;AAAA,UACd,YAAYD,EAAK;AAAA;AAAA,UACjB,OAAOA,EAAK;AAAA;AAAA;MAEhB,CAAC;AAAA,IACH;AAAA;EAEF,SAAS;AAAA,IACP,YAAYA,GAAM;AAChB,aAAO,KAAKA,EAAK,MAAM,QAAQ;AAAA,IACjC;AAAA,IACA,cAAcE,GAAM;AAIlB,aAAO,GAHK,IAAI;AAAA,QACdA,EAAK,WAAW,MAAM,IAAIA,IAAO,OAAO,SAAS,SAASA;AAAA,QAE9C,MAAM;AAAA,IACtB;AAAA;AAEJ,GAxFOC,IAAA,EAAA,OAAM,qBAAoB,iCAyBrBC,IAAA,EAAA,OAAM,qBAAoB;;AAzBpC,SAAAC,EAAA,GAAAC,EA2BM,OA3BNH,GA2BM;AAAA,YA1BJG,EAyBMC,GAAA,MAAAC,EAxBWC,EAAA,aAAW,CAAnBT,YADTM,EAyBM,OAAA;AAAA,MAvBH,KAAKN,EAAK;AAAA,MACX,OAAM;AAAA,MACL,SAAK,CAAAU,MAAED,EAAA,YAAYT,CAAI;AAAA;MAERW,EAAA,mBACdL,EAME,OAAA;AAAA;QALC,KAAKG,EAAA,cAAcT,EAAK,IAAI;AAAA,QAC7B,KAAI;AAAA,QACJ,OAAM;AAAA,QACN,OAAM;AAAA,QACN,QAAO;AAAA,8BAITM,EAMK,KAAA;AAAA;QALF,OAAKM,EAAA,CAAEZ,EAAK,cAAcA,EAAK,MAC1B,mBAAmB,CAAA;AAAA,QACxB,OAAKa,EAAA;AAAA,UAAuB,OAAAb,EAAK,QAAK,IAAOA,EAAK,KAAK,KAAA;AAAA;;MAK5Dc,EAAwD,QAAxDV,GAAwDW,EAApBf,EAAK,KAAK,GAAA,CAAA;AAAA;;;;"}
|