@eodash/eodash 5.0.0-alpha.2.5 → 5.0.0-alpha.2.6
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/README.md +19 -5
- package/core/client/App.vue +6 -7
- package/core/client/SuspensedDashboard.ce.vue +58 -40
- package/core/client/asWebComponent.d.ts +10 -5
- package/core/client/asWebComponent.js +6 -6
- package/core/client/components/DashboardLayout.vue +35 -16
- package/core/client/components/DynamicWebComponent.vue +44 -44
- package/core/client/components/ErrorAlert.vue +19 -7
- package/core/client/components/Footer.vue +28 -14
- package/core/client/components/Header.vue +4 -4
- package/core/client/components/IframeWrapper.vue +3 -3
- package/core/client/components/Loading.vue +17 -18
- package/core/client/components/MobileLayout.vue +48 -26
- package/core/client/composables/DefineEodash.js +38 -29
- package/core/client/composables/DefineWidgets.js +101 -81
- package/core/client/composables/index.js +32 -29
- package/core/client/eodash.js +44 -39
- package/core/client/main.js +2 -2
- package/core/client/plugins/index.js +9 -10
- package/core/client/plugins/vuetify.js +9 -10
- package/core/client/render.js +4 -5
- package/core/client/store/States.js +8 -13
- package/core/client/store/index.js +14 -11
- package/core/client/store/stac.js +51 -37
- package/core/client/types.d.ts +169 -201
- package/core/client/utils/eodashSTAC.js +130 -49
- package/core/client/utils/helpers.js +18 -20
- package/core/client/utils/index.js +17 -10
- package/core/client/utils/keys.js +2 -2
- package/core/client/views/Dashboard.vue +53 -36
- package/core/client/vite-env.d.ts +19 -17
- package/dist/client/{DashboardLayout-BYROtP-7.js → DashboardLayout-BuDcv6LM.js} +9 -9
- package/dist/client/{DynamicWebComponent-BQhxFPM0.js → DynamicWebComponent-BEP4rVce.js} +2 -2
- package/dist/client/EodashDatePicker-oFb1zt5E.js +1211 -0
- package/dist/client/{EodashItemFilter-DIBDAHcc.js → EodashItemFilter-BElmgrST.js} +4 -6
- package/dist/client/{EodashMap-C6jJ2Lb_.js → EodashMap-DXyOgcEd.js} +13131 -14490
- package/dist/client/{Footer-BVIZms1S.js → Footer-CoPx6UXQ.js} +3 -3
- package/dist/client/{Header-TsTL1d2R.js → Header-C-zX31Ys.js} +169 -167
- package/dist/client/{IframeWrapper-XKChM78a.js → IframeWrapper-2w2ye0zM.js} +1 -1
- package/dist/client/{MobileLayout-BlGcMQra.js → MobileLayout-C9OVcP12.js} +45 -57
- package/dist/client/{VMain-C9XV5Lyg.js → VMain-Dm43jd43.js} +2 -2
- package/dist/client/{WidgetsContainer-BQXHnZpa.js → WidgetsContainer-BS87sLqk.js} +10 -3
- package/dist/client/{asWebComponent-CbdGxelK.js → asWebComponent-CpQUVi2N.js} +5508 -5561
- package/dist/client/{basedecoder-Qm25PwVp-CHo5Pomv.js → basedecoder-DHcBySSe-BmCFNFnw.js} +5 -6
- package/dist/client/{decoder-HRvnjnEI-CHAYOWhz.js → decoder-CP4lv0Kb-BHrv68IA.js} +1 -1
- package/dist/client/deflate-BXt-9JA_-CWfClgpK.js +10 -0
- package/dist/client/eo-dash.js +3 -3
- package/dist/client/eodashSTAC-Q7kbX1Gy.js +2788 -0
- package/dist/client/{eox-itemfilter-DcQkRD2l.js → eox-itemfilter-TaBxgqq_.js} +1002 -974
- package/dist/client/{eox-map-C3DL31fp.js → eox-map-L7abwKTR.js} +5677 -5695
- package/dist/client/{forwardRefs-CyCJOFsz.js → forwardRefs-BVFQ82G4.js} +12 -21
- package/dist/client/{index-CabQjjQg.js → index-dOzyv_xR.js} +1 -1
- package/dist/client/{jpeg-DNfUpLwy-Fjan-04T.js → jpeg-BAgeD1d3-oeHbFPUL.js} +5 -6
- package/dist/client/{lerc-_E46UbWQ-TxBH4OeK.js → lerc-DzVumYtB-rm1Xco54.js} +5 -7
- package/dist/client/{lzw-BOMhmEDy-Dboc93VO.js → lzw-LAGDNbSC-DkP96qO9.js} +1 -1
- package/dist/client/{packbits-DaUD6MLm-Bu1PoTGa.js → packbits-BlDR4Kj5-C66n1-zr.js} +1 -1
- package/dist/client/{pako.esm-C3kYPGGQ-BMki8cQY.js → pako.esm-CB1uQYY0-DB0PYm1P.js} +6 -12
- package/dist/client/{raw-CcGKjn8q-DFOt-i8n.js → raw-CMGvRjfu-BRi6E4i1.js} +1 -1
- package/dist/client/{ssrBoot-DWJ-z4I-.js → ssrBoot-L9KejErM.js} +1 -1
- package/dist/client/style.css +2 -2
- package/dist/client/{transition-BlLt41wg.js → transition-DCePIwYR.js} +1 -1
- package/dist/client/{webfontloader-CyOFAuFB.js → webfontloader-qotgY98I.js} +56 -92
- package/dist/client/{webimage-D2c098k3-DLj1LQxB.js → webimage-BM_pbLN3-L2cGWK5l.js} +1 -1
- package/dist/node/cli.js +1 -1
- package/dist/node/types.d.ts +32 -38
- package/package.json +11 -11
- package/widgets/EodashDatePicker.vue +94 -43
- package/widgets/EodashItemFilter.vue +13 -10
- package/widgets/EodashMap.vue +87 -20
- package/widgets/WidgetsContainer.vue +45 -27
- package/dist/client/EodashDatePicker-CFltnt5d.js +0 -1194
- package/dist/client/deflate-Be2Arps5-hDqMz3RA.js +0 -10
- package/dist/client/http-ZWiLaAeR.js +0 -1337
package/README.md
CHANGED
|
@@ -1,45 +1,59 @@
|
|
|
1
1
|
# @eodash/eodash [](https://www.npmjs.com/package/@eodash/eodash)
|
|
2
2
|
|
|
3
3
|
A package for creating earth observation dashboards. To learn more about eodash ecosystem visit [eodash.org](https://eodash.org)
|
|
4
|
+
|
|
4
5
|
## Usage
|
|
6
|
+
|
|
5
7
|
Checkout the [documentation](https://eodash.github.io/eodash/get-started.html) for a detailed guide.
|
|
6
8
|
|
|
7
9
|
## Get Started
|
|
10
|
+
|
|
8
11
|
Install all the required dependecies after cloning or downloading the repository using Node v18 or higher:
|
|
12
|
+
|
|
9
13
|
```bash
|
|
10
14
|
npm run install
|
|
11
15
|
```
|
|
16
|
+
|
|
12
17
|
Run the dev server:
|
|
18
|
+
|
|
13
19
|
```bash
|
|
14
20
|
npm run dev
|
|
15
21
|
```
|
|
22
|
+
|
|
16
23
|
To compile and minify a demo instance:
|
|
24
|
+
|
|
17
25
|
```bash
|
|
18
26
|
npm run build
|
|
19
27
|
```
|
|
28
|
+
|
|
20
29
|
To preview the compiled production files :
|
|
30
|
+
|
|
21
31
|
```bash
|
|
22
32
|
npm run preview
|
|
23
33
|
```
|
|
34
|
+
|
|
24
35
|
To compile and minify a demo instance as a web component library:
|
|
36
|
+
|
|
25
37
|
```bash
|
|
26
38
|
npm run build -- --lib
|
|
27
39
|
```
|
|
28
40
|
|
|
29
41
|
## Folder Structure
|
|
42
|
+
|
|
30
43
|
.
|
|
31
|
-
├── core # CLI & Client source code
|
|
44
|
+
├── core # CLI & Client source code
|
|
32
45
|
├── docs # Documentation files
|
|
33
46
|
├── tests # CLI & Client component tests folder
|
|
34
47
|
├── widgets # Vue componenets as internal widgets.
|
|
35
48
|
├── public # Statically served directory
|
|
36
49
|
└── README.md
|
|
37
50
|
|
|
38
|
-
|
|
39
51
|
## Writing commits
|
|
52
|
+
|
|
40
53
|
To ensure clear communication with the package consumers and enable machine-readable commits, we adhere to [The Conventional Commits](https://www.conventionalcommits.org/) specification that allows the generation of [semVer](https://semver.org) releases and associated change logs using [googleapis/release-please](https://github.com/googleapis/release-please).
|
|
41
54
|
|
|
42
55
|
The most important prefixes you should have in mind are:
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
56
|
+
|
|
57
|
+
- fix: which represents bug fixes, and correlates to a SemVer patch.
|
|
58
|
+
- feat: which represents a new feature, and correlates to a SemVer minor.
|
|
59
|
+
- feat!:, or fix!:, refactor!:, etc., which represent a breaking change (indicated by the !) and will result in a SemVer major.
|
package/core/client/App.vue
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<v-app>
|
|
3
3
|
<Suspense>
|
|
4
|
-
|
|
5
4
|
<Dashboard />
|
|
6
5
|
|
|
7
6
|
<template #fallback>
|
|
@@ -12,16 +11,16 @@
|
|
|
12
11
|
</template>
|
|
13
12
|
|
|
14
13
|
<script setup>
|
|
15
|
-
import Dashboard from
|
|
16
|
-
import ErrorAlert from
|
|
17
|
-
import { onErrorCaptured, ref } from
|
|
14
|
+
import Dashboard from "@/views/Dashboard.vue";
|
|
15
|
+
import ErrorAlert from "./components/ErrorAlert.vue";
|
|
16
|
+
import { onErrorCaptured, ref } from "vue";
|
|
18
17
|
|
|
19
|
-
const error = ref(
|
|
18
|
+
const error = ref("");
|
|
20
19
|
onErrorCaptured((e, inst, info) => {
|
|
21
20
|
error.value = `
|
|
22
21
|
${e}.
|
|
23
22
|
component: ${inst?.$.type.name}.
|
|
24
23
|
info: ${info}.
|
|
25
|
-
|
|
26
|
-
})
|
|
24
|
+
`;
|
|
25
|
+
});
|
|
27
26
|
</script>
|
|
@@ -10,78 +10,96 @@
|
|
|
10
10
|
</v-app>
|
|
11
11
|
</template>
|
|
12
12
|
<script setup>
|
|
13
|
-
import Dashboard from
|
|
14
|
-
import { createApp, getCurrentInstance, onErrorCaptured, ref } from "vue"
|
|
15
|
-
import { registerPlugins } from
|
|
16
|
-
import { eodashKey } from
|
|
17
|
-
import ErrorAlert from
|
|
13
|
+
import Dashboard from "@/views/Dashboard.vue";
|
|
14
|
+
import { createApp, getCurrentInstance, onErrorCaptured, ref } from "vue";
|
|
15
|
+
import { registerPlugins } from "@/plugins";
|
|
16
|
+
import { eodashKey } from "@/utils/keys";
|
|
17
|
+
import ErrorAlert from "@/components/ErrorAlert.vue";
|
|
18
18
|
|
|
19
19
|
defineProps({
|
|
20
20
|
config: {
|
|
21
21
|
type: String,
|
|
22
|
-
}
|
|
22
|
+
},
|
|
23
23
|
});
|
|
24
24
|
|
|
25
|
-
/** @type {
|
|
26
|
-
const vAppRef = ref(null)
|
|
27
|
-
const app = createApp({})
|
|
28
|
-
registerPlugins(app)
|
|
25
|
+
/** @type {import("vue").Ref<import("vuetify/components").VApp | null>} */
|
|
26
|
+
const vAppRef = ref(null);
|
|
27
|
+
const app = createApp({});
|
|
28
|
+
registerPlugins(app);
|
|
29
|
+
|
|
30
|
+
const inst = getCurrentInstance();
|
|
31
|
+
|
|
32
|
+
Object.assign(inst?.appContext ?? {}, app._context);
|
|
29
33
|
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
Object.assign(inst.appContext, app._context)
|
|
33
|
-
//@ts-expect-error
|
|
34
|
-
Object.assign(inst.provides, app._context.provides)
|
|
34
|
+
//@ts-expect-error Property 'provides' does not exist on type 'ComponentInternalInstance'
|
|
35
|
+
Object.assign(inst?.provides ?? {}, app._context.provides);
|
|
35
36
|
|
|
36
|
-
/**
|
|
37
|
+
/**
|
|
38
|
+
* @param {import("vue").Ref<
|
|
39
|
+
* HTMLElement | import("vue").ComponentPublicInstance
|
|
40
|
+
* >[]} [hiddenElements]
|
|
41
|
+
*/
|
|
37
42
|
function setStylesFromHead(hiddenElements) {
|
|
38
|
-
const eodashShadowRoot = vAppRef.value?.$el.getRootNode()
|
|
39
|
-
const styleSheet = new CSSStyleSheet()
|
|
40
|
-
const head = document.querySelector(
|
|
41
|
-
let stylesStr =
|
|
43
|
+
const eodashShadowRoot = vAppRef.value?.$el.getRootNode();
|
|
44
|
+
const styleSheet = new CSSStyleSheet();
|
|
45
|
+
const head = document.querySelector("head");
|
|
46
|
+
let stylesStr = "";
|
|
42
47
|
|
|
43
48
|
Array.from(head?.children ?? []).forEach((child) => {
|
|
44
|
-
if (child.getAttribute(
|
|
45
|
-
stylesStr += `\n ${child.innerHTML}
|
|
46
|
-
return
|
|
49
|
+
if (child.getAttribute("type") === "text/css") {
|
|
50
|
+
stylesStr += `\n ${child.innerHTML}`;
|
|
51
|
+
return;
|
|
47
52
|
}
|
|
48
53
|
|
|
49
|
-
if (
|
|
50
|
-
|
|
54
|
+
if (
|
|
55
|
+
child.tagName == "LINK" &&
|
|
56
|
+
child.getAttribute("rel")?.includes("stylesheet")
|
|
57
|
+
) {
|
|
58
|
+
eodashShadowRoot?.appendChild(child.cloneNode(true));
|
|
51
59
|
}
|
|
52
60
|
});
|
|
53
61
|
|
|
54
62
|
stylesStr += `\n
|
|
55
|
-
${
|
|
56
|
-
|
|
57
|
-
|
|
63
|
+
${
|
|
64
|
+
//@ts-expect-error Property 'provides' does not exist on type 'ComponentInternalInstance'
|
|
65
|
+
/** @type {import("@/types").Eodash} */ (inst?.provides[eodashKey])
|
|
66
|
+
?.brand.noLayout
|
|
67
|
+
? `div.v-application__wrap {
|
|
58
68
|
min-height: fit-content;
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
|
|
69
|
+
}`
|
|
70
|
+
: ""
|
|
71
|
+
}
|
|
72
|
+
`;
|
|
73
|
+
styleSheet.replaceSync(stylesStr.replaceAll(":root", ":host"));
|
|
62
74
|
eodashShadowRoot?.adoptedStyleSheets.push(styleSheet);
|
|
63
75
|
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
76
|
+
if (
|
|
77
|
+
hiddenElements &&
|
|
78
|
+
!(
|
|
79
|
+
//@ts-expect-error Property 'provides' does not exist on type 'ComponentInternalInstance'
|
|
80
|
+
/** @type {import("@/types").Eodash} */ (inst.provides[eodashKey])?.brand
|
|
81
|
+
.noLayout
|
|
82
|
+
)
|
|
83
|
+
) {
|
|
84
|
+
hiddenElements.forEach((element) => {
|
|
67
85
|
if (element.value) {
|
|
68
86
|
if (element.value instanceof HTMLElement) {
|
|
69
|
-
element.value.style.opacity = "1"
|
|
87
|
+
element.value.style.opacity = "1";
|
|
70
88
|
} else {
|
|
71
89
|
/** @type {HTMLElement} */
|
|
72
|
-
(element.value.$el).style.opacity = "1"
|
|
90
|
+
(element.value.$el).style.opacity = "1";
|
|
73
91
|
}
|
|
74
92
|
}
|
|
75
|
-
})
|
|
93
|
+
});
|
|
76
94
|
}
|
|
77
95
|
}
|
|
78
96
|
|
|
79
|
-
const error = ref(
|
|
97
|
+
const error = ref("");
|
|
80
98
|
onErrorCaptured((e, comp, info) => {
|
|
81
99
|
error.value = `
|
|
82
100
|
${e}.
|
|
83
101
|
component: ${comp?.$.type.name}.
|
|
84
102
|
info: ${info}.
|
|
85
|
-
|
|
86
|
-
})
|
|
103
|
+
`;
|
|
104
|
+
});
|
|
87
105
|
</script>
|
|
@@ -1,18 +1,23 @@
|
|
|
1
1
|
/** @group WebComponent */
|
|
2
|
-
type EodashConstructor = import("vue").VueElementConstructor<
|
|
2
|
+
type EodashConstructor = import("vue").VueElementConstructor<
|
|
3
|
+
import("vue").ExtractPropTypes<{ config: string }>
|
|
4
|
+
>;
|
|
3
5
|
/**
|
|
4
|
-
*
|
|
6
|
+
* Eodash Web Component constructor
|
|
7
|
+
*
|
|
5
8
|
* @group WebComponent
|
|
6
9
|
*/
|
|
7
|
-
export declare const Eodash: EodashConstructor
|
|
10
|
+
export declare const Eodash: EodashConstructor;
|
|
8
11
|
/**
|
|
9
12
|
* Registers `eo-dash` as Custom Element in the window
|
|
13
|
+
*
|
|
10
14
|
* @group WebComponent
|
|
11
15
|
*/
|
|
12
|
-
export declare function register(): void
|
|
16
|
+
export declare function register(): void;
|
|
13
17
|
|
|
14
18
|
/**
|
|
15
19
|
* Eodash store @see EodashStore
|
|
20
|
+
*
|
|
16
21
|
* @group WebComponent
|
|
17
22
|
*/
|
|
18
|
-
export declare const store: import("./types").EodashStore
|
|
23
|
+
export declare const store: import("./types").EodashStore;
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import SuspensedDashboard from
|
|
2
|
-
import { defineCustomElement } from
|
|
1
|
+
import SuspensedDashboard from "./SuspensedDashboard.ce.vue";
|
|
2
|
+
import { defineCustomElement } from "vue";
|
|
3
3
|
/** @type {import("./asWebComponent").EodashConstructor} */
|
|
4
|
-
export const Eodash = defineCustomElement(SuspensedDashboard)
|
|
4
|
+
export const Eodash = defineCustomElement(SuspensedDashboard);
|
|
5
5
|
|
|
6
6
|
export function register() {
|
|
7
|
-
customElements.define(
|
|
7
|
+
customElements.define("eo-dash", Eodash);
|
|
8
8
|
}
|
|
9
9
|
|
|
10
|
-
export { default as store } from
|
|
10
|
+
export { default as store } from "@/store";
|
|
11
11
|
|
|
12
|
-
register()
|
|
12
|
+
register();
|
|
@@ -1,19 +1,39 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<v-main>
|
|
3
3
|
<eox-layout :gap="eodash.template.gap ?? 2">
|
|
4
|
-
<eox-layout-item
|
|
4
|
+
<eox-layout-item
|
|
5
|
+
v-if="bgWidget.component"
|
|
6
|
+
class="bg-panel"
|
|
7
|
+
x="0"
|
|
8
|
+
y="0"
|
|
9
|
+
h="12"
|
|
10
|
+
w="12"
|
|
11
|
+
>
|
|
5
12
|
<Suspense suspensible>
|
|
6
|
-
<component
|
|
13
|
+
<component
|
|
14
|
+
id="bg-widget"
|
|
15
|
+
:is="bgWidget.component"
|
|
16
|
+
v-bind="bgWidget.props"
|
|
17
|
+
/>
|
|
7
18
|
</Suspense>
|
|
8
19
|
</eox-layout-item>
|
|
9
20
|
<template v-for="(importedWidget, idx) in importedWidgets" :key="idx">
|
|
10
21
|
<Transition name="fade">
|
|
11
|
-
<eox-layout-item
|
|
12
|
-
|
|
13
|
-
:
|
|
22
|
+
<eox-layout-item
|
|
23
|
+
v-if="importedWidget.value.component"
|
|
24
|
+
:key="importedWidget.value.id"
|
|
25
|
+
class="panel"
|
|
26
|
+
:h="importedWidget.value.layout.h"
|
|
27
|
+
:w="importedWidget.value.layout.w"
|
|
28
|
+
:x="importedWidget.value.layout.x"
|
|
29
|
+
:y="importedWidget.value.layout.y"
|
|
30
|
+
>
|
|
14
31
|
<Suspense suspensible>
|
|
15
|
-
<component
|
|
16
|
-
|
|
32
|
+
<component
|
|
33
|
+
:key="importedWidget.value.id"
|
|
34
|
+
:is="importedWidget.value.component"
|
|
35
|
+
v-bind="importedWidget.value.props"
|
|
36
|
+
/>
|
|
17
37
|
</Suspense>
|
|
18
38
|
</eox-layout-item>
|
|
19
39
|
</Transition>
|
|
@@ -22,16 +42,16 @@
|
|
|
22
42
|
</v-main>
|
|
23
43
|
</template>
|
|
24
44
|
<script setup>
|
|
25
|
-
import { eodashKey } from
|
|
26
|
-
import { inject } from
|
|
27
|
-
import { useDefineWidgets } from
|
|
28
|
-
import
|
|
45
|
+
import { eodashKey } from "@/utils/keys";
|
|
46
|
+
import { inject } from "vue";
|
|
47
|
+
import { useDefineWidgets } from "@/composables/DefineWidgets";
|
|
48
|
+
import "@eox/layout";
|
|
29
49
|
|
|
30
|
-
const eodash = /** @type {import("@/types").Eodash} */ (inject(eodashKey))
|
|
50
|
+
const eodash = /** @type {import("@/types").Eodash} */ (inject(eodashKey));
|
|
31
51
|
|
|
32
|
-
const [bgWidget] = useDefineWidgets([eodash.template?.background])
|
|
52
|
+
const [bgWidget] = useDefineWidgets([eodash.template?.background]);
|
|
33
53
|
|
|
34
|
-
const importedWidgets = useDefineWidgets(eodash.template?.widgets)
|
|
54
|
+
const importedWidgets = useDefineWidgets(eodash.template?.widgets);
|
|
35
55
|
</script>
|
|
36
56
|
<style scoped>
|
|
37
57
|
.panel {
|
|
@@ -39,12 +59,11 @@ const importedWidgets = useDefineWidgets(eodash.template?.widgets)
|
|
|
39
59
|
overflow: visible;
|
|
40
60
|
z-index: 1;
|
|
41
61
|
border-radius: 0px;
|
|
42
|
-
background: rgb(var(--v-theme-surface))
|
|
62
|
+
background: rgb(var(--v-theme-surface));
|
|
43
63
|
}
|
|
44
64
|
|
|
45
65
|
.bg-panel {
|
|
46
66
|
z-index: 0;
|
|
47
|
-
|
|
48
67
|
}
|
|
49
68
|
|
|
50
69
|
.fade-enter-active,
|
|
@@ -5,64 +5,64 @@
|
|
|
5
5
|
</template>
|
|
6
6
|
|
|
7
7
|
<script async setup>
|
|
8
|
-
import { useSTAcStore } from
|
|
9
|
-
import {
|
|
10
|
-
|
|
11
|
-
onMounted as whenMounted
|
|
12
|
-
} from 'vue';
|
|
13
|
-
import { ref } from 'vue';
|
|
8
|
+
import { useSTAcStore } from "@/store/stac";
|
|
9
|
+
import { onUnmounted as whenUnMounted, onMounted as whenMounted } from "vue";
|
|
10
|
+
import { ref } from "vue";
|
|
14
11
|
|
|
15
|
-
const props =
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
12
|
+
const props = /** @type {import("@/types").WebComponentProps} */ (
|
|
13
|
+
defineProps({
|
|
14
|
+
link: {
|
|
15
|
+
type: [String, Function],
|
|
16
|
+
required: true,
|
|
17
|
+
},
|
|
18
|
+
constructorProp: String,
|
|
19
|
+
tagName: {
|
|
20
|
+
type: String,
|
|
21
|
+
required: true,
|
|
22
|
+
},
|
|
23
|
+
properties: {
|
|
24
|
+
type: Object,
|
|
25
|
+
default: () => {
|
|
26
|
+
return {};
|
|
27
|
+
},
|
|
28
|
+
},
|
|
29
|
+
onMounted: Function,
|
|
30
|
+
onUnmounted: Function,
|
|
31
|
+
})
|
|
32
|
+
);
|
|
34
33
|
|
|
34
|
+
const getWebComponent = async () =>
|
|
35
|
+
typeof props.link === "string"
|
|
36
|
+
? await import(/* @vite-ignore */ props.link)
|
|
37
|
+
: await props.link();
|
|
35
38
|
|
|
36
|
-
const
|
|
37
|
-
await
|
|
39
|
+
const imported = !customElements.get(props.tagName)
|
|
40
|
+
? await getWebComponent().catch((e) => {
|
|
41
|
+
console.error(e);
|
|
42
|
+
})
|
|
43
|
+
: null;
|
|
38
44
|
|
|
39
|
-
const
|
|
40
|
-
console.error(e)
|
|
41
|
-
}) : null
|
|
42
|
-
|
|
43
|
-
const defined = customElements.get(props.tagName)
|
|
45
|
+
const defined = customElements.get(props.tagName);
|
|
44
46
|
|
|
45
47
|
// if the imported link doesn't define the custom tag provided
|
|
46
48
|
if (!defined && props.constructorProp) {
|
|
47
|
-
const Constructor = imported[props.constructorProp]
|
|
48
|
-
customElements.define(props.tagName, Constructor)
|
|
49
|
+
const Constructor = imported[props.constructorProp];
|
|
50
|
+
customElements.define(props.tagName, Constructor);
|
|
49
51
|
}
|
|
50
52
|
|
|
51
|
-
const store = useSTAcStore()
|
|
53
|
+
const store = useSTAcStore();
|
|
52
54
|
|
|
53
55
|
/**
|
|
54
|
-
*
|
|
55
|
-
*
|
|
56
|
-
* @type {import('vue').Ref<CustomElement|null>}
|
|
56
|
+
* @typedef {HTMLElement & Record<string | number | symbol, unknown>} CustomElement
|
|
57
|
+
* @type {import("vue").Ref<CustomElement | null>}
|
|
57
58
|
*/
|
|
58
|
-
const elementRef = ref(null)
|
|
59
|
-
|
|
59
|
+
const elementRef = ref(null);
|
|
60
60
|
|
|
61
61
|
whenMounted(() => {
|
|
62
|
-
props.onMounted?.(elementRef.value, store)
|
|
63
|
-
})
|
|
62
|
+
props.onMounted?.(elementRef.value, store);
|
|
63
|
+
});
|
|
64
64
|
|
|
65
65
|
whenUnMounted(() => {
|
|
66
|
-
props.onUnmounted?.(elementRef.value, store)
|
|
67
|
-
})
|
|
66
|
+
props.onUnmounted?.(elementRef.value, store);
|
|
67
|
+
});
|
|
68
68
|
</script>
|
|
@@ -1,21 +1,33 @@
|
|
|
1
1
|
<template>
|
|
2
|
-
<v-alert
|
|
3
|
-
|
|
2
|
+
<v-alert
|
|
3
|
+
v-if="error"
|
|
4
|
+
translate="yes"
|
|
5
|
+
location="start bottom"
|
|
6
|
+
type="error"
|
|
7
|
+
position="fixed"
|
|
8
|
+
@click:close="error = ''"
|
|
9
|
+
variant="elevated"
|
|
10
|
+
:icon="[mdiAlertCircle]"
|
|
11
|
+
class="alert"
|
|
12
|
+
closable
|
|
13
|
+
:close-icon="[mdiClose]"
|
|
14
|
+
>
|
|
4
15
|
{{ errorMessage }}
|
|
5
16
|
<details is="animated-details">
|
|
6
|
-
<summary>
|
|
17
|
+
<summary>Error</summary>
|
|
7
18
|
{{ error }}
|
|
8
19
|
</details>
|
|
9
20
|
</v-alert>
|
|
10
21
|
</template>
|
|
11
22
|
<script setup>
|
|
12
23
|
import { eodashKey } from "@/utils/keys";
|
|
13
|
-
import { mdiClose, mdiAlertCircle } from "@mdi/js"
|
|
24
|
+
import { mdiClose, mdiAlertCircle } from "@mdi/js";
|
|
14
25
|
import { inject } from "vue";
|
|
15
26
|
|
|
16
|
-
const error = defineModel({ type: String, required: true })
|
|
17
|
-
const eodash = /** @type {import("@/types").Eodash} */(inject(eodashKey))
|
|
18
|
-
const errorMessage =
|
|
27
|
+
const error = defineModel({ type: String, required: true });
|
|
28
|
+
const eodash = /** @type {import("@/types").Eodash} */ (inject(eodashKey));
|
|
29
|
+
const errorMessage =
|
|
30
|
+
eodash.brand.errorMessage ?? "something went wrong, please try again later";
|
|
19
31
|
</script>
|
|
20
32
|
<style scoped>
|
|
21
33
|
.alert {
|
|
@@ -1,33 +1,47 @@
|
|
|
1
1
|
<template>
|
|
2
|
-
<v-footer
|
|
3
|
-
|
|
2
|
+
<v-footer
|
|
3
|
+
ref="footer"
|
|
4
|
+
:height="mdAndDown ? '48px' : 'auto'"
|
|
5
|
+
color="secondary"
|
|
6
|
+
app
|
|
7
|
+
class="d-flex justify-space-between"
|
|
8
|
+
>
|
|
4
9
|
<p class="pt-0 footer-text">
|
|
5
10
|
{{ eodash.brand.footerText ?? "" }}
|
|
6
11
|
</p>
|
|
7
12
|
<div>
|
|
8
|
-
<a
|
|
13
|
+
<a
|
|
14
|
+
href="https://github.com/eodash/eodash"
|
|
15
|
+
class="text-white"
|
|
16
|
+
target="_blank"
|
|
17
|
+
>eodash</a
|
|
18
|
+
>
|
|
19
|
+
by
|
|
9
20
|
<a href="https://eox.at" target="_blank" class="text-white">
|
|
10
|
-
<img :src=
|
|
21
|
+
<img :src="`data:image/svg+xml;base64,${base64Logo}`" height="11px" />
|
|
11
22
|
</a>
|
|
12
23
|
</div>
|
|
13
24
|
</v-footer>
|
|
14
25
|
</template>
|
|
15
26
|
<script setup>
|
|
16
|
-
import { eodashKey } from
|
|
17
|
-
import { ref } from
|
|
18
|
-
import { inject } from
|
|
19
|
-
import { useDisplay } from
|
|
27
|
+
import { eodashKey } from "@/utils/keys";
|
|
28
|
+
import { ref } from "vue";
|
|
29
|
+
import { inject } from "vue";
|
|
30
|
+
import { useDisplay } from "vuetify/lib/framework.mjs";
|
|
20
31
|
|
|
21
32
|
/**
|
|
22
33
|
* Footer template ref
|
|
23
|
-
*
|
|
34
|
+
*
|
|
35
|
+
* @type {import("vue").Ref<
|
|
36
|
+
* import("vuetify/lib/components/index.mjs").VFooter | null
|
|
37
|
+
* >}
|
|
24
38
|
*/
|
|
25
|
-
const footer = ref(null)
|
|
26
|
-
const eodash = /** @type {import("@/types").Eodash} */(inject(eodashKey))
|
|
39
|
+
const footer = ref(null);
|
|
40
|
+
const eodash = /** @type {import("@/types").Eodash} */ (inject(eodashKey));
|
|
27
41
|
|
|
28
|
-
const { mdAndDown } = useDisplay()
|
|
29
|
-
const eoxLogo = `<svg width="100%" height="100%" viewBox="0 0 355 85" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" xmlns:serif="http://www.serif.com/" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linejoin:round;stroke-miterlimit:1.41421;"><g id="ink_ext_XXXXXX"><path id="path5076" d="M152.986,40.52l-0.75,-0.019l-0.737,-0.056l-0.725,-0.093l-0.713,-0.127l-0.7,-0.162l-0.7,-0.196l-0.675,-0.228l-0.65,-0.261l-0.65,-0.292l-0.625,-0.319l-0.612,-0.352l-0.588,-0.377l-0.562,-0.407l-0.55,-0.431l-0.538,-0.457l-0.5,-0.481l-0.487,-0.505l-0.45,-0.528l-0.438,-0.55l-0.4,-0.57l-0.375,-0.59l-0.35,-0.609l-0.325,-0.627l-0.287,-0.645l-0.263,-0.66l-0.225,-0.676l-0.2,-0.69l-0.162,-0.704l-0.125,-0.717l-0.1,-0.728l-0.05,-0.739l-0.025,-0.748c0,-8.023 6.512,-14.532 14.537,-14.532c8.038,0 14.538,6.509 14.538,14.532c0,8.036 -6.5,14.544 -14.538,14.544Z" style="fill:none;"/><path id="path5078" d="M165.748,-0.002c-42.009,0 -76.06,18.985 -76.06,42.402c0,13.268 10.921,25.102 28.021,32.875c-8.081,-5.487 -13.403,-12.973 -14.584,-21.859c-2.685,-20.186 16.83,-40.82 45.148,-49.615c-14.687,6.665 -24.923,21.427 -24.923,38.599c0,23.218 18.648,42.046 41.773,42.383c-0.037,0.005 -0.087,0.015 -0.137,0.02c0.263,0 0.512,0.009 0.762,0.009c42.013,0 76.076,-18.984 76.076,-42.412c0,-13.261 -10.937,-25.097 -28.037,-32.871l0.75,0.522l0.736,0.531l0.713,0.543l0.7,0.555l0.687,0.566l0.664,0.578l0.649,0.588l0.625,0.6l0.613,0.609l0.588,0.621l0.574,0.631l0.562,0.643l0.538,0.652l0.513,0.662l0.5,0.672l0.475,0.684l0.449,0.693l0.438,0.703l0.425,0.713l0.387,0.723l0.375,0.73l0.352,0.74l0.336,0.75l0.3,0.76l0.287,0.77l0.264,0.777l0.25,0.787l0.211,0.795l0.188,0.805l0.175,0.812l0.151,0.82l0.125,0.831c2.675,20.19 -16.838,40.825 -45.151,49.619c14.688,-6.665 24.926,-21.426 24.926,-38.614c0,-23.202 -18.65,-42.026 -41.775,-42.367c0.05,-0.005 0.1,-0.015 0.15,-0.025c-0.262,0 -0.526,-0.01 -0.789,-0.01Zm-13.248,11.314c7.817,0 14.25,6.433 14.25,14.25c0,0.001 0,0.001 0,0.001c0,7.817 -6.433,14.249 -14.25,14.249c-7.817,0 -14.25,-6.432 -14.25,-14.249c0,-0.001 0,-0.001 0,-0.001c0,-7.817 6.433,-14.25 14.25,-14.25Z" style="fill:#fff;fill-rule:nonzero;"/><path id="path5080" d="M213.786,9.529l0.75,0.521l0.738,0.532l0.712,0.544l0.7,0.555l0.688,0.566l0.662,0.577l0.65,0.588l0.625,0.6l0.613,0.61l0.587,0.62l0.575,0.631l0.563,0.643l0.537,0.652l0.513,0.663l0.5,0.672l0.475,0.684l0.45,0.692l0.437,0.703l0.425,0.712l0.388,0.723l0.375,0.731l0.35,0.741l0.337,0.75l0.3,0.76l0.288,0.769l0.262,0.777l0.25,0.786l0.213,0.797l0.187,0.804l0.175,0.812l0.15,0.821l0.125,0.83c2.675,20.19 -16.837,40.825 -45.15,49.619c14.688,-6.665 24.925,-21.426 24.925,-38.614c0,-23.202 -18.65,-42.025 -41.775,-42.367c0.05,-0.005 0.1,-0.015 0.15,-0.025c-0.262,0 -0.525,-0.01 -0.787,-0.01c-42.01,0 -76.062,18.985 -76.062,42.402c0,13.268 10.922,25.103 28.022,32.876c-8.081,-5.487 -13.403,-12.973 -14.584,-21.859c-2.685,-20.187 16.831,-40.82 45.149,-49.615c-14.688,6.665 -24.925,21.426 -24.925,38.598c0,23.218 18.65,42.046 41.775,42.383c-0.038,0.005 -0.088,0.015 -0.138,0.02c0.263,0 0.513,0.01 0.763,0.01c42.012,-0.001 76.075,-18.985 76.075,-42.413c0,-13.261 -10.938,-25.097 -28.038,-32.871Z" style="fill:none;"/><path id="path5082" d="M354.323,82.586l-41.999,-42.002l38.524,-38.515l-29.913,0l-23.562,23.559l-23.563,-23.559l-29.924,0l38.525,38.515l-42,42.002l29.913,0l27.049,-27.046l27.05,27.046l29.9,0" style="fill:#fff;fill-rule:nonzero;"/><path id="path5084" d="M354.323,82.586l-41.999,-42.002l38.524,-38.515l-29.913,0l-23.562,23.559l-23.563,-23.559l-29.924,0l38.525,38.515l-42,42.002l29.913,0l27.049,-27.046l27.05,27.046l29.9,0Z" style="fill:none;"/><path id="path5086" d="M0,2.069l75.033,0l0,16.489l-51.629,0l0,14.931l40.258,0l0,16.495l-40.258,0l0,16.05l53.124,0l0,16.488l-76.528,0l0,-80.453" style="fill:#fff;fill-rule:nonzero;"/><path id="path5088" d="M0,2.069l75.033,0l0,16.489l-51.629,0l0,14.931l40.258,0l0,16.495l-40.258,0l0,16.05l53.124,0l0,16.488l-76.528,0l0,-80.453Z" style="fill:none;"/></g></svg
|
|
30
|
-
const base64Logo = window.btoa(eoxLogo)
|
|
42
|
+
const { mdAndDown } = useDisplay();
|
|
43
|
+
const eoxLogo = `<svg width="100%" height="100%" viewBox="0 0 355 85" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" xmlns:serif="http://www.serif.com/" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linejoin:round;stroke-miterlimit:1.41421;"><g id="ink_ext_XXXXXX"><path id="path5076" d="M152.986,40.52l-0.75,-0.019l-0.737,-0.056l-0.725,-0.093l-0.713,-0.127l-0.7,-0.162l-0.7,-0.196l-0.675,-0.228l-0.65,-0.261l-0.65,-0.292l-0.625,-0.319l-0.612,-0.352l-0.588,-0.377l-0.562,-0.407l-0.55,-0.431l-0.538,-0.457l-0.5,-0.481l-0.487,-0.505l-0.45,-0.528l-0.438,-0.55l-0.4,-0.57l-0.375,-0.59l-0.35,-0.609l-0.325,-0.627l-0.287,-0.645l-0.263,-0.66l-0.225,-0.676l-0.2,-0.69l-0.162,-0.704l-0.125,-0.717l-0.1,-0.728l-0.05,-0.739l-0.025,-0.748c0,-8.023 6.512,-14.532 14.537,-14.532c8.038,0 14.538,6.509 14.538,14.532c0,8.036 -6.5,14.544 -14.538,14.544Z" style="fill:none;"/><path id="path5078" d="M165.748,-0.002c-42.009,0 -76.06,18.985 -76.06,42.402c0,13.268 10.921,25.102 28.021,32.875c-8.081,-5.487 -13.403,-12.973 -14.584,-21.859c-2.685,-20.186 16.83,-40.82 45.148,-49.615c-14.687,6.665 -24.923,21.427 -24.923,38.599c0,23.218 18.648,42.046 41.773,42.383c-0.037,0.005 -0.087,0.015 -0.137,0.02c0.263,0 0.512,0.009 0.762,0.009c42.013,0 76.076,-18.984 76.076,-42.412c0,-13.261 -10.937,-25.097 -28.037,-32.871l0.75,0.522l0.736,0.531l0.713,0.543l0.7,0.555l0.687,0.566l0.664,0.578l0.649,0.588l0.625,0.6l0.613,0.609l0.588,0.621l0.574,0.631l0.562,0.643l0.538,0.652l0.513,0.662l0.5,0.672l0.475,0.684l0.449,0.693l0.438,0.703l0.425,0.713l0.387,0.723l0.375,0.73l0.352,0.74l0.336,0.75l0.3,0.76l0.287,0.77l0.264,0.777l0.25,0.787l0.211,0.795l0.188,0.805l0.175,0.812l0.151,0.82l0.125,0.831c2.675,20.19 -16.838,40.825 -45.151,49.619c14.688,-6.665 24.926,-21.426 24.926,-38.614c0,-23.202 -18.65,-42.026 -41.775,-42.367c0.05,-0.005 0.1,-0.015 0.15,-0.025c-0.262,0 -0.526,-0.01 -0.789,-0.01Zm-13.248,11.314c7.817,0 14.25,6.433 14.25,14.25c0,0.001 0,0.001 0,0.001c0,7.817 -6.433,14.249 -14.25,14.249c-7.817,0 -14.25,-6.432 -14.25,-14.249c0,-0.001 0,-0.001 0,-0.001c0,-7.817 6.433,-14.25 14.25,-14.25Z" style="fill:#fff;fill-rule:nonzero;"/><path id="path5080" d="M213.786,9.529l0.75,0.521l0.738,0.532l0.712,0.544l0.7,0.555l0.688,0.566l0.662,0.577l0.65,0.588l0.625,0.6l0.613,0.61l0.587,0.62l0.575,0.631l0.563,0.643l0.537,0.652l0.513,0.663l0.5,0.672l0.475,0.684l0.45,0.692l0.437,0.703l0.425,0.712l0.388,0.723l0.375,0.731l0.35,0.741l0.337,0.75l0.3,0.76l0.288,0.769l0.262,0.777l0.25,0.786l0.213,0.797l0.187,0.804l0.175,0.812l0.15,0.821l0.125,0.83c2.675,20.19 -16.837,40.825 -45.15,49.619c14.688,-6.665 24.925,-21.426 24.925,-38.614c0,-23.202 -18.65,-42.025 -41.775,-42.367c0.05,-0.005 0.1,-0.015 0.15,-0.025c-0.262,0 -0.525,-0.01 -0.787,-0.01c-42.01,0 -76.062,18.985 -76.062,42.402c0,13.268 10.922,25.103 28.022,32.876c-8.081,-5.487 -13.403,-12.973 -14.584,-21.859c-2.685,-20.187 16.831,-40.82 45.149,-49.615c-14.688,6.665 -24.925,21.426 -24.925,38.598c0,23.218 18.65,42.046 41.775,42.383c-0.038,0.005 -0.088,0.015 -0.138,0.02c0.263,0 0.513,0.01 0.763,0.01c42.012,-0.001 76.075,-18.985 76.075,-42.413c0,-13.261 -10.938,-25.097 -28.038,-32.871Z" style="fill:none;"/><path id="path5082" d="M354.323,82.586l-41.999,-42.002l38.524,-38.515l-29.913,0l-23.562,23.559l-23.563,-23.559l-29.924,0l38.525,38.515l-42,42.002l29.913,0l27.049,-27.046l27.05,27.046l29.9,0" style="fill:#fff;fill-rule:nonzero;"/><path id="path5084" d="M354.323,82.586l-41.999,-42.002l38.524,-38.515l-29.913,0l-23.562,23.559l-23.563,-23.559l-29.924,0l38.525,38.515l-42,42.002l29.913,0l27.049,-27.046l27.05,27.046l29.9,0Z" style="fill:none;"/><path id="path5086" d="M0,2.069l75.033,0l0,16.489l-51.629,0l0,14.931l40.258,0l0,16.495l-40.258,0l0,16.05l53.124,0l0,16.488l-76.528,0l0,-80.453" style="fill:#fff;fill-rule:nonzero;"/><path id="path5088" d="M0,2.069l75.033,0l0,16.489l-51.629,0l0,14.931l40.258,0l0,16.495l-40.258,0l0,16.05l53.124,0l0,16.488l-76.528,0l0,-80.453Z" style="fill:none;"/></g></svg>`;
|
|
44
|
+
const base64Logo = window.btoa(eoxLogo);
|
|
31
45
|
</script>
|
|
32
46
|
<style scoped>
|
|
33
47
|
.footer-text {
|
|
@@ -5,12 +5,12 @@
|
|
|
5
5
|
</v-app-bar>
|
|
6
6
|
</template>
|
|
7
7
|
<script setup>
|
|
8
|
-
import { eodashKey } from
|
|
9
|
-
import { inject } from
|
|
8
|
+
import { eodashKey } from "@/utils/keys";
|
|
9
|
+
import { inject } from "vue";
|
|
10
10
|
|
|
11
|
-
const eodash = /** @type {import("@/types").Eodash} */(inject(eodashKey))
|
|
11
|
+
const eodash = /** @type {import("@/types").Eodash} */ (inject(eodashKey));
|
|
12
12
|
|
|
13
|
-
const title = eodash.brand?.name
|
|
13
|
+
const title = eodash.brand?.name;
|
|
14
14
|
</script>
|
|
15
15
|
<style scoped>
|
|
16
16
|
.logo {
|