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


TypeScript mobx-state-tree.flow函數代碼示例

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


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

示例1: flow

  .actions(self => ({
    loadTeams: flow(function* load() {
      const backendSrv = getEnv(self).backendSrv;
      const rsp = yield backendSrv.get('/api/teams/search/', { perpage: 50, page: 1 });
      self.map.clear();

      for (let team of rsp.teams) {
        self.map.set(team.id.toString(), Team.create(team));
      }
    }),

    setSearchQuery(query: string) {
      self.search = query;
    },

    loadById: flow(function* load(id: string) {
      if (self.map.has(id)) {
        return;
      }

      const backendSrv = getEnv(self).backendSrv;
      const team = yield backendSrv.get(`/api/teams/${id}`);
      self.map.set(id, Team.create(team));
    }),
  }));
開發者ID:cboggs,項目名稱:grafana,代碼行數:25,代碼來源:TeamsStore.ts

示例2: addMiddleware

 .actions(self => {
     addMiddleware(self, atomic)
     return {
         inc(x) {
             self.z += x
             return self.z
         },
         throwingFn(x) {
             self.z += x
             throw "Oops"
         },
         incProcess: flow(function*(x) {
             yield delay(2)
             self.z += x
             yield delay(2)
             self.z += x
             return self.z
         }),
         throwingProcess: flow(function*(x) {
             yield delay(2)
             self.z += x
             yield delay(2)
             self.z += x
             throw "Oops"
         })
     }
 })
開發者ID:lelandyolo,項目名稱:mobx-state-tree,代碼行數:27,代碼來源:atomic.ts

示例3: return

.actions(self => ({
  addPartialMovie: (obj: any) => {
    return (self as any).addMovie(obj, true);
  },
  addMovie: (obj: any, isPartial: boolean) => {
    if (self.movies.has(obj.id)) {
      const movie = self.movies.get(obj.id);
      return movie!.update(obj, isPartial);
    }

    return self.movies.put(
      Movie.create(mapMovie(obj, isPartial)),
    );
  },
  loadMovieById: flow(function* loadMovieById(movieId: string) {
    const start = new Date();
    const end = addDays(start, 5);
    const result = yield client.query({
      query: fetchMovieByIdQuery,
      fetchPolicy: 'network-only',
      variables: {
        movieId,
        start: start.toISOString().substr(0, 10),
        end: end.toISOString().substr(0, 10),
      },
    });

    (self as any).addMovie(result.data.Movie, false);
  }),
  loadNewMovies: flow(function* loadNewMovies() {
    const query = (fetchPolicy: FetchPolicy = 'network-only') => client.query({
      fetchPolicy,
      query: fetchNewMoviesQuery,
      variables: {
        from: new Date().toISOString().substr(0, 10),
      },
    });

    let result = yield query();
    const isNetworkError = result.error && result.error.message.includes('Network error');

    if (isNetworkError) {
      result = yield query('cache-only');
    }

    self.isOffline = isNetworkError;
    self.isCache = isNetworkError && result.data;

    if (!result.data) {
      return;
    }

    result.data.allMovies.map(Movies.addPartialMovie);
    self.comingSoon.clear();
    self.comingSoon.push(
      ...result.data.allMovies.map((movie: { id: string }) => movie.id),
    );
  }),
}))
開發者ID:birkir,項目名稱:kvikmyndr-app,代碼行數:59,代碼來源:movies.ts

示例4: flow

.actions(self => ({
  loadWeek: flow(function* loadWeek() {

    self.loading = true;

    const start = new Date();
    const end = addDays(start, 5);

    const query = (fetchPolicy: FetchPolicy = 'network-only') => new Promise((resolve) => {
      client.query({
        fetchPolicy,
        query: fetchMoviesForWeekQuery,
        variables: {
          start: start.toISOString().substr(0, 10),
          end: end.toISOString().substr(0, 10),
        },
      })
      .then(resolve);
      if (fetchPolicy === 'network-only') {
        setTimeout(() => resolve({ error: { message: 'Network error' } }), 5000);
      }
    });

    let result = yield query();
    const isNetworkError = result.error && result.error.message.includes('Network error');

    if (isNetworkError) {
      result = yield query('cache-only');
    }

    self.isOffline = isNetworkError;
    self.isCache = isNetworkError && result.data;

    if (!result.data) {
      return;
    }
    result.data.allMovies.map(Movies.addPartialMovie);

    result.data.allMovies.forEach((movie: IMovieFromDb) => {
      movie.showtimes.forEach((showtime) => {
        const dateKey = addHours(showtime.playingAt, -4).toISOString().substr(0, 10);

        if (!self.dates.has(dateKey)) {
          self.dates.put({
            date: dateKey,
            movies: {},
          });
        }

        const dateOf = self.dates.get(dateKey);
        if (dateOf) {
          dateOf.movies.put({ id: movie.id, movie: movie.id });
        }
      });
    });

    self.loaded = true;
    self.loading = false;
  }),
}))
開發者ID:birkir,項目名稱:kvikmyndr-app,代碼行數:60,代碼來源:in-theaters.ts

示例5: update

 .actions(self => ({
   update() {
     return flow(function* () {
       self.updateMetadata = yield CodePush.getUpdateMetadata();
     })();
   },
 }))
開發者ID:birkir,項目名稱:kvikmyndr-app,代碼行數:7,代碼來源:update.ts

示例6: flow

  .actions(self => ({
    loadRules: flow(function* load(filters) {
      const backendSrv = getEnv(self).backendSrv;
      self.stateFilter = filters.state; // store state filter used in api query
      const apiRules = yield backendSrv.get('/api/alerts', filters);
      self.rules.clear();

      for (let rule of apiRules) {
        setStateFields(rule, rule.state);

        if (rule.state !== 'paused') {
          if (rule.executionError) {
            rule.info = 'Execution Error: ' + rule.executionError;
          }
          if (rule.evalData && rule.evalData.noData) {
            rule.info = 'Query returned no data';
          }
        }

        self.rules.push(AlertRule.create(rule));
      }
    }),
    setSearchQuery(query: string) {
      self.search = query;
    },
  }));
開發者ID:GPegel,項目名稱:grafana,代碼行數:26,代碼來源:AlertListStore.ts

示例7: flow

 .actions(self => ({
     setTitle: flow(function* setTitle(newTitle) {
         self.helper() // should not be logged
         yield self.helper2() // should be logged
         self.title = newTitle
         return
     })
 }))
開發者ID:lelandyolo,項目名稱:mobx-state-tree,代碼行數:8,代碼來源:action-logger.ts

示例8: flow

  .actions(self => ({
    load: flow(function* load(uid: string) {
      // clear folder state
      if (self.folder && self.folder.uid !== uid) {
        self.folder = null;
      }

      const backendSrv = getEnv(self).backendSrv;
      const res = yield backendSrv.getFolderByUid(uid);
      self.folder = Folder.create({
        id: res.id,
        uid: res.uid,
        title: res.title,
        url: res.url,
        canSave: res.canSave,
        hasChanged: false,
        version: res.version,
      });

      return res;
    }),

    setTitle: function(originalTitle: string, title: string) {
      self.folder.title = title;
      self.folder.hasChanged = originalTitle.toLowerCase() !== title.trim().toLowerCase() && title.trim().length > 0;
    },

    saveFolder: flow(function* saveFolder(options: any) {
      const backendSrv = getEnv(self).backendSrv;
      self.folder.title = self.folder.title.trim();

      const res = yield backendSrv.updateFolder(self.folder, options);
      self.folder.url = res.url;
      self.folder.version = res.version;

      return `${self.folder.url}/settings`;
    }),

    deleteFolder: flow(function* deleteFolder() {
      const backendSrv = getEnv(self).backendSrv;

      return backendSrv.deleteFolder(self.folder.uid);
    }),
  }));
開發者ID:InvariantIO,項目名稱:grafana,代碼行數:44,代碼來源:FolderStore.ts

示例9: flow

  .actions(self => {
    const fetchItems = flow(function*() {
      const items: Array<typeof Item.Type> = yield api.getItems()

      items.forEach(item => self._cache.set(item.id.toString(), item))
    })

    return {
      fetchItems
    }
  })
開發者ID:chaucerbao,項目名稱:react-project-template,代碼行數:11,代碼來源:items.ts

示例10: flow

.actions((self) => {

  const addCinema = (obj: any) => {
    const cinema = { ...obj };
    if (self.cinemas.has(cinema.id)) {
      return;
    }

    return self.cinemas.put(
      Cinema.create(cinema),
    );
  };

  const loadAllCinemas = flow(function* () {

    const result = yield client.query({
      query: fetchAllCinemas,
      fetchPolicy: 'network-only',
    });

    result.data.allCinemas.map(addCinema);
  });

  const loadCinemaById = flow(function* (cinemaId: string) {
    const result = yield client.query({
      query: fetchCinemaByIdQuery,
      fetchPolicy: 'network-only',
      variables: {
        cinemaId,
      },
    });

    addCinema(result.data.Cinema);
  });

  return {
    loadAllCinemas,
    loadCinemaById,
    addCinema,
  };
})
開發者ID:birkir,項目名稱:kvikmyndr-app,代碼行數:41,代碼來源:cinemas.ts


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