當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript apollo-mantra.mutation函數代碼示例

本文整理匯總了TypeScript中apollo-mantra.mutation函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript mutation函數的具體用法?TypeScript mutation怎麽用?TypeScript mutation使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了mutation函數的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: emailResetLink

function emailResetLink(dispatch: Function, email: string, callback: Function) {
  const ed = errorDispatch(dispatch);

  if (!isNotEmpty(ed, email) || !isEmail(ed, email)) {
    if (callback) { callback(); }
    return;
  }

  dispatch(mutation({
    query: `mutation requestResetPassword($email: String!) {
      requestResetPassword(email: $email)
    }`,
    variables: {
      email
    },
    catchCallback: (error) => {
      let err = error.message;
      if (error.graphQLErrors) {
        err = error.graphQLErrors[0];
      }

      if (err.message === 'User email does not exist') {
        dispatch(actions.showError('accounts.error.emailNotFound'));
      } else {
        dispatch(actions.showError('accounts.error.unknownError'));
      }
      if (callback) { callback(); }
    },
    thenCallback: (data: any) => {
      dispatch(actions.showInfo('accounts.messages.passwordResetEmailSent'));
      if (callback) { callback(); }
    }
  }));
}
開發者ID:tomitrescak,項目名稱:meteor-accounts-ui-redux-semantic,代碼行數:34,代碼來源:accounts.ts

示例2: resendVerification

function resendVerification(dispatch: Function, email: string, callback: Function) {
  const ed = errorDispatch(dispatch);

  if (!isNotEmpty(ed, email) || !isEmail(ed, email)) {
    if (callback) { callback(); }
    return;
  }

  dispatch(mutation({
    query: `mutation requestResendVerification($email: String!) {
      requestResendVerification(email: $email)
    }`,
    variables: {
      email
    },
    errorCallback: (err) => {
      if (err.message === 'User not found') {
        dispatch(actions.showError('accounts.error.emailNotFound'));
      } if (err.message === 'User already verified') {
        dispatch(actions.showError('accounts.error.userAlreadyVerified'));
      } else {
        dispatch(actions.showError('accounts.error.unknownError'));
      }
      if (callback) { callback(); }
    },
    thenCallback: (data: any) => {
      dispatch(actions.showInfo('accounts.messages.verificationEmailSent'));
      if (callback) { callback(); }
    }
  }));
}
開發者ID:tomitrescak,項目名稱:meteor-accounts-ui-redux-semantic,代碼行數:31,代碼來源:accounts.ts

示例3: resume

function resume(dispatch: Function, token: string, tokenExpiration: number, profileData: string) {
  if (new Date().getTime() > tokenExpiration) {
    dispatch(actions.logOut());
    return;
  }

  dispatch(actions.changeLoggingIn(true));

  dispatch(mutation({
    query: `mutation resume($token: String!) {
      resume(token: $token) {
        hashedToken
        expires
        user {
          _id
          profile {
            ${profileData}
          }
          roles
        }
      }
    }`,
    variables: {
      token
    },
    catchCallback: (error) => {
      dispatch(actions.changeLoggingIn(false));
      dispatch(actions.logOut());
    },
    thenCallback: (data: any) => {
      dispatch(actions.changeLoggingIn(false));
      dispatch(actions.logIn(data.resume));
    }
  }));
}
開發者ID:tomitrescak,項目名稱:meteor-accounts-ui-redux-semantic,代碼行數:35,代碼來源:accounts.ts

示例4: resetPassword

function resetPassword(dispatch: Function, token: string, password: string, passwordConfirm: string, profileData: string, callback: Function): void {
  const ed = errorDispatch(dispatch);

  if (!isNotEmpty(ed, password) || !areValidPasswords(ed, password, passwordConfirm)) {
    return;
  }

  dispatch(mutation({
    query: `mutation resetPassword($token: String!, $password: String!) {
      resetPassword(token: $token, password: $password) {
        hashedToken
        expires
        user {
          _id
          profile {
            ${profileData}
          }
          roles
        }
      }
    }`,
    variables: {
      token,
      password
    },
    catchCallback: (error) => {
      let err = error;
      if (error.graphQLErrors) {
        err = error.graphQLErrors[0];
      }

      if (err.message === 'jwt expired') {
        ed('accounts.error.tokenExpired');
      } else if (err.message === 'invalid token') {
        ed('accounts.error.invalidToken');
      } else if (err.message === 'jwt malformed') {
        ed('accounts.error.invalidToken');
      } else {
        ed(err.message);
      }
      if (callback) { callback(); }
    },
    thenCallback: (data: any) => {
      // dispatch(actions.showInfo('accounts.messages.passwordChanged'));
      const url = location.href.split('?')[0];
      if (history && history.pushState) {
        history.pushState(null, '', url);
        dispatch(actions.logIn(data.resetPassword));
      } else {
        dispatch(actions.logIn(data.resetPassword));
        window.location.href = url;
      }
      if (callback) { callback(); }
    }
  }));
}
開發者ID:tomitrescak,項目名稱:meteor-accounts-ui-redux-semantic,代碼行數:56,代碼來源:accounts.ts

示例5: register

function register(dispatch: Function, name: string, email: string, password: string, passwordConfirm: string, profileData: string, callback: any) {
  const ed = errorDispatch(dispatch);

  let user = {
    email: email,
    password: password,
    profile: {
      name: name
    }
  };

  if (!isNotEmpty(ed, email) || !isNotEmpty(ed, password) || !isEmail(ed, email) || !areValidPasswords(ed, password, passwordConfirm)) {
    return;
  }

  dispatch(mutation({
    query: `mutation createAccountAndLogin($user: UserPasswordInput!) {
      createAccountAndLogin(user: $user) {
        hashedToken
        expires
        user {
          _id
          profile {
            ${profileData}
          }
          roles
        }
      }
    }`,
    variables: {
      user,
      password
    },
    catchCallback: (error) => {
      let err = error.message;
      if (error.graphQLErrors) {
        err = error.graphQLErrors[0];
      }
      if (err.message === 'User with this email already exists!') {
        ed('accounts.error.emailAlreadyExists');
      } else if (err.message === 'Email doesn\'t match the criteria.') {
        ed('accounts.error.emailLimited');
      } else if (err.message === 'Login forbidden') {
        ed('accounts.error.loginForbidden');
      } else {
        ed('accounts.error.unknownError');
      }
      if (callback) { callback(); }
    },
    thenCallback: (data: any) => {
      dispatch(actions.logIn(data.createAccountAndLogin));
      if (callback) { callback(); }
    }
  }));
}
開發者ID:tomitrescak,項目名稱:meteor-accounts-ui-redux-semantic,代碼行數:55,代碼來源:accounts.ts

示例6: signIn

function signIn(dispatch: Function, email: string, password: string, profileData: string, callback: Function): any {
  dispatch(actions.clearMessages());

  const ed = errorDispatch(dispatch);
  email = trimInput(email.toLowerCase());

  if (!isNotEmpty(ed, email) || !isEmail(ed, email) || !isNotEmpty(ed, password) || !isValidPassword(ed, password)) {
    return;
  }

  dispatch(mutation({
    query: `mutation loginWithPassword($user: UserPasswordInput!) {
      loginWithPassword(user: $user) {
        hashedToken
        expires
        user {
          _id
          profile {
            ${profileData}
          }
          roles
        }
      }
    }`,
    variables: {
      user: {
        email,
        password
      }
    },
    catchCallback: (error) => {
      let err = error.message;
      if (error.graphQLErrors) {
        err = error.graphQLErrors[0];
      }

      if (err.message === 'Email not verified') {
        dispatch(actions.showError('accounts.error.emailNotVerified'));
      } else {
        dispatch(actions.showError('accounts.error.invalidCredentials'));
      }

      if (callback) { callback(); }
    },
    // errorCallback: (err) => {
    //   dispatch(actions.showError('accounts.error.invalidCredentials'));
    //   if (callback) { callback(); }
    // },
    thenCallback: (data: any) => {
      dispatch(actions.logIn(data.loginWithPassword));
      if (callback) { callback(); }
    }
  }));
}
開發者ID:tomitrescak,項目名稱:meteor-accounts-ui-redux-semantic,代碼行數:54,代碼來源:accounts.ts

示例7: verify

function verify(dispatch: Function, token: string, profileData: string): void {
  const ed = errorDispatch(dispatch);

  dispatch(mutation({
    query: `mutation verify($token: String!) {
      verify(token: $token) {
        hashedToken
        expires
        user {
          _id
          profile {
            ${profileData}
          }
          roles
        }
      }
    }`,
    variables: {
      token
    },
    catchCallback: (error) => {
      let err = error.message;
      if (error.graphQLErrors) {
        err = error.graphQLErrors[0];
      }

      if (err.message === 'jwt expired') {
        ed('accounts.error.tokenExpired');
      } else if (err.message === 'invalid token') {
        ed('accounts.error.invalidToken');
      } else if (err.message === 'jwt malformed') {
        ed('accounts.error.invalidToken');
      } else {
        ed(err.message);
      }
    },
    thenCallback: (data: any) => {
      const url = location.href.split('?')[0];
      dispatch(actions.logIn(data.verify));

      if (history && history.pushState) {
        history.pushState(null, '', url);
      } else {
        window.location.href = url;
      }
    }
  }));
}
開發者ID:tomitrescak,項目名稱:meteor-accounts-ui-redux-semantic,代碼行數:48,代碼來源:accounts.ts


注:本文中的apollo-mantra.mutation函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。