import gql from 'graphql-tag'; import * as VueApolloComposable from '@vue/apollo-composable'; import * as VueCompositionApi from 'vue'; export type Maybe = T | null; export type Exact = { [K in keyof T]: T[K] }; export type MakeOptional = Omit & { [SubKey in K]?: Maybe }; export type MakeMaybe = Omit & { [SubKey in K]: Maybe }; export type ReactiveFunction = () => TParam; /** All built-in and custom scalars, mapped to their actual values */ export type Scalars = { ID: string; String: string; Boolean: boolean; Int: number; Float: number; /** An ISO 8601-encoded date */ ISO8601Date: any; /** An ISO 8601-encoded datetime */ ISO8601DateTime: any; /** Represents untyped JSON */ JSON: any; }; /** Key/value type with complex values. */ export type KeyComplexValue = { __typename?: 'KeyComplexValue'; key: Scalars['String']; value?: Maybe; }; /** Autogenerated return type of Login */ export type LoginPayload = { __typename?: 'LoginPayload'; /** The current session */ sessionId: Scalars['String']; }; /** Autogenerated return type of Logout */ export type LogoutPayload = { __typename?: 'LogoutPayload'; /** Was the logout successful? */ success: Scalars['Boolean']; }; /** All available mutations. */ export type Mutations = { __typename?: 'Mutations'; /** Performs a user login to create a session */ login?: Maybe; /** End the current session */ logout?: Maybe; }; /** All available mutations. */ export type MutationsLoginArgs = { fingerprint: Scalars['String']; login: Scalars['String']; password: Scalars['String']; }; /** An object with an ID. */ export type Node = { /** ID of the object. */ id: Scalars['ID']; }; /** Data of one object attribute value of another object */ export type ObjectAttributeValue = { __typename?: 'ObjectAttributeValue'; /** The object attribute record */ attribute: ObjectManagerAttribute; /** The value of the current object's object attribute */ value?: Maybe; }; /** Custom object fields (only editable & active) */ export type ObjectAttributeValueInterface = { objectAttributeValues: Array; }; /** An object manager attribute record */ export type ObjectManagerAttribute = Node & { __typename?: 'ObjectManagerAttribute'; active: Scalars['Boolean']; /** Create date/time of the record */ createdAt: Scalars['ISO8601DateTime']; /** User that created this record */ createdBy: User; dataOption?: Maybe; dataType: Scalars['String']; display: Scalars['String']; editable: Scalars['Boolean']; id: Scalars['ID']; name: Scalars['String']; position: Scalars['Int']; screens?: Maybe; /** Last update date/time of the record */ updatedAt: Scalars['ISO8601DateTime']; /** Last user that updated this record */ updatedBy: User; }; /** Organizations that users can belong to */ export type Organization = Node & ObjectAttributeValueInterface & { __typename?: 'Organization'; active: Scalars['Boolean']; /** Create date/time of the record */ createdAt: Scalars['ISO8601DateTime']; /** User that created this record */ createdBy: User; domain?: Maybe; domainAssignment: Scalars['Boolean']; id: Scalars['ID']; members: UserConnection; name: Scalars['String']; note?: Maybe; objectAttributeValues: Array; shared: Scalars['Boolean']; /** Last update date/time of the record */ updatedAt: Scalars['ISO8601DateTime']; /** Last user that updated this record */ updatedBy: User; }; /** Organizations that users can belong to */ export type OrganizationMembersArgs = { after?: Maybe; before?: Maybe; first?: Maybe; last?: Maybe; }; /** Information about pagination in a connection. */ export type PageInfo = { __typename?: 'PageInfo'; /** When paginating forwards, the cursor to continue. */ endCursor?: Maybe; /** When paginating forwards, are there more items? */ hasNextPage: Scalars['Boolean']; /** When paginating backwards, are there more items? */ hasPreviousPage: Scalars['Boolean']; /** When paginating backwards, the cursor to continue. */ startCursor?: Maybe; }; /** All available queries */ export type Queries = { __typename?: 'Queries'; /** Configuration required for front end operation (more results returned for authenticated users) */ applicationConfig: Array; /** Information about the authenticated user */ currentUser: User; /** Fetches an object given its ID. */ node?: Maybe; /** Fetches a list of objects given a list of IDs. */ nodes: Array>; /** Information about the current session */ sessionId: Scalars['String']; }; /** All available queries */ export type QueriesNodeArgs = { id: Scalars['ID']; }; /** All available queries */ export type QueriesNodesArgs = { ids: Array; }; /** Users (admins, agents and customers) */ export type User = Node & ObjectAttributeValueInterface & { __typename?: 'User'; active: Scalars['Boolean']; /** Create date/time of the record */ createdAt: Scalars['ISO8601DateTime']; /** User that created this record */ createdById: Scalars['Int']; email?: Maybe; fax?: Maybe; firstname?: Maybe; id: Scalars['ID']; image?: Maybe; imageSource?: Maybe; lastLogin?: Maybe; lastname?: Maybe; login: Scalars['String']; loginFailed: Scalars['Int']; mobile?: Maybe; note?: Maybe; objectAttributeValues: Array; organization?: Maybe; outOfOffice: Scalars['Boolean']; outOfOfficeEndAt?: Maybe; outOfOfficeReplacementId?: Maybe; outOfOfficeStartAt?: Maybe; password?: Maybe; phone?: Maybe; preferences?: Maybe; source?: Maybe; /** Last update date/time of the record */ updatedAt: Scalars['ISO8601DateTime']; /** Last user that updated this record */ updatedById: Scalars['Int']; verified: Scalars['Boolean']; vip?: Maybe; web?: Maybe; }; /** The connection type for User. */ export type UserConnection = { __typename?: 'UserConnection'; /** A list of edges. */ edges?: Maybe>>; /** A list of nodes. */ nodes?: Maybe>>; /** Information to aid in pagination. */ pageInfo: PageInfo; }; /** An edge in a connection. */ export type UserEdge = { __typename?: 'UserEdge'; /** A cursor for use in pagination. */ cursor: Scalars['String']; /** The item at the end of the edge. */ node?: Maybe; }; export type ObjectAttributeValuesFragment = { __typename?: 'ObjectAttributeValue', value?: string | null | undefined, attribute: { __typename?: 'ObjectManagerAttribute', name: string, display: string, dataType: string, dataOption?: any | null | undefined, screens?: any | null | undefined, editable: boolean, active: boolean } }; export type LoginMutationVariables = Exact<{ login: Scalars['String']; password: Scalars['String']; fingerprint: Scalars['String']; }>; export type LoginMutation = { __typename?: 'Mutations', login?: { __typename?: 'LoginPayload', sessionId: string } | null | undefined }; export type LogoutMutationVariables = Exact<{ [key: string]: never; }>; export type LogoutMutation = { __typename?: 'Mutations', logout?: { __typename?: 'LogoutPayload', success: boolean } | null | undefined }; export type ApplicationConfigQueryVariables = Exact<{ [key: string]: never; }>; export type ApplicationConfigQuery = { __typename?: 'Queries', applicationConfig: Array<{ __typename?: 'KeyComplexValue', key: string, value?: any | null | undefined }> }; export type CurrentUserQueryVariables = Exact<{ [key: string]: never; }>; export type CurrentUserQuery = { __typename?: 'Queries', currentUser: { __typename?: 'User', firstname?: string | null | undefined, lastname?: string | null | undefined, objectAttributeValues: Array<{ __typename?: 'ObjectAttributeValue', value?: string | null | undefined, attribute: { __typename?: 'ObjectManagerAttribute', name: string, display: string, dataType: string, dataOption?: any | null | undefined, screens?: any | null | undefined, editable: boolean, active: boolean } }>, organization?: { __typename?: 'Organization', name: string, objectAttributeValues: Array<{ __typename?: 'ObjectAttributeValue', value?: string | null | undefined, attribute: { __typename?: 'ObjectManagerAttribute', name: string, display: string, dataType: string, dataOption?: any | null | undefined, screens?: any | null | undefined, editable: boolean, active: boolean } }> } | null | undefined } }; export type SessionIdQueryVariables = Exact<{ [key: string]: never; }>; export type SessionIdQuery = { __typename?: 'Queries', sessionId: string }; export const ObjectAttributeValuesFragmentDoc = gql` fragment objectAttributeValues on ObjectAttributeValue { attribute { name display dataType dataOption screens editable active } value } `; export const LoginDocument = gql` mutation login($login: String!, $password: String!, $fingerprint: String!) { login(login: $login, password: $password, fingerprint: $fingerprint) { sessionId } } `; /** * __useLoginMutation__ * * To run a mutation, you first call `useLoginMutation` within a Vue component and pass it any options that fit your needs. * When your component renders, `useLoginMutation` returns an object that includes: * - A mutate function that you can call at any time to execute the mutation * - Several other properties: https://v4.apollo.vuejs.org/api/use-mutation.html#return * * @param options that will be passed into the mutation, supported options are listed on: https://v4.apollo.vuejs.org/guide-composable/mutation.html#options; * * @example * const { mutate, loading, error, onDone } = useLoginMutation({ * variables: { * login: // value for 'login' * password: // value for 'password' * fingerprint: // value for 'fingerprint' * }, * }); */ export function useLoginMutation(options: VueApolloComposable.UseMutationOptions | ReactiveFunction>) { return VueApolloComposable.useMutation(LoginDocument, options); } export type LoginMutationCompositionFunctionResult = VueApolloComposable.UseMutationReturn; export const LogoutDocument = gql` mutation logout { logout { success } } `; /** * __useLogoutMutation__ * * To run a mutation, you first call `useLogoutMutation` within a Vue component and pass it any options that fit your needs. * When your component renders, `useLogoutMutation` returns an object that includes: * - A mutate function that you can call at any time to execute the mutation * - Several other properties: https://v4.apollo.vuejs.org/api/use-mutation.html#return * * @param options that will be passed into the mutation, supported options are listed on: https://v4.apollo.vuejs.org/guide-composable/mutation.html#options; * * @example * const { mutate, loading, error, onDone } = useLogoutMutation(); */ export function useLogoutMutation(options: VueApolloComposable.UseMutationOptions | ReactiveFunction> = {}) { return VueApolloComposable.useMutation(LogoutDocument, options); } export type LogoutMutationCompositionFunctionResult = VueApolloComposable.UseMutationReturn; export const ApplicationConfigDocument = gql` query applicationConfig { applicationConfig { key value } } `; /** * __useApplicationConfigQuery__ * * To run a query within a Vue component, call `useApplicationConfigQuery` and pass it any options that fit your needs. * When your component renders, `useApplicationConfigQuery` returns an object from Apollo Client that contains result, loading and error properties * you can use to render your UI. * * @param options that will be passed into the query, supported options are listed on: https://v4.apollo.vuejs.org/guide-composable/query.html#options; * * @example * const { result, loading, error } = useApplicationConfigQuery(); */ export function useApplicationConfigQuery(options: VueApolloComposable.UseQueryOptions | VueCompositionApi.Ref> | ReactiveFunction> = {}) { return VueApolloComposable.useQuery(ApplicationConfigDocument, {}, options); } export type ApplicationConfigQueryCompositionFunctionResult = VueApolloComposable.UseQueryReturn; export const CurrentUserDocument = gql` query currentUser { currentUser { firstname lastname objectAttributeValues { ...objectAttributeValues } organization { name objectAttributeValues { ...objectAttributeValues } } } } ${ObjectAttributeValuesFragmentDoc}`; /** * __useCurrentUserQuery__ * * To run a query within a Vue component, call `useCurrentUserQuery` and pass it any options that fit your needs. * When your component renders, `useCurrentUserQuery` returns an object from Apollo Client that contains result, loading and error properties * you can use to render your UI. * * @param options that will be passed into the query, supported options are listed on: https://v4.apollo.vuejs.org/guide-composable/query.html#options; * * @example * const { result, loading, error } = useCurrentUserQuery(); */ export function useCurrentUserQuery(options: VueApolloComposable.UseQueryOptions | VueCompositionApi.Ref> | ReactiveFunction> = {}) { return VueApolloComposable.useQuery(CurrentUserDocument, {}, options); } export type CurrentUserQueryCompositionFunctionResult = VueApolloComposable.UseQueryReturn; export const SessionIdDocument = gql` query sessionId { sessionId } `; /** * __useSessionIdQuery__ * * To run a query within a Vue component, call `useSessionIdQuery` and pass it any options that fit your needs. * When your component renders, `useSessionIdQuery` returns an object from Apollo Client that contains result, loading and error properties * you can use to render your UI. * * @param options that will be passed into the query, supported options are listed on: https://v4.apollo.vuejs.org/guide-composable/query.html#options; * * @example * const { result, loading, error } = useSessionIdQuery(); */ export function useSessionIdQuery(options: VueApolloComposable.UseQueryOptions | VueCompositionApi.Ref> | ReactiveFunction> = {}) { return VueApolloComposable.useQuery(SessionIdDocument, {}, options); } export type SessionIdQueryCompositionFunctionResult = VueApolloComposable.UseQueryReturn;