@paris-ias/list 1.0.111 → 1.0.113
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/module.json +1 -1
- package/dist/runtime/components/events/DenseItem.vue +24 -15
- package/dist/runtime/components/fellowships/DenseItem.vue +1 -1
- package/dist/runtime/components/list/atoms/SearchInput.vue +4 -2
- package/dist/runtime/components/list/molecules/Pagination.vue +2 -0
- package/dist/runtime/components/list/organisms/List.vue +16 -2
- package/dist/runtime/components/list/views/Dense.vue +0 -1
- package/dist/runtime/components/news/DenseItem.vue +24 -23
- package/dist/runtime/components/people/Badges.vue +74 -0
- package/dist/runtime/components/people/DenseItem.vue +11 -8
- package/dist/runtime/components/people/RowsItem.vue +2 -2
- package/dist/runtime/components/people/View.vue +1 -1
- package/dist/runtime/components/publications/DenseItem.vue +14 -7
- package/dist/runtime/graphql/list/publications.gql +2 -0
- package/dist/runtime/runtime/components/actions/ExpandedItem.vue +14 -0
- package/dist/runtime/runtime/components/actions/RowsItem.vue +12 -0
- package/dist/runtime/runtime/components/actions/View.vue +20 -0
- package/dist/runtime/runtime/components/affiliations/ExpandedItem.vue +14 -0
- package/dist/runtime/runtime/components/affiliations/RowsItem.vue +12 -0
- package/dist/runtime/runtime/components/affiliations/View.vue +20 -0
- package/dist/runtime/runtime/components/apps/ExpandedItem.vue +14 -0
- package/dist/runtime/runtime/components/apps/RowsItem.vue +12 -0
- package/dist/runtime/runtime/components/apps/View.vue +20 -0
- package/dist/runtime/runtime/components/disciplines/ExpandedItem.vue +14 -0
- package/dist/runtime/runtime/components/disciplines/RowsItem.vue +12 -0
- package/dist/runtime/runtime/components/disciplines/View.vue +20 -0
- package/dist/runtime/runtime/components/events/Badges.vue +73 -0
- package/dist/runtime/runtime/components/events/DateTimePlace.vue +77 -0
- package/dist/runtime/runtime/components/events/DenseItem.vue +60 -0
- package/dist/runtime/runtime/components/events/ExpandedItem.vue +9 -0
- package/dist/runtime/runtime/components/events/RegisterModal.vue +50 -0
- package/dist/runtime/runtime/components/events/RelatedItem.vue +44 -0
- package/dist/runtime/runtime/components/events/RowsItem.vue +118 -0
- package/dist/runtime/runtime/components/events/SlidingItem.vue +63 -0
- package/dist/runtime/runtime/components/events/View.vue +333 -0
- package/dist/runtime/runtime/components/fellowships/Badges.vue +47 -0
- package/dist/runtime/runtime/components/fellowships/DenseItem.vue +42 -0
- package/dist/runtime/runtime/components/fellowships/ExpandedItem.vue +7 -0
- package/dist/runtime/runtime/components/fellowships/RegisterModal.vue +41 -0
- package/dist/runtime/runtime/components/fellowships/RowsItem.vue +58 -0
- package/dist/runtime/runtime/components/fellowships/View.vue +203 -0
- package/dist/runtime/runtime/components/files/ExpandedItem.vue +14 -0
- package/dist/runtime/runtime/components/files/RowsItem.vue +12 -0
- package/dist/runtime/runtime/components/files/View.vue +20 -0
- package/dist/runtime/runtime/components/list/atoms/FiltersMenu.vue +44 -0
- package/dist/runtime/runtime/components/list/atoms/ResetButton.vue +33 -0
- package/dist/runtime/runtime/components/list/atoms/ResultsList.vue +27 -0
- package/dist/runtime/runtime/components/list/atoms/SearchInput.vue +59 -0
- package/dist/runtime/runtime/components/list/atoms/SearchItem.vue +65 -0
- package/dist/runtime/runtime/components/list/atoms/SearchString.vue +160 -0
- package/dist/runtime/runtime/components/list/atoms/SortMenu.vue +80 -0
- package/dist/runtime/runtime/components/list/atoms/ViewMenu.vue +63 -0
- package/dist/runtime/runtime/components/list/atoms/itemsPerPage.vue +33 -0
- package/dist/runtime/runtime/components/list/inputs/AutoComplete.vue +24 -0
- package/dist/runtime/runtime/components/list/inputs/BooleanSwitch.vue +20 -0
- package/dist/runtime/runtime/components/list/inputs/Checkbox.vue +20 -0
- package/dist/runtime/runtime/components/list/inputs/Select.vue +28 -0
- package/dist/runtime/runtime/components/list/molecules/Filters.vue +98 -0
- package/dist/runtime/runtime/components/list/molecules/GlobalSearchInput.vue +131 -0
- package/dist/runtime/runtime/components/list/molecules/Header.vue +51 -0
- package/dist/runtime/runtime/components/list/molecules/Pagination.vue +194 -0
- package/dist/runtime/runtime/components/list/molecules/ResultsContainer.vue +78 -0
- package/dist/runtime/runtime/components/list/organisms/List.vue +110 -0
- package/dist/runtime/runtime/components/list/organisms/Results.vue +72 -0
- package/dist/runtime/runtime/components/list/organisms/Slider.vue +180 -0
- package/dist/runtime/runtime/components/list/views/Dense.vue +12 -0
- package/dist/runtime/runtime/components/list/views/Expanded.vue +10 -0
- package/dist/runtime/runtime/components/list/views/Grid.vue +13 -0
- package/dist/runtime/runtime/components/list/views/Rows.vue +12 -0
- package/dist/runtime/runtime/components/list/views/Slider.vue +147 -0
- package/dist/runtime/runtime/components/list/views/Table.vue +13 -0
- package/dist/runtime/runtime/components/mailing/ExpandedItem.vue +14 -0
- package/dist/runtime/runtime/components/mailing/RowsItem.vue +12 -0
- package/dist/runtime/runtime/components/mailing/View.vue +20 -0
- package/dist/runtime/runtime/components/misc/atoms/DateStamp.vue +101 -0
- package/dist/runtime/runtime/components/misc/atoms/ImageContainer.vue +127 -0
- package/dist/runtime/runtime/components/misc/atoms/ShareMenu.vue +61 -0
- package/dist/runtime/runtime/components/misc/atoms/Socials.vue +120 -0
- package/dist/runtime/runtime/components/misc/molecules/ChipContainer.vue +31 -0
- package/dist/runtime/runtime/components/misc/molecules/Related.vue +28 -0
- package/dist/runtime/runtime/components/misc/molecules/RelatedItems.vue +27 -0
- package/dist/runtime/runtime/components/misc/molecules/SearchItem.vue +26 -0
- package/dist/runtime/runtime/components/news/DenseItem.vue +73 -0
- package/dist/runtime/runtime/components/news/ExpandedItem.vue +145 -0
- package/dist/runtime/runtime/components/news/Header.vue +7 -0
- package/dist/runtime/runtime/components/news/RelatedItem.vue +44 -0
- package/dist/runtime/runtime/components/news/RowsItem.vue +182 -0
- package/dist/runtime/runtime/components/news/View.vue +174 -0
- package/dist/runtime/runtime/components/people/DenseItem.vue +60 -0
- package/dist/runtime/runtime/components/people/ExpandedItem.vue +14 -0
- package/dist/runtime/runtime/components/people/RelatedItem.vue +41 -0
- package/dist/runtime/runtime/components/people/RowsItem.vue +93 -0
- package/dist/runtime/runtime/components/people/View.vue +172 -0
- package/dist/runtime/runtime/components/projects/DenseItem.vue +77 -0
- package/dist/runtime/runtime/components/projects/ExpandedItem.vue +12 -0
- package/dist/runtime/runtime/components/projects/RelatedItem.vue +44 -0
- package/dist/runtime/runtime/components/projects/RowsItem.vue +103 -0
- package/dist/runtime/runtime/components/projects/View.vue +130 -0
- package/dist/runtime/runtime/components/publications/DenseItem.vue +89 -0
- package/dist/runtime/runtime/components/publications/RelatedItem.vue +44 -0
- package/dist/runtime/runtime/components/publications/RowsItem.vue +105 -0
- package/dist/runtime/runtime/components/publications/View.vue +132 -0
- package/dist/runtime/runtime/components/tags/ExpandedItem.vue +14 -0
- package/dist/runtime/runtime/components/tags/RowsItem.vue +12 -0
- package/dist/runtime/runtime/components/tags/View.vue +20 -0
- package/dist/runtime/runtime/components/users/ExpandedItem.vue +14 -0
- package/dist/runtime/runtime/components/users/RowsItem.vue +12 -0
- package/dist/runtime/runtime/components/users/View.vue +20 -0
- package/dist/runtime/runtime/composables/useFetchItem.d.ts +6 -0
- package/dist/runtime/runtime/composables/useFetchItem.js +49 -0
- package/dist/runtime/runtime/composables/useIcons.d.ts +1 -0
- package/dist/runtime/runtime/composables/useIcons.js +30 -0
- package/dist/runtime/runtime/composables/useUtils.d.ts +12 -0
- package/dist/runtime/runtime/composables/useUtils.js +48 -0
- package/dist/runtime/runtime/graphql/buildFiltersValues.gql +35 -0
- package/dist/runtime/runtime/graphql/item/action.gql +22 -0
- package/dist/runtime/runtime/graphql/item/affiliations.gql +37 -0
- package/dist/runtime/runtime/graphql/item/apps.gql +34 -0
- package/dist/runtime/runtime/graphql/item/disciplines.gql +17 -0
- package/dist/runtime/runtime/graphql/item/events.gql +120 -0
- package/dist/runtime/runtime/graphql/item/fellowships.gql +164 -0
- package/dist/runtime/runtime/graphql/item/files.gql +25 -0
- package/dist/runtime/runtime/graphql/item/mailing.gql +10 -0
- package/dist/runtime/runtime/graphql/item/news.gql +129 -0
- package/dist/runtime/runtime/graphql/item/people.gql +174 -0
- package/dist/runtime/runtime/graphql/item/projects.gql +171 -0
- package/dist/runtime/runtime/graphql/item/publications.gql +169 -0
- package/dist/runtime/runtime/graphql/item/tags.gql +13 -0
- package/dist/runtime/runtime/graphql/item/users.gql +14 -0
- package/dist/runtime/runtime/graphql/list/action.gql +31 -0
- package/dist/runtime/runtime/graphql/list/affiliations.gql +42 -0
- package/dist/runtime/runtime/graphql/list/apps.gql +42 -0
- package/dist/runtime/runtime/graphql/list/disciplines.gql +22 -0
- package/dist/runtime/runtime/graphql/list/events.gql +44 -0
- package/dist/runtime/runtime/graphql/list/fellowships.gql +53 -0
- package/dist/runtime/runtime/graphql/list/files.gql +37 -0
- package/dist/runtime/runtime/graphql/list/mailing.gql +22 -0
- package/dist/runtime/runtime/graphql/list/news.gql +40 -0
- package/dist/runtime/runtime/graphql/list/people.gql +50 -0
- package/dist/runtime/runtime/graphql/list/projects.gql +37 -0
- package/dist/runtime/runtime/graphql/list/publications.gql +38 -0
- package/dist/runtime/runtime/graphql/list/search.gql +161 -0
- package/dist/runtime/runtime/graphql/list/tags.gql +22 -0
- package/dist/runtime/runtime/graphql/list/users.gql +38 -0
- package/dist/runtime/runtime/graphql/login.gql +0 -0
- package/dist/runtime/runtime/plugins/pinia.d.ts +2 -0
- package/dist/runtime/runtime/plugins/pinia.js +134 -0
- package/dist/runtime/runtime/plugins/vuetify.d.ts +2 -0
- package/dist/runtime/runtime/plugins/vuetify.js +21 -0
- package/dist/runtime/runtime/public/default.png +0 -0
- package/dist/runtime/runtime/public/filters.json +72 -0
- package/dist/runtime/runtime/server/tsconfig.json +3 -0
- package/dist/runtime/runtime/stores/factory.d.ts +25 -0
- package/dist/runtime/runtime/stores/factory.js +19 -0
- package/dist/runtime/runtime/stores/root.d.ts +60 -0
- package/dist/runtime/runtime/stores/root.js +315 -0
- package/dist/runtime/runtime/translations/en.json +350 -0
- package/dist/runtime/runtime/translations/fr.json +349 -0
- package/dist/runtime/runtime/types/imports.d.ts +13 -0
- package/dist/runtime/runtime/types/stores.d.ts +11 -0
- package/dist/runtime/translations/en.json +1 -1
- package/package.json +2 -2
- /package/dist/runtime/{components → runtime/components}/people/GroupBadges.vue +0 -0
package/dist/module.json
CHANGED
|
@@ -2,10 +2,19 @@
|
|
|
2
2
|
<v-row
|
|
3
3
|
v-ripple
|
|
4
4
|
no-gutters
|
|
5
|
-
class="cursor-pointer highlight-on-hover"
|
|
5
|
+
class="cursor-pointer highlight-on-hover my-2"
|
|
6
6
|
@click="$router.push(localePath('/activities/events/' + item.slug[locale]))"
|
|
7
7
|
>
|
|
8
|
-
<v-col v-if="mdAndUp"
|
|
8
|
+
<v-col v-if="mdAndUp" cols="1">
|
|
9
|
+
<MiscAtomsDateStamp
|
|
10
|
+
v-if="item.start"
|
|
11
|
+
:loading="$stores['events'].loading"
|
|
12
|
+
:date-start="item.start"
|
|
13
|
+
:date-stop="item.stop"
|
|
14
|
+
class="pr-6 mt-md-2"
|
|
15
|
+
/>
|
|
16
|
+
</v-col>
|
|
17
|
+
<v-col v-if="mdAndUp" cols="1">
|
|
9
18
|
<MiscAtomsImageContainer
|
|
10
19
|
cover
|
|
11
20
|
:loading="$stores.events.loading"
|
|
@@ -18,19 +27,19 @@
|
|
|
18
27
|
/>
|
|
19
28
|
</v-col>
|
|
20
29
|
|
|
21
|
-
<v-col align-self="
|
|
22
|
-
<
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
<div class="text-h5 dense">
|
|
30
|
+
<v-col align-self="top" class="pl-2">
|
|
31
|
+
<v-chip
|
|
32
|
+
class="mr-3"
|
|
33
|
+
color="black"
|
|
34
|
+
:size="mdAndUp ? 'default' : 'small'"
|
|
35
|
+
style="background-color: white; color: black"
|
|
36
|
+
tile
|
|
37
|
+
variant="outlined"
|
|
38
|
+
>
|
|
39
|
+
{{ $t("list.filters.events.category." + item.category) }}
|
|
40
|
+
</v-chip>
|
|
41
|
+
|
|
42
|
+
<div class="text-h5 dense paragraph">
|
|
34
43
|
{{ item.name }}
|
|
35
44
|
</div>
|
|
36
45
|
</v-col>
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
no-gutters
|
|
5
5
|
class="cursor-pointer highlight-on-hover"
|
|
6
6
|
@click="
|
|
7
|
-
$router.push(localePath('/activities/fellowships' + item.slug[locale]))
|
|
7
|
+
$router.push(localePath('/activities/fellowships/' + item.slug[locale]))
|
|
8
8
|
"
|
|
9
9
|
>
|
|
10
10
|
<v-col align-self="center" cols="8" class="text-h5 dense">
|
|
@@ -13,8 +13,10 @@
|
|
|
13
13
|
tile
|
|
14
14
|
type="search"
|
|
15
15
|
:loading="rootStore.loading"
|
|
16
|
-
@keyup.enter="$router.push(localePath('/search'))"
|
|
17
|
-
@click:append="
|
|
16
|
+
@keyup.enter="type === 'all' ? null : $router.push(localePath('/search'))"
|
|
17
|
+
@click:append="
|
|
18
|
+
type === 'all' ? null : $router.push(localePath('/search'))
|
|
19
|
+
"
|
|
18
20
|
>
|
|
19
21
|
<!-- :loading="$nuxt.loading || $store.state.loading" :class="{ 'mt-3':
|
|
20
22
|
$store.state.scrolled }" -->
|
|
@@ -177,8 +177,10 @@ const createGap = (pageIndex) => {
|
|
|
177
177
|
isGap: true
|
|
178
178
|
};
|
|
179
179
|
};
|
|
180
|
+
const emit = defineEmits(["update"]);
|
|
180
181
|
const updatePage = (page) => {
|
|
181
182
|
rootStore.updatePage({ page, type: props.type, lang: locale.value });
|
|
183
|
+
emit("update", page);
|
|
182
184
|
};
|
|
183
185
|
const getGapPage = (index) => {
|
|
184
186
|
return Math.floor(
|
|
@@ -10,7 +10,11 @@
|
|
|
10
10
|
/>
|
|
11
11
|
</component>
|
|
12
12
|
<div class="text-center">
|
|
13
|
-
<ListAtomsPerPage
|
|
13
|
+
<ListAtomsPerPage
|
|
14
|
+
v-if="numberOfPages > 1"
|
|
15
|
+
:type="type"
|
|
16
|
+
class="float-right"
|
|
17
|
+
/>
|
|
14
18
|
|
|
15
19
|
<ListMoleculesPagination
|
|
16
20
|
v-if="numberOfPages > 1"
|
|
@@ -22,6 +26,7 @@
|
|
|
22
26
|
:page-padding="1"
|
|
23
27
|
:page-gap="2"
|
|
24
28
|
:hide-prev-next="false"
|
|
29
|
+
@update="onPageChange"
|
|
25
30
|
/>
|
|
26
31
|
</div>
|
|
27
32
|
</template>
|
|
@@ -35,10 +40,12 @@ import {
|
|
|
35
40
|
computed,
|
|
36
41
|
onBeforeUnmount,
|
|
37
42
|
onMounted,
|
|
38
|
-
useI18n
|
|
43
|
+
useI18n,
|
|
44
|
+
useRoute
|
|
39
45
|
} from "#imports";
|
|
40
46
|
const { $stores } = useNuxtApp();
|
|
41
47
|
const { locale } = useI18n();
|
|
48
|
+
const route = useRoute();
|
|
42
49
|
const rootStore = useRootStore();
|
|
43
50
|
const props = defineProps({
|
|
44
51
|
addBtn: {
|
|
@@ -99,4 +106,11 @@ try {
|
|
|
99
106
|
onBeforeUnmount(() => {
|
|
100
107
|
rootStore.resetState(props.type, locale.value);
|
|
101
108
|
});
|
|
109
|
+
const onPageChange = (newPage) => {
|
|
110
|
+
rootStore.updatePage({ page: newPage, type: props.type, lang: locale.value });
|
|
111
|
+
window.scrollTo({
|
|
112
|
+
top: 0,
|
|
113
|
+
behavior: "smooth"
|
|
114
|
+
});
|
|
115
|
+
};
|
|
102
116
|
</script>
|
|
@@ -2,43 +2,44 @@
|
|
|
2
2
|
<v-row
|
|
3
3
|
v-ripple
|
|
4
4
|
no-gutters
|
|
5
|
-
class="cursor-pointer highlight-on-hover"
|
|
5
|
+
class="cursor-pointer highlight-on-hover my-2"
|
|
6
6
|
@click="$router.push(localePath('/activities/news/' + item.slug[locale]))"
|
|
7
7
|
>
|
|
8
8
|
<v-col v-if="mdAndUp" align-self="center" cols="1">
|
|
9
9
|
<MiscAtomsImageContainer
|
|
10
10
|
cover
|
|
11
|
-
:loading="$stores.
|
|
11
|
+
:loading="$stores.news.loading"
|
|
12
12
|
:src="item.image.url ? item.image : '/default.png'"
|
|
13
13
|
:ratio="1 / 1"
|
|
14
|
-
:name="item.
|
|
14
|
+
:name="item.slug"
|
|
15
15
|
:slug="item.slug"
|
|
16
|
-
link="
|
|
16
|
+
link="news-slug"
|
|
17
17
|
width="80px"
|
|
18
18
|
/>
|
|
19
19
|
</v-col>
|
|
20
|
-
<v-col align-self="
|
|
20
|
+
<v-col align-self="top" class="text-h5 dense px-2 paragraph">
|
|
21
21
|
<v-skeleton-loader v-if="rootStore.loading" type="heading" />
|
|
22
22
|
<template v-else>
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
23
|
+
<v-skeleton-loader
|
|
24
|
+
v-if="rootStore.loading"
|
|
25
|
+
:type="
|
|
26
|
+
['chip', 'chip@2', 'chip@3', 'chip@4', 'chip@4', 'chip@4'][
|
|
27
|
+
['xs', 'sm', 'md', 'lg', 'xl', 'xxl'].indexOf(name || 'md')
|
|
28
|
+
]
|
|
29
|
+
"
|
|
30
|
+
/>
|
|
26
31
|
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
<v-chip class="ma-2" style="background-color: white; color: black">
|
|
39
|
-
{{ $t(eventCategory) }}
|
|
40
|
-
</v-chip>
|
|
41
|
-
<MiscMoleculesChipContainer :items="item.tags" size="small" />
|
|
32
|
+
<template v-else>
|
|
33
|
+
<v-chip
|
|
34
|
+
class="ma-2"
|
|
35
|
+
style="background-color: white; color: black"
|
|
36
|
+
:size="mdAndUp ? 'default' : 'small'"
|
|
37
|
+
>
|
|
38
|
+
{{ $t(eventCategory) }}
|
|
39
|
+
</v-chip>
|
|
40
|
+
<MiscMoleculesChipContainer :items="item.tags" size="small" />
|
|
41
|
+
</template>
|
|
42
|
+
{{ item.name }}
|
|
42
43
|
</template>
|
|
43
44
|
</v-col>
|
|
44
45
|
</v-row>
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<span>
|
|
3
|
+
<v-skeleton-loader
|
|
4
|
+
v-if="rootStore.loading || $stores.people.loading"
|
|
5
|
+
type="chip"
|
|
6
|
+
/>
|
|
7
|
+
<template v-else-if="item.groups">
|
|
8
|
+
<template v-for="(value, key, index) in item.groups" :key="key + index">
|
|
9
|
+
<template v-if="value && key === 'vintage'">
|
|
10
|
+
<v-chip
|
|
11
|
+
v-for="(vintage, index2) in item.groups.vintage"
|
|
12
|
+
:key="index2"
|
|
13
|
+
:size="mdAndUp ? 'default' : 'small'"
|
|
14
|
+
class="mt-3 mr-3"
|
|
15
|
+
variant="outlined"
|
|
16
|
+
tile
|
|
17
|
+
style="background-color: white; color: black"
|
|
18
|
+
>
|
|
19
|
+
{{ $t("vintage", [vintage.year]) }}
|
|
20
|
+
</v-chip>
|
|
21
|
+
</template>
|
|
22
|
+
|
|
23
|
+
<v-chip
|
|
24
|
+
v-if="
|
|
25
|
+
value &&
|
|
26
|
+
key !== 'fellows' &&
|
|
27
|
+
((!item.groups.vintage && key === 'vintage') ||
|
|
28
|
+
!['vintage', '__typename'].includes(key))
|
|
29
|
+
"
|
|
30
|
+
class="mt-3 mr-3"
|
|
31
|
+
:size="mdAndUp ? 'default' : 'small'"
|
|
32
|
+
color="black"
|
|
33
|
+
style="background-color: white; color: black"
|
|
34
|
+
tile
|
|
35
|
+
variant="outlined"
|
|
36
|
+
>
|
|
37
|
+
{{ $t("list.filters.people.groups." + key) }}
|
|
38
|
+
</v-chip>
|
|
39
|
+
</template>
|
|
40
|
+
<template
|
|
41
|
+
v-for="(value, key, index) in item.disciplines"
|
|
42
|
+
:key="key + index"
|
|
43
|
+
>
|
|
44
|
+
<v-chip
|
|
45
|
+
v-if="value && index < 3"
|
|
46
|
+
class="mt-3 mr-3"
|
|
47
|
+
color="black"
|
|
48
|
+
:size="mdAndUp ? 'default' : 'small'"
|
|
49
|
+
style="background-color: white; color: black"
|
|
50
|
+
tile
|
|
51
|
+
variant="outlined"
|
|
52
|
+
>
|
|
53
|
+
{{ $t("disciplines." + key) }}
|
|
54
|
+
</v-chip>
|
|
55
|
+
</template>
|
|
56
|
+
</template></span
|
|
57
|
+
>
|
|
58
|
+
</template>
|
|
59
|
+
|
|
60
|
+
<script setup>
|
|
61
|
+
import { useRootStore } from "../../stores/root";
|
|
62
|
+
import { useNuxtApp } from "#imports";
|
|
63
|
+
import { useDisplay } from "vuetify";
|
|
64
|
+
const { mdAndUp } = useDisplay();
|
|
65
|
+
const rootStore = useRootStore();
|
|
66
|
+
const { $stores } = useNuxtApp();
|
|
67
|
+
const props = defineProps({
|
|
68
|
+
item: {
|
|
69
|
+
type: Object,
|
|
70
|
+
required: true,
|
|
71
|
+
default: () => ({})
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
</script>
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
<v-row
|
|
3
3
|
v-ripple
|
|
4
4
|
no-gutters
|
|
5
|
-
class="cursor-pointer highlight-on-hover my-
|
|
5
|
+
class="cursor-pointer highlight-on-hover my-2"
|
|
6
6
|
@click="
|
|
7
7
|
$router.push(
|
|
8
8
|
localePath({
|
|
@@ -12,7 +12,7 @@
|
|
|
12
12
|
)
|
|
13
13
|
"
|
|
14
14
|
>
|
|
15
|
-
<v-col v-if="mdAndUp"
|
|
15
|
+
<v-col v-if="mdAndUp" cols="1">
|
|
16
16
|
<MiscAtomsImageContainer
|
|
17
17
|
cover
|
|
18
18
|
:loading="$stores.people.loading"
|
|
@@ -24,18 +24,17 @@
|
|
|
24
24
|
width="80px"
|
|
25
25
|
/>
|
|
26
26
|
</v-col>
|
|
27
|
-
<v-col align-self="
|
|
27
|
+
<v-col align-self="top" class="text-h6 dense px-2">
|
|
28
28
|
<v-skeleton-loader v-if="rootStore.loading" type="heading" />
|
|
29
|
-
<div v-else class="text-h5">
|
|
29
|
+
<div v-else class="d-flex text-h5 align-center">
|
|
30
30
|
{{ item.firstname + " " + item.lastname }}
|
|
31
|
+
<v-spacer />
|
|
32
|
+
<PeopleBadges :item="item" />
|
|
31
33
|
</div>
|
|
32
|
-
<div class="
|
|
34
|
+
<div class="text-body-1 font-weight-light paragraph">
|
|
33
35
|
{{ item.groups.vintage ? item.groups.vintage[0].theme : "" }}
|
|
34
36
|
</div>
|
|
35
37
|
</v-col>
|
|
36
|
-
<v-col align-self="center" cols="auto">
|
|
37
|
-
<PeopleGroupBadges :item="item" />
|
|
38
|
-
</v-col>
|
|
39
38
|
</v-row>
|
|
40
39
|
</template>
|
|
41
40
|
|
|
@@ -58,3 +57,7 @@ const props = defineProps({
|
|
|
58
57
|
}
|
|
59
58
|
});
|
|
60
59
|
</script>
|
|
60
|
+
|
|
61
|
+
<style>
|
|
62
|
+
.paragraph{max-width:83ch!important}
|
|
63
|
+
</style>
|
|
@@ -7,7 +7,7 @@
|
|
|
7
7
|
localePath({
|
|
8
8
|
name: 'people-slug',
|
|
9
9
|
params: { slug: item.slug },
|
|
10
|
-
})
|
|
10
|
+
}),
|
|
11
11
|
)
|
|
12
12
|
"
|
|
13
13
|
>
|
|
@@ -51,7 +51,7 @@
|
|
|
51
51
|
{{ item.firstname + " " + item.lastname }}
|
|
52
52
|
</NuxtLink>
|
|
53
53
|
<MiscAtomsSocials v-if="item.socials" :socials="item.socials" />
|
|
54
|
-
<
|
|
54
|
+
<PeoplepBadges :item="item" />
|
|
55
55
|
<div
|
|
56
56
|
v-if="item.biography && item.biography.length > 0"
|
|
57
57
|
class="text-wrap clamped-text text-black"
|
|
@@ -23,10 +23,8 @@
|
|
|
23
23
|
<v-skeleton-loader v-if="rootStore.loading" type="heading" />
|
|
24
24
|
<template v-else>
|
|
25
25
|
{{ item.name }}
|
|
26
|
-
<div class="text-body-2">
|
|
27
|
-
{{ item.summary }}
|
|
28
|
-
</div>
|
|
29
26
|
</template>
|
|
27
|
+
<MDC class="text-caption" :value="item.summary" />
|
|
30
28
|
</v-col>
|
|
31
29
|
|
|
32
30
|
<v-col align-self="center">
|
|
@@ -40,9 +38,18 @@
|
|
|
40
38
|
/>
|
|
41
39
|
|
|
42
40
|
<template v-else>
|
|
43
|
-
<v-chip
|
|
41
|
+
<v-chip
|
|
42
|
+
v-if="eventCategory"
|
|
43
|
+
class="ma-2"
|
|
44
|
+
style="background-color: white; color: black"
|
|
45
|
+
>
|
|
44
46
|
{{ $t(eventCategory) }} </v-chip
|
|
45
|
-
><v-chip
|
|
47
|
+
><v-chip
|
|
48
|
+
v-if="eventType"
|
|
49
|
+
c
|
|
50
|
+
class="ma-2"
|
|
51
|
+
style="background-color: white; color: black"
|
|
52
|
+
>
|
|
46
53
|
{{ $t(eventType) }}
|
|
47
54
|
</v-chip>
|
|
48
55
|
<MiscMoleculesChipContainer :items="item.tags" size="small" />
|
|
@@ -75,7 +82,7 @@ const eventCategory = computed(() => {
|
|
|
75
82
|
console.log("props.item.category: ", props.item.category);
|
|
76
83
|
return "list.filters.publications.category." + props.item.category;
|
|
77
84
|
} else {
|
|
78
|
-
return
|
|
85
|
+
return false;
|
|
79
86
|
}
|
|
80
87
|
});
|
|
81
88
|
const eventType = computed(() => {
|
|
@@ -83,7 +90,7 @@ const eventType = computed(() => {
|
|
|
83
90
|
console.log("props.item.type: ", props.item.type);
|
|
84
91
|
return "list.filters.publications.type." + props.item.type;
|
|
85
92
|
} else {
|
|
86
|
-
return
|
|
93
|
+
return false;
|
|
87
94
|
}
|
|
88
95
|
});
|
|
89
96
|
</script>
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
{{ item }}
|
|
3
|
+
</template>
|
|
4
|
+
|
|
5
|
+
<script setup>
|
|
6
|
+
import { useNuxtApp } from "#imports";
|
|
7
|
+
const { $stores } = useNuxtApp();
|
|
8
|
+
defineProps({
|
|
9
|
+
item: {
|
|
10
|
+
type: Object,
|
|
11
|
+
required: true
|
|
12
|
+
},
|
|
13
|
+
loading: {
|
|
14
|
+
type: Boolean,
|
|
15
|
+
required: false,
|
|
16
|
+
default: false
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
$stores.actions.loading = false;
|
|
20
|
+
</script>
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
{{ item }}
|
|
3
|
+
</template>
|
|
4
|
+
|
|
5
|
+
<script setup>
|
|
6
|
+
import { useNuxtApp } from "#imports";
|
|
7
|
+
const { $stores } = useNuxtApp();
|
|
8
|
+
defineProps({
|
|
9
|
+
item: {
|
|
10
|
+
type: Object,
|
|
11
|
+
required: true
|
|
12
|
+
},
|
|
13
|
+
loading: {
|
|
14
|
+
type: Boolean,
|
|
15
|
+
required: false,
|
|
16
|
+
default: false
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
$stores.affiliations.loading = false;
|
|
20
|
+
</script>
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
{{ item }}
|
|
3
|
+
</template>
|
|
4
|
+
|
|
5
|
+
<script setup>
|
|
6
|
+
import { useNuxtApp } from "#imports";
|
|
7
|
+
const { $stores } = useNuxtApp();
|
|
8
|
+
defineProps({
|
|
9
|
+
item: {
|
|
10
|
+
type: Object,
|
|
11
|
+
required: true
|
|
12
|
+
},
|
|
13
|
+
loading: {
|
|
14
|
+
type: Boolean,
|
|
15
|
+
required: false,
|
|
16
|
+
default: false
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
$stores.apps.loading = false;
|
|
20
|
+
</script>
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
{{ item }}
|
|
3
|
+
</template>
|
|
4
|
+
|
|
5
|
+
<script setup>
|
|
6
|
+
import { useNuxtApp } from "#imports";
|
|
7
|
+
const { $stores } = useNuxtApp();
|
|
8
|
+
defineProps({
|
|
9
|
+
item: {
|
|
10
|
+
type: Object,
|
|
11
|
+
required: true
|
|
12
|
+
},
|
|
13
|
+
loading: {
|
|
14
|
+
type: Boolean,
|
|
15
|
+
required: false,
|
|
16
|
+
default: false
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
$stores.disciplines.loading = false;
|
|
20
|
+
</script>
|