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


TypeScript core.createModel函數代碼示例

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


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

示例1: createModel

const Gist = createModel({
  state: {
    gist: {},
    comments: []
  },
  reducers: {
    setGist: (state: IGistState, payload: any) => {
      state.gist = payload
      return state
    },
    setComments: (state: IGistState, payload: any[]) => {
      return (state.comments = payload)
    }
  },
  effects: {
    async getGist(payload: string) {
      try {
        const { data } = await github.get(`/gists/${payload}`, {
          headers: {
            Accept: 'application/vnd.github.v3.html'
          },
          responseType: 'text'
        })

        for (const filename in data.files) {
          if (data.files.hasOwnProperty(filename)) {
            const file = data.files[filename]
            const res = await github.post(
              '/markdown',
              {
                text: '```' + file.language + '\n' + file.content + '\n```',
                mode: 'markdown'
              },
              { responseType: 'text' }
            )
            file.html = res.data
          }
        }
        dispatch.gist.getComments(payload)
        dispatch.gist.setGist(data)
      } catch (err) {
        console.error(err)
      }
    },
    async getComments(payload: string) {
      try {
        const { data } = await github.get(`/gists/${payload}/comments`, {
          headers: {
            Accept: 'application/vnd.github.v3.html'
          },
          responseType: 'text'
        })

        dispatch.gist.setComments(data)
      } catch (err) {
        console.error(err)
      }
    }
  }
})
開發者ID:duhongjun,項目名稱:blog,代碼行數:60,代碼來源:gist.ts

示例2: createModel

const Todos = createModel({
  state: {
    meta: {
      page: 1,
      perPage: 10,
      total: 0
    },
    todos: [],
    labels: []
  },
  reducers: {
    setTodos: (state: ITodoState, payload: ISetTodos) => {
      state.todos = payload.todos
      state.meta = payload.meta
      return state
    },
    setLabel: (state: ITodoState, payload: any[]) => {
      return (state.labels = payload)
    }
  },
  effects: {
    async getTodos(payload: IGetTodos) {
      const { page, perPage } = payload.meta
      try {
        const res = await github.get(`/repos/${CONFIG.owner}/${CONFIG.todo_repo}/issues`, {
          params: { creator: CONFIG.owner, page, per_page: perPage, state: 'all' }
        })
        const todos = res.data
        const link = res.headers.link
        let newMeta = payload.meta
        if (link) {
          const isLast = link.match(/<([^>]+)>(?=\;\s+rel="last")/)
          const lastPage = isLast ? isLast[1].match(/page=(\d+)/)[1] : page
          newMeta = {
            ...payload.meta,
            ...{ page, per_page: perPage, total: lastPage * perPage }
          }
        }
        dispatch.todos.setTodos({ todos, meta: newMeta })
      } catch (err) {
        console.error(err)
      }
    },
    async getLabels() {
      const { data } = await github.get(`/repos/${CONFIG.owner}/${CONFIG.todo_repo}/labels`)
      dispatch.todos.setLabel(data)
    }
  }
})
開發者ID:duhongjun,項目名稱:blog,代碼行數:49,代碼來源:todos.ts

示例3: createModel

const Cases = createModel({
  state: {
    meta: {
      page: 1,
      perPage: 10,
      total: 0
    },
    cases: []
  },
  reducers: {
    setCases: (state: ICaseState, payload: ISetCase) => {
      state.cases = payload.cases
      state.meta = payload.meta
      return state
    }
  },
  effects: {
    async getCases(payload: IGetCase) {
      const { page, perPage } = payload.meta

      try {
        const { data, headers } = await github.get(`/repos/${CONFIG.owner}/showcase/issues`)
        const link = headers.link
        let newMeta = payload.meta
        const cases: any[] = []
        if (link) {
          const isLast = link.match(/<([^>]+)>(?=\;\s+rel="last")/)
          const lastPage = isLast ? isLast[1].match(/page=(\d+)/)[1] : page
          newMeta = {
            ...payload.meta,
            ...{ page, per_page: perPage, total: lastPage * perPage }
          }
        }
        data.forEach((c: any) => {
          cases.push(dataParser(c))
        })
        dispatch.cases.setCases({ cases, meta: newMeta })
      } catch (err) {
        console.error(err)
      }
    }
  }
})
開發者ID:duhongjun,項目名稱:blog,代碼行數:43,代碼來源:cases.ts

示例4: createModel

const Repo = createModel({
  state: {
    repo: {},
    readme: '',
    events: []
  },
  reducers: {
    setRepo: (state: IRepoState, payload: any) => {
      return (state.repo = payload)
    },
    setReadme: (state: IRepoState, payload: string) => {
      return (state.readme = payload)
    },
    setEvents: (state: IRepoState, payload: any[]) => {
      return (state.events = payload)
    }
  },
  effects: {
    async getRepo(payload: string) {
      try {
        const { data = {} } = await github.get(`/repos/${CONFIG.owner}/${payload}`, {
          headers: {
            Accept: 'application/vnd.github.mercy-preview+json;charset=utf-8'
          }
        })
        dispatch.repo.getReadme(payload)
        dispatch.repo.getEvents(payload)
        dispatch.repo.setRepo(data)
      } catch (err) {
        console.error(err)
      }
    },
    async getReadme(payload: string) {
      try {
        const { data } = await github.get(`/repos/${CONFIG.owner}/${payload}/readme`, {
          headers: {
            Accept: 'application/vnd.github.v3.html'
          },
          responseType: 'text'
        })
        dispatch.repo.setReadme(data)
      } catch (err) {
        console.error(err)
      }
    },
    async getEvents(payload: string) {
      try {
        const { data } = await github.get(`/repos/${CONFIG.owner}/${payload}/events`)
        dispatch.repo.setEvents(data)
      } catch (err) {
        console.error(err)
      }
    }
  }
})
開發者ID:duhongjun,項目名稱:blog,代碼行數:55,代碼來源:repo.ts

示例5: createModel

const Posts = createModel({
  state: {
    meta: {
      page: 1,
      perPage: 10,
      total: 0
    },
    posts: []
  },
  reducers: {
    setPosts: (state: IPostState, payload: ISetPosts) => {
      state.posts = payload.posts
      state.meta = payload.meta
      return state
    }
  },
  effects: {
    async getPosts(payload: IGetPosts) {
      const { page, perPage } = payload.meta

      try {
        const res = await github.get(`/repos/${CONFIG.owner}/${CONFIG.repo}/issues`, {
          params: { creator: CONFIG.owner, page, per_page: perPage, state: 'open' }
        })
        const posts = res.data
        const link = res.headers.link
        let newMeta = payload.meta
        /**
         * Pagination
         * # see detail https://developer.github.com/guides/traversing-with-pagination/
         */
        if (link) {
          const isLast = link.match(/<([^>]+)>(?=\;\s+rel="last")/)
          const lastPage = isLast ? isLast[1].match(/page=(\d+)/)[1] : page
          newMeta = {
            ...payload.meta,
            ...{ page, per_page: perPage, total: lastPage * perPage }
          }
        }
        posts.forEach((post: any) => {
          // 獲取第一張圖片作為縮略圖
          const match = /!\[[^\]]+\]\(([^\)]+)\)/im.exec(post.body)
          if (match && match[1]) {
            post.thumbnails = match[1]
          }
        })
        dispatch.posts.setPosts({ posts, meta: newMeta })
      } catch (err) {
        console.error(err)
      }
    }
  }
})
開發者ID:duhongjun,項目名稱:blog,代碼行數:53,代碼來源:posts.ts

示例6: createModel

  todo: any
}

const Todos = createModel({
  state: {
    todo: {}
  },
  reducers: {
    setTodo: (state: ITodoState, payload: any) => {
      return (state.todo = payload)
    }
  },
  effects: {
    async getTodo(payload: string) {
      try {
        const { data } = await github.get(`/repos/${CONFIG.owner}/${CONFIG.todo_repo}/issues/${payload}`, {
          headers: {
            Accept: 'application/vnd.github.v3.html'
          },
          responseType: 'text'
        })
        dispatch.todo.setTodo(data)
      } catch (err) {
        console.error(err)
      }
    }
  }
})

export default Todos
開發者ID:duhongjun,項目名稱:blog,代碼行數:30,代碼來源:todo.ts

示例7: createModel

const Gists = createModel({
  state: {
    meta: {
      page: 1,
      perPage: 10,
      total: 0
    },
    gists: []
  },
  reducers: {
    setGists: (state: IGistState, payload: ISetGists) => {
      state.gists = payload.gists
      state.meta = payload.meta
      return state
    }
  },
  effects: {
    async getGists(payload: IGetGists) {
      const { page, perPage } = payload.meta

      try {
        const res = await github.get(`/users/${CONFIG.owner}/gists`, {
          params: { page, per_page: perPage }
        })
        const gists = res.data
        const link = res.headers.link
        let newMeta = payload.meta
        if (link) {
          const isLast = link.match(/<([^>]+)>(?=\;\s+rel="last")/)
          const lastPage = isLast ? isLast[1].match(/page=(\d+)/)[1] : page
          newMeta = {
            ...payload.meta,
            ...{ page, per_page: perPage, total: lastPage * perPage }
          }
        }
        dispatch.gists.setGists({ gists, meta: newMeta })
      } catch (err) {
        console.error(err)
      }
    }
  }
})
開發者ID:duhongjun,項目名稱:blog,代碼行數:42,代碼來源:gists.ts

示例8: createModel

}

const About = createModel({
  state: {
    about: ''
  },
  reducers: {
    storeAboutMe: (state: IAboutState, payload: ISetAbout) => {
      return (state.about = payload.about)
    }
  },
  effects: {
    async getAboutMe() {
      let html = ''
      try {
        const response = await github.get(`/repos/${CONFIG.owner}/${CONFIG.repo}/contents/ABOUTME.md`, {
          headers: {
            Accept: 'application/vnd.github.v3.html'
          },
          responseType: 'text'
        })
        html = response.data
      } catch (err) {
        console.error(err)
      }
      dispatch.about.storeAboutMe(html)
    }
  }
})

export default About
開發者ID:duhongjun,項目名稱:blog,代碼行數:31,代碼來源:about.ts

示例9: createModel

const Repos = createModel({
  state: {
    meta: {
      page: 1,
      perPage: 10,
      total: 0
    },
    repos: []
  },
  reducers: {
    setRepos: (state: IRepoState, payload: ISetRepos) => {
      state.repos = payload.repos
      state.meta = payload.meta
      return state
    }
  },
  effects: {
    async getRepos(payload: IGetRepos) {
      const { page, perPage } = payload.meta

      try {
        const res = await github.get(`/users/${CONFIG.owner}/repos?sort=created`, {
          params: { page, per_page: perPage },
          headers: {
            Accept: 'application/vnd.github.mercy-preview+json;charset=utf-8'
          }
        })
        const repos = res.data
        const link = res.headers.link
        let newMeta = payload.meta
        /**
         * Pagination
         * # see detail https://developer.github.com/guides/traversing-with-pagination/
         */
        if (link) {
          const isLast = link.match(/<([^>]+)>(?=\;\s+rel="last")/)
          const lastPage = isLast ? isLast[1].match(/page=(\d+)/)[1] : page
          newMeta = {
            ...payload.meta,
            ...{ page, per_page: perPage, total: lastPage * perPage }
          }
        }
        dispatch.repos.setRepos({ repos, meta: newMeta })
      } catch (err) {
        console.error(err)
      }
    }
  }
})
開發者ID:duhongjun,項目名稱:blog,代碼行數:49,代碼來源:repos.ts

示例10: createModel

const Post = createModel({
  state: {
    post: {},
    comments: []
  },
  reducers: {
    setPost: (state: IPostState, payload: any) => {
      return (state.post = payload)
    },
    setComments: (state: IPostState, payload: any[]) => {
      return (state.comments = payload)
    }
  },
  effects: {
    async getPost(payload: number) {
      let post: ISimpleObj = {}
      try {
        const { data } = await github.get(`/repos/${CONFIG.owner}/${CONFIG.repo}/issues/${payload}`, {
          headers: {
            Accept: 'application/vnd.github.v3.html'
          },
          responseType: 'text'
        })
        post = data
        // post.filter_html = htmlFilter(data.body_html)
        post.filter_html = data.body_html
      } catch (err) {
        console.error(err)
      }
      dispatch.post.setPost(post)
    },
    async getIssuesComments(payload: number) {
      try {
        const { data } = await github.get(`/repos/${CONFIG.owner}/${CONFIG.repo}/issues/${payload}/comments`, {
          headers: {
            Accept: 'application/vnd.github.v3.html'
          },
          responseType: 'text'
        })
        dispatch.post.setComments(data)
      } catch (err) {
        console.error(err)
      }
    }
  }
})
開發者ID:duhongjun,項目名稱:blog,代碼行數:46,代碼來源:post.ts


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