Skip to content

  • Projects
  • Groups
  • Snippets
  • Help
    • Loading...
    • Help
    • Support
    • Submit feedback
  • Sign in / Register
N
Neos
  • Project overview
    • Project overview
    • Details
    • Activity
    • Releases
  • Repository
    • Repository
    • Files
    • Commits
    • Branches
    • Tags
    • Contributors
    • Graph
    • Compare
    • Locked Files
  • Issues 1
    • Issues 1
    • List
    • Boards
    • Labels
    • Service Desk
    • Milestones
  • Merge Requests 2
    • Merge Requests 2
  • CI / CD
    • CI / CD
    • Pipelines
    • Jobs
    • Schedules
  • Security & Compliance
    • Security & Compliance
    • Dependency List
    • License Compliance
  • Packages
    • Packages
    • List
    • Container Registry
  • Analytics
    • Analytics
    • CI / CD
    • Code Review
    • Insights
    • Issues
    • Repository
    • Value Stream
  • Wiki
    • Wiki
  • Snippets
    • Snippets
  • Members
    • Members
  • Collapse sidebar
  • Activity
  • Graph
  • Create a new issue
  • Jobs
  • Commits
  • Issue Boards
  • MyCard
  • Neos
  • Merge Requests
  • !169

Merged
Opened Apr 16, 2023 by timel@timel14 of 14 tasks completed14/14 tasks
  • Report abuse
Report abuse

Valtio

  • Overview 4
  • Commits 41
  • Pipelines 29
  • Changes 148
  • 添加 valtio store
  • 添加 valtio eslint plugin
  • store通过context从根节点注入
  • 新增 chat store
  • 新增 join store
  • 新增 player store
  • 新增 mora store
  • 定义 duel store 类型
  • service之中使用store
  • components之中使用store
  • 基础测试
  • 移除redux相关代码
    • 注释掉相关代码
    • 移除

见这个issue: #3 (closed)

尝试写一些基础的代码,尝试在redux的基础上加入valtio store,最后再将redux去掉。

示例代码:

// ts 之中使用 Valtio
import { moraStore } from "@/stores"; // add

export default function handleDuelStart(_pb: ygopro.YgoStocMsg) {
  const dispatch = store.dispatch;
  dispatch(duelStart());

  moraStore.duelStart = true; // 直接修改 store
}
// 组件之中使用 Valtio
const Mora = () => {
  const snapMora = useSnapshot(stateMora); // 获取 snapshot

  const handleSelectMora = (selected: string) => {
    sendHandResult(selected);
    dispatch(unSelectHandAble());
    stateMora.selectHandAble = false; // 直接修改 store
  };

  const handleSelectTp = (isFirst: boolean) => {
    sendTpResult(isFirst);
    dispatch(unSelectTpAble());
    stateMora.selectTpAble = false;
  };

  return <>{snapMora.selectHandAble}<> // 从 snapshot 上读取状态

简单来说就是:

  • ts中store搭配subscribe和subscribeKey
  • 组件中useSnapshot搭配useEffect
Edited Apr 27, 2023 by timel
Assignee
Assign to
None
Milestone
None
Assign milestone
Time tracking
0
Labels
None
Assign labels
  • View project labels
Reference: mycard/Neos!169

Revert this merge request

This will create a new commit in order to revert the existing changes.

Switch branch
Cancel
A new branch will be created in your fork and a new merge request will be started.

Cherry-pick this merge request

Switch branch
Cancel
A new branch will be created in your fork and a new merge request will be started.