From e09e3ed4a7134d8d3602ae8068be3a251ac8f1e8 Mon Sep 17 00:00:00 2001 From: valere Date: Mon, 23 Dec 2024 00:19:12 +0100 Subject: [PATCH] feat: install composable & store --- README.md | 192 ------------------ src/components/StoryContainer.vue | 44 ++-- src/components/StoryList.vue | 35 +--- .../{tools => player}/StoryDrawRect.vue | 0 .../{tools => player}/StoryEditor.vue | 29 ++- src/components/{tools => player}/ZoomRect.vue | 0 src/components/tools/StoryEditor.md | 17 -- src/components/tools/StoryPlayer.vue | 83 -------- src/composable/IsMobile.ts | 13 ++ src/composable/Viewer.ts | 10 + src/stores/stories.ts | 19 -- src/stores/story.ts | 36 ++++ src/types/virages.d.ts | 21 +- 13 files changed, 131 insertions(+), 368 deletions(-) rename src/components/{tools => player}/StoryDrawRect.vue (100%) rename src/components/{tools => player}/StoryEditor.vue (89%) rename src/components/{tools => player}/ZoomRect.vue (100%) delete mode 100644 src/components/tools/StoryEditor.md delete mode 100644 src/components/tools/StoryPlayer.vue create mode 100644 src/composable/IsMobile.ts create mode 100644 src/composable/Viewer.ts delete mode 100644 src/stores/stories.ts create mode 100644 src/stores/story.ts diff --git a/README.md b/README.md index 99ff04d..9f5fba0 100644 --- a/README.md +++ b/README.md @@ -1,197 +1,5 @@ # virages.io -## ROADMAP - -1. define a Marker in the viewport - -- x -- y - -2. define a ZoomArea - -- x -- y -- w -- h - -3. define a Mask - -- Trace - -## TOOLS - -DSIGN SYSTEMS - -- StoryLite - https://atlas-viewer-storybook.netlify.app/#/stories/testing-ensuremouseeventsareaccuratewhenboxchanges -- micr.io - https://i.micr.io/aoxENNv/en/poulpatore-bigjpg - -BACK OFFICE - -- https://atlas-viewer-storybook.netlify.app/#/stories/annotations-selectiondemo -- https://github.com/altert/OpenseadragonFabricjsOverlay -- https://dash.micr.io/u:ErWRfBqNb1ef0QEnIRPzkQ/tets/@aoxENNv/en - -FRONT OFFICE - -- https://canvas-panel.digirati.com/#/about -- https://canvas-panel.digirati.com/#/examples/fullpage?manifest=https://stephenwf.github.io/ocean-liners.json -- https://github.com/digirati-co-uk/canvas-panel/tree/master - -CONCURENTS - -- https://micr.io/ -- https://archief.ntr.nl/tuinderlusten/en.html - -LOGO -Virages est un outils pour les historiens de l'art qui veulent expliquer/analyser des images (peintures) en très haute résolution -Concevez un logo minimaliste, moderne pour virages.io, incorporant un V, les couleurs CMJN & RGB. - -ws apps : - -- logo virages - -ALL: https://storiiies-editor.cogapp.com/ -https://github.com/IIIF/awesome-iiif/tree/66f8c724ee7fdb44f750ed4d7cedad449bb5f7a3 - -FRONT: OpenSeaDragon -FRONT OFFICE: https://annotorious.github.io/guides/annotorious-in-vue/ - -BACK: vips (Zoomable or ZoomHub) -BACK office : https://annotorious.github.io/getting-started/ - -https://github.com/IIIF/awesome-iiif - -IIIF -Giga pixel - -- [ ] load a picture from a props on mounted in a 2d canvas -- [ ] display that picture with a good ratio and cover the full window -- [ ] a method focusOn(x, y, zoom) will change the scale of the image targetting a specific point -- [ ] at any moment the picture is showing in a good ratio even when the window is resized - -Watch an erotic dream world where desire, colorful fantasy and poetic body parts intertwine. -https://vimeo.com/ondemand/uneruedanssalongueur - -calvitie - -forme de nudité -ex : - -- Hunter Thomson -- Gérard jugnot -- Sébastien Tellier - -qu'apporte l'analyse -artistique ? -quel est son sens ? - -l'analyse peint une âme à l'oeuvre, elle renvoit la passion à l'objet d'art. -En ce sens l'analyse peut enfermer l'oeuvre dans un cadre, dans des lignes droites comme elle peut démontrer son aura par l'interprétation voir la surpasser par la sur-interprétation. - -un film aléatoire - -https://shop.gandi.net/en/6514bca2-b7cc-11ec-87b3-00163eada87b/domain/suggest/7cf99682-e92f-45d9-a87c-01d4d07999ca?search=msledchildren.com - -- [ ] display one picture !!!!!!!!! -- [ ] 2 dyn canvas size of the window -- [ ] 3 setView (position, zoom, duration) -- [ ] 4 crop selection -- [ ] 5 filters -- [ ] 6 journey -- [ ] 7 UI : https://www.nextrembrandt.com/ -- [ ] display 2 pictures -- [ ] overlay pictures -- [ ] freeway mode -- [ ] possible effect on art click https://tympanus.net/codrops/2023/03/14/fullscreen-clip-animation/ - -# IA & painting Art: - -- [ ] IA shcema to painting : https://github.com/alexjc/neural-doodle -- [ ] Depth Estimation of a painting -- [ ] Object Detection in painting -- [ ] Perspective Detection in painting -- [ ] Inpaint in ... well painting :) - -### rembrandt: - -https://www.youtube.com/results?search_query=tu+delft+rembrandt - -### Depth map - -Inpainting / Outpainting -> youtube -https://github.com/AUTOMATIC1111/stable-diffusion-webui -https://github.com/docker-mailserver/docker-mailserver - -https://tresjs.org/examples/load-textures.html -https://atroposjs.com/docs/vue#whats-next - -- découpe d'une image avec clip - d'abord basic ellipse ou cercle - MODULES: - -- errance [tuiles + zoom + full screen] -- histoire [tuiles + scroll + zoom] -- analyse [click + zoom + animation -- épaisseurs [3d] - -## Pourquoi virages alors que l'art génératif existe ? - -Si visuellement l’art génératif illustre très bien un article, même en tâtonnant il est impossible d'avoir exactement ce que l'on désir. -C'est l'occasion à l'art visuel traditionnel de mettre en avant ce qui fait sa spécificité, l'intention de son auteur. -Le mot artiste ne veut rien dire. -Il n'y a pas d'artiste, -Il n'y a que de l'art et leurs auteurs. - -### MARCHÉ : - -https://www.tumblr.com -https://behance.net -https://vitali-studio.com -https://issuu.com -https://cargo.site -https://www.artsy.net/ -https://www.flickr.com - -### THEMES: - -plutôt que perdre du temps sur du web design fait et refait, -pourquoi ne pas créer des thèmes sur des modèles comme : - -- https://www.apple.com/fr/newsroom/ -- https://www.louvre.fr/en/what-s-on/exhibitions/leonardo-da-vinci#exhibition-overview -- https://salvatormundirevisited.com/ - -### CSS - -backdrop-filter -Filter color on hover : -https://cosmicmagazine.com.au/ - -Folio for photographie & paintings -OU -CMS pour portfolio au plus généralement site créatif (EvilSpins) - -Virag.es is a fullstack "framework" since it's a CMS -Virag.es back should be build with the best back (prisma nest) framework & vue - -## Photo - -- meta -- raw compat -- correction ... - -## Paintings - -- explorable table -- compte-fils / thread counter (https://codesandbox.io/s/github/WebsiteBeaver/vue-magnifier) -- video ? -- animation half per half (comme pour Lucie 3) -- VHS effect : https://www.ssion.com/ -- painting light (filmer une peinture avec peu de lumière et avec une lumière à fond) - -## Lister toutes les références & symbole dans une page qui s'appelerai Mythologie - ## DESIGN / FEATURES : - mobile first -> scroll first diff --git a/src/components/StoryContainer.vue b/src/components/StoryContainer.vue index fb329f4..82adce6 100644 --- a/src/components/StoryContainer.vue +++ b/src/components/StoryContainer.vue @@ -2,9 +2,9 @@
@@ -16,9 +16,9 @@ import OpenSeadragon from 'openseadragon' import '@/assets/plugins/openseadragon-scalebar.js' import '@/assets/plugins/openseadragon-bookmark-url.js' import { onMounted, ref, provide, onUnmounted } from 'vue' -import type { Story } from '@/types/virages' +import type { Story, ViewerConfiguration } from '@/types/virages' import Article from './StoryArticle.vue' -import Editor from './tools/StoryEditor.vue' +import Editor from './player/StoryEditor.vue' const props = defineProps<{ story: Story }>() const Viewer = ref() @@ -26,26 +26,30 @@ const openSeadragonElt = ref() provide('Viewer', Viewer) +const defaultViewerConfiguration: ViewerConfiguration = { + prefixUrl: 'https://openseadragon.github.io/openseadragon/images/', + crossOriginPolicy: 'Anonymous', + animationTime: 2, + showNavigator: false, + sequenceMode: false, + showNavigationControl: false, + drawer: 'canvas', + preventDefaultAction: true, + visibilityRatio: 0.5, + defaultZoomLevel: 1.2, + gestureSettingsMouse: { + scrollToZoom: true, + clickToZoom: false, + dblClickToZoom: false, + dragToPan: true, + }, +} + const initViewer = () => { Viewer.value = OpenSeadragon({ element: openSeadragonElt.value, - animationTime: 0.4, - prefixUrl: 'https://openseadragon.github.io/openseadragon/images/', - showNavigator: false, - sequenceMode: false, tileSources: props.story.url, - showNavigationControl: false, - drawer: 'canvas', - preventDefaultAction: true, - visibilityRatio: 0.5, - crossOriginPolicy: 'Anonymous', - gestureSettingsMouse: { - scrollToZoom: true, - clickToZoom: false, - dblClickToZoom: false, - dragToPan: true, - }, - defaultZoomLevel: 1.2, + ...defaultViewerConfiguration, }) } diff --git a/src/components/StoryList.vue b/src/components/StoryList.vue index 3578af1..e2388ad 100644 --- a/src/components/StoryList.vue +++ b/src/components/StoryList.vue @@ -1,15 +1,15 @@ diff --git a/src/components/tools/StoryDrawRect.vue b/src/components/player/StoryDrawRect.vue similarity index 100% rename from src/components/tools/StoryDrawRect.vue rename to src/components/player/StoryDrawRect.vue diff --git a/src/components/tools/StoryEditor.vue b/src/components/player/StoryEditor.vue similarity index 89% rename from src/components/tools/StoryEditor.vue rename to src/components/player/StoryEditor.vue index 0352f18..d8b6af2 100644 --- a/src/components/tools/StoryEditor.vue +++ b/src/components/player/StoryEditor.vue @@ -29,21 +29,25 @@ diff --git a/src/components/tools/ZoomRect.vue b/src/components/player/ZoomRect.vue similarity index 100% rename from src/components/tools/ZoomRect.vue rename to src/components/player/ZoomRect.vue diff --git a/src/components/tools/StoryEditor.md b/src/components/tools/StoryEditor.md deleted file mode 100644 index f3bfeb1..0000000 --- a/src/components/tools/StoryEditor.md +++ /dev/null @@ -1,17 +0,0 @@ -# Story Editor - -## Props: - -story: Story (should be a state as Markers are CRUD ?) - -## Ref: - -selectedMarker: Marker - -## Methods: - -LoadStory -CreateMarker -SelectMarker -EditMarker -DeleteMarker diff --git a/src/components/tools/StoryPlayer.vue b/src/components/tools/StoryPlayer.vue deleted file mode 100644 index 1d7e0fe..0000000 --- a/src/components/tools/StoryPlayer.vue +++ /dev/null @@ -1,83 +0,0 @@ - - - - - diff --git a/src/composable/IsMobile.ts b/src/composable/IsMobile.ts new file mode 100644 index 0000000..d8fa5c1 --- /dev/null +++ b/src/composable/IsMobile.ts @@ -0,0 +1,13 @@ +import { computed } from 'vue' + +export function useIsMobile() { + const userAgent = navigator.userAgent || navigator.vendor || window.opera + + // Check for mobile user agents + const isMobile = computed(() => { + const mobileRegex = /Android|webOS|iPhone|iPad|iPod|BlackBerry|Windows Phone/i + return mobileRegex.test(userAgent) + }) + + return { isMobile } +} diff --git a/src/composable/Viewer.ts b/src/composable/Viewer.ts new file mode 100644 index 0000000..49aaf07 --- /dev/null +++ b/src/composable/Viewer.ts @@ -0,0 +1,10 @@ +import type OpenSeadragon from 'openseadragon' +import { type Ref } from 'vue' + +export function useViewer(Viewer: Ref) { + const zoomTo = (zoomLevel: number) => { + Viewer.value.viewport.zoomTo(zoomLevel, undefined, false) + } + + return { zoomTo } +} diff --git a/src/stores/stories.ts b/src/stores/stories.ts deleted file mode 100644 index b542e0f..0000000 --- a/src/stores/stories.ts +++ /dev/null @@ -1,19 +0,0 @@ -import type { Story } from '@/types/virages' -import { defineStore } from 'pinia' - -export const useStories = defineStore('stories', { - state: (): Story => ({ - stories: [], - nextId: 0, - }), - getters: { - finishedStories(state) { - return state.stories.filter((todo) => todo.isFinished) - }, - }, - actions: { - action(data) { - this.stories.push({}) - }, - }, -}) diff --git a/src/stores/story.ts b/src/stores/story.ts new file mode 100644 index 0000000..549fd61 --- /dev/null +++ b/src/stores/story.ts @@ -0,0 +1,36 @@ +import type { Story } from '@/types/virages' +import { defineStore } from 'pinia' +import datas from '@/assets/stories.json' + +export const useStoryStore = defineStore('story', { + state: () => ({ + stories: [] as Story[], + isStoryOpen: false, + }), + actions: { + getStories() { + this.stories = datas + }, + openStory(story: Story) { + this.stories.forEach((story) => { + story.displayMode = 'HIDDEN' + }) + story.displayMode = 'EDITOR' + this.isStoryOpen = true + document.body.classList.add('app-fullscreen') + }, + closeStories() { + this.stories.forEach((story) => { + story.displayMode = 'ARTICLE' + }) + this.isStoryOpen = false + document.body.classList.remove('app-fullscreen') + }, + getStoryById(id: number) { + return this.stories.find((story) => story.id === id) + }, + addMarker(story: Story, marker: Marker) { + story.markers.push(marker) + }, + }, +}) diff --git a/src/types/virages.d.ts b/src/types/virages.d.ts index 38fdb98..db1cb28 100644 --- a/src/types/virages.d.ts +++ b/src/types/virages.d.ts @@ -5,7 +5,7 @@ export interface Story { url: string // absolute or relative url (../public/deepzoom) markers: Marker[] displayMode: string // 'ARTICLE' | 'EDITOR' | 'PLAYER' | 'HIDDEN' - date_art_creation: Date + // date_art_creation: Date } export interface Marker { @@ -26,3 +26,22 @@ export interface Marker { zoom: number annotation: string } + +export interface ViewerConfiguration { + prefixUrl: string + crossOriginPolicy: string + animationTime: number + showNavigator: boolean + sequenceMode: boolean + showNavigationControl: boolean + drawer: string + preventDefaultAction: boolean + visibilityRatio: number + defaultZoomLevel: number + gestureSettingsMouse: { + scrollToZoom: boolean + clickToZoom: boolean + dblClickToZoom: boolean + dragToPan: boolean + } +}