Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
N
Neos
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Locked Files
Issues
0
Issues
0
List
Boards
Labels
Service Desk
Milestones
Merge Requests
0
Merge Requests
0
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
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
love_飞影
Neos
Commits
34f0aaa2
Commit
34f0aaa2
authored
Jan 08, 2023
by
chechunchi
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add optionModal slice
parent
9000063c
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
50 additions
and
0 deletions
+50
-0
src/reducers/duel/mod.ts
src/reducers/duel/mod.ts
+9
-0
src/reducers/duel/modalSlice.ts
src/reducers/duel/modalSlice.ts
+41
-0
No files found.
src/reducers/duel/mod.ts
View file @
34f0aaa2
...
...
@@ -37,6 +37,9 @@ import {
setPositionModalIsOpenImpl
,
setPositionModalPositionsImpl
,
resetPositionModalImpl
,
setOptionModalIsOpenImpl
,
resetOptionModalImpl
,
optionModalCase
,
}
from
"
./modalSlice
"
;
import
{
MonsterState
,
...
...
@@ -91,6 +94,7 @@ const initialState: DuelState = {
checkCardModal
:
{
isOpen
:
false
,
cancelAble
:
false
,
tags
:
[]
},
yesNoModal
:
{
isOpen
:
false
},
positionModal
:
{
isOpen
:
false
,
positions
:
[]
},
optionModal
:
{
isOpen
:
false
,
options
:
[]
},
},
};
...
...
@@ -141,6 +145,8 @@ const duelSlice = createSlice({
setPositionModalIsOpen
:
setPositionModalIsOpenImpl
,
setPositionModalPositions
:
setPositionModalPositionsImpl
,
resetPositionModal
:
resetPositionModalImpl
,
setOptionModalIsOpen
:
setOptionModalIsOpenImpl
,
resetOptionModal
:
resetOptionModalImpl
,
},
extraReducers
(
builder
)
{
handsCase
(
builder
);
...
...
@@ -150,6 +156,7 @@ const duelSlice = createSlice({
cemeteryCase
(
builder
);
checkCardModalCase
(
builder
);
YesNoModalCase
(
builder
);
optionModalCase
(
builder
);
},
});
...
...
@@ -185,6 +192,8 @@ export const {
setPositionModalIsOpen
,
setPositionModalPositions
,
resetPositionModal
,
setOptionModalIsOpen
,
resetOptionModal
,
}
=
duelSlice
.
actions
;
export
const
selectDuelHsStart
=
(
state
:
RootState
)
=>
{
return
state
.
duel
.
meInitInfo
!=
null
;
...
...
src/reducers/duel/modalSlice.ts
View file @
34f0aaa2
...
...
@@ -58,6 +58,11 @@ export interface ModalState {
isOpen
:
boolean
;
positions
:
ygopro
.
CardPosition
[];
};
// 选项选择弹窗
optionModal
:
{
isOpen
:
boolean
;
options
:
{
msg
:
string
;
response
:
number
}[];
};
}
// 更新卡牌弹窗打开状态
...
...
@@ -288,11 +293,43 @@ export const setPositionModalPositionsImpl: CaseReducer<
state
.
modalState
.
positionModal
.
positions
=
action
.
payload
;
};
export
const
setOptionModalIsOpenImpl
:
CaseReducer
<
DuelState
,
PayloadAction
<
boolean
>
>
=
(
state
,
action
)
=>
{
state
.
modalState
.
optionModal
.
isOpen
=
action
.
payload
;
};
export
const
resetOptionModalImpl
:
CaseReducer
<
DuelState
>
=
(
state
)
=>
{
state
.
modalState
.
optionModal
.
options
=
[];
};
export
const
resetPositionModalImpl
:
CaseReducer
<
DuelState
>
=
(
state
)
=>
{
state
.
modalState
.
positionModal
.
isOpen
=
false
;
state
.
modalState
.
positionModal
.
positions
=
[];
};
// 增加选项
export
const
fetchOptionMeta
=
createAsyncThunk
(
"
duel/fetchOptionMeta
"
,
async
(
param
:
{
code
:
number
;
response
:
number
})
=>
{
const
meta
=
await
fetchCard
(
param
.
code
>>
4
);
const
msg
=
getCardStr
(
meta
,
param
.
code
&
0xf
)
||
"
[?]
"
;
const
response
=
{
msg
,
response
:
param
.
response
};
return
response
;
}
);
export
const
optionModalCase
=
(
builder
:
ActionReducerMapBuilder
<
DuelState
>
)
=>
{
builder
.
addCase
(
fetchOptionMeta
.
fulfilled
,
(
state
,
action
)
=>
{
state
.
modalState
.
optionModal
.
options
.
push
(
action
.
payload
);
});
};
export
const
selectCardModalIsOpen
=
(
state
:
RootState
)
=>
state
.
duel
.
modalState
.
cardModal
.
isOpen
;
export
const
selectCardModalName
=
(
state
:
RootState
)
=>
...
...
@@ -331,3 +368,7 @@ export const selectPositionModalIsOpen = (state: RootState) =>
state
.
duel
.
modalState
.
positionModal
.
isOpen
;
export
const
selectPositionModalPositions
=
(
state
:
RootState
)
=>
state
.
duel
.
modalState
.
positionModal
.
positions
;
export
const
selectOptionModalIsOpen
=
(
state
:
RootState
)
=>
state
.
duel
.
modalState
.
optionModal
.
isOpen
;
export
const
selectOptionModalOptions
=
(
state
:
RootState
)
=>
state
.
duel
.
modalState
.
optionModal
.
options
;
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment