Proof of concept for encoding known talents into URL

This commit is contained in:
Melvin Valster
2019-07-21 23:11:50 +02:00
parent 8302af7504
commit 06723fec6d
4 changed files with 75 additions and 8 deletions
+3 -1
View File
@@ -4,7 +4,9 @@
- [ ] Talent tooltips
- [ ] Generate URL for chosen talents
- [ ] Responsive on mobile
- [ ] Pretty ClassPicker
- [ ] Prettier talent frames
- [ ] Prettier icon frames & coloring
- [x] Pretty ClassPicker
- [x] Add react-router
- [x] Prevent reducing talent points on a row when it is a dependency for points already spent in the next row
- [x] Prevent reducing talent points on a talent that is a requirement for another talent with points in it
+21 -4
View File
@@ -3,16 +3,28 @@ import { Map } from 'immutable'
import { TalentTree } from './TalentTree'
import {
modifyTalentPoint,
calcAvailablePoints
calcAvailablePoints,
encodeKnownTalents
} from '../lib/tree'
import { talentsBySpec } from '../data/talents'
import { classByName } from '../data/classes'
import { History } from 'history'
interface Props {
selectedClass: string
history: History
}
// const EMPTY_TALENTS = Map<number, number>()
const EMPTY_TALENTS = Map<number, number>()
// .set(30, 5)
// .set(26, 5)
// .set(34, 5)
// .set(28, 2)
// .set(27, 3)
// .set(33, 1)
// .set(29, 1)
// .set(32, 1)
export class Calculator extends React.PureComponent<Props> {
static whyDidYouRender = true
@@ -30,10 +42,15 @@ export class Calculator extends React.PureComponent<Props> {
}
handleTalentPress = (specId: number, talentId: number, modifier: 1 | -1) => {
const { selectedClass } = this.props
const talent = talentsBySpec[specId][talentId]
this.setState({
knownTalents: modifyTalentPoint(this.state.knownTalents, talent, modifier)
})
console.log('Clicked talent: ' + talentId)
const newKnownTalents = modifyTalentPoint(this.state.knownTalents, talent, modifier)
this.setState({ knownTalents: newKnownTalents })
const pointString = encodeKnownTalents(newKnownTalents, selectedClass)
this.props.history.replace(`/${selectedClass}/${pointString}`)
}
render() {
+5 -2
View File
@@ -15,7 +15,7 @@ export class IndexRoute extends React.PureComponent<Props> {
static whyDidYouRender = true
render() {
const { match } = this.props
const { match, history } = this.props
const { selectedClass, pointString } = match.params
return (
@@ -23,7 +23,10 @@ export class IndexRoute extends React.PureComponent<Props> {
<ClassPicker selected={selectedClass} />
{selectedClass &&
<Calculator selectedClass={selectedClass} />
<Calculator
selectedClass={selectedClass}
history={history}
/>
}
</div>
)
+46 -1
View File
@@ -1,5 +1,10 @@
import { List, Map, fromJS } from 'immutable'
import { talentsBySpec, talentToSpec, talentsById } from '../data/talents';
import {
talentsBySpec,
talentToSpec,
talentsBySpecArray
} from '../data/talents';
import { classByName } from '../data/classes'
export const MAX_POINTS = 51
export const MAX_ROWS = 7
@@ -128,4 +133,44 @@ export function parsePointString(str: string): List<List<number>> {
})
return fromJS(list)
}
/**
* Encodes a Map of known talents into a URL-friendly string.
*/
export function encodeKnownTalents(known: Map<number, number>, className: string): string {
let string = ''
const { specs } = classByName[className]
for (let i = 0; i < specs.length; i++) {
const specId = specs[i]
const talents = talentsBySpecArray[specId].sort((a, b) => {
if (a.row === b.row) {
return a.col - b.col
}
return a.row - b.row
})
string += i > 0 ? '-' : ''
string += removeTrailingCharacters(
talents.map((talent) => known.get(talent.id, 0)).join(''),
'0'
)
}
return removeTrailingCharacters(string, '-')
}
/**
* Decodes a string of points into a Map of talents.
*/
export function decodeKnownTalents(pointString: string, className: string): Map<number, number> {
return Map()
}
/**
* Removes repeated characters from the end of a string.
*/
function removeTrailingCharacters(str: string, char: string): string {
while (str[str.length - 1] === char) {
str = str.slice(0, -1)
}
return str
}