Files
vue-js-modal/src/parser.js

63 lines
1.1 KiB
JavaScript

// Parses string with float number and suffix:
// "0.001" => { type: "px", value: 0.001 }
// "0.001px" => { type: "px", value: 0.001 }
// "0.1%" => { type: "px", value: 0.1 }
// "foo" => { type: "", value: "foo" }
// "auto" => { type: "auto", value: 0 }
var floatRegexp = '[-+]?[0-9]*\.?[0-9]+'
var types = [
{
name: 'px',
regexp: new RegExp(`^${floatRegexp}px\$`)
},
{
name: '%',
regexp: new RegExp(`^${floatRegexp}%\$`)
},
// Fallback option:
// If no suffix specified, assign to px
{
name: 'px',
regexp: new RegExp(`^${floatRegexp}\$`)
}
]
var getType = (value) => {
if (value === 'auto') {
return {
type: value,
value: 0
}
}
for (var i = 0; i < types.length; i++) {
let type = types[i]
if (type.regexp.test(value)) {
return {
type: type.name,
value: parseFloat(value)
}
}
}
return {
type: '',
value: value
}
}
export const parse = (value) => {
switch (typeof value) {
case 'number':
return { type: 'px', value }
case 'string':
return getType(value)
default:
return { type: '', value }
}
}
export default parse