diff --git a/manifest.webapp b/manifest.webapp index 892ca51..a92ec15 100644 --- a/manifest.webapp +++ b/manifest.webapp @@ -63,6 +63,11 @@ "type": "io.cozy.identities", "description": "Required by Papillon", "verbs": ["GET"] + }, + "triggers": { + "type": "io.cozy.triggers", + "description": "Required by Papillon", + "verbs": ["GET"] } } } diff --git a/src/hooks/useCurrentAccountFolderLink.js b/src/hooks/useCurrentAccountFolderLink.js index 2b68932..a93c791 100644 --- a/src/hooks/useCurrentAccountFolderLink.js +++ b/src/hooks/useCurrentAccountFolderLink.js @@ -1,5 +1,5 @@ import { useState, useEffect } from 'react' -import { buildAccountFolderQuery } from 'src/queries' +import { buildAccountQuery, buildTriggerQuery } from 'src/queries' import { useClient, generateWebLink } from 'cozy-client' @@ -13,21 +13,34 @@ const useCurrentAccountFolderLink = () => { useEffect(() => { const fetchCurrentAccountFolderLink = async () => { - const accountFolderQuery = buildAccountFolderQuery( - currentAccount?.cozyMetadata?.sourceAccountIdentifier + const accountQuery = buildAccountQuery() + + const { data: accountResult } = await client.query( + accountQuery.definition(), + accountQuery.options ) - const { data } = await client.query( - accountFolderQuery.definition(), - accountFolderQuery.options + if (!accountResult[0]?._id) { + return + } + + const triggerQuery = buildTriggerQuery(accountResult[0]._id) + + const { data: triggerResult } = await client.query( + triggerQuery.definition(), + triggerQuery.options ) + if (!triggerResult[0]?.message?.folder_to_save) { + return + } + const webLink = generateWebLink({ cozyUrl: client.getStackClient().uri, slug: 'drive', subDomainType: client.capabilities.flat_subdomains ? 'flat' : 'nested', pathname: '', - hash: `/folder/${data[0]._id}`, + hash: `/folder/${triggerResult[0].message.folder_to_save}`, searchParams: [] }) diff --git a/src/queries/index.js b/src/queries/index.js index 371df2e..207e0ad 100644 --- a/src/queries/index.js +++ b/src/queries/index.js @@ -126,17 +126,38 @@ export const buildPresenceQuery = sourceAccountIdentifier => ({ } }) -export const buildAccountFolderQuery = accountIdentifier => ({ +export const buildAccountQuery = () => ({ definition: () => - Q('io.cozy.files') - .partialIndex({ type: 'directory', trashed: false }) - .referencedBy({ - _id: accountIdentifier, - _type: 'io.cozy.accounts.sourceAccountIdentifier' + Q('io.cozy.accounts') + .where({ + account_type: 'pronote' + }) + .partialIndex({ + account_type: 'pronote' }), options: { - as: 'io.cozy.files/byReferencedAccountIdentifier/' + accountIdentifier, - fetchPolicy: defaultFetchPolicy, - singleDocData: true + as: 'io.cozy.files/account_type/pronote', + fetchPolicy: defaultFetchPolicy + } +}) + +export const buildTriggerQuery = accountId => ({ + definition: () => + Q('io.cozy.triggers') + .where({ + message: { + account: accountId, + konnector: 'pronote' + } + }) + .partialIndex({ + message: { + account: accountId, + konnector: 'pronote' + } + }), + options: { + as: 'io.cozy.triggers/konnector/pronote/account/' + accountId, + fetchPolicy: defaultFetchPolicy } })