2017-09-05 14:35:52 +02:00
|
|
|
/**
|
|
|
|
* --------------------------------------------------------------------------
|
2021-10-09 09:33:12 +03:00
|
|
|
* Bootstrap (v5.1.3): dom/manipulator.js
|
2020-06-16 21:41:47 +03:00
|
|
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
|
2017-09-05 14:35:52 +02:00
|
|
|
* --------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
2021-10-29 10:38:35 +03:00
|
|
|
function normalizeData(value) {
|
|
|
|
if (value === 'true') {
|
2018-06-09 21:11:05 +02:00
|
|
|
return true
|
2019-02-26 13:13:01 +02:00
|
|
|
}
|
|
|
|
|
2021-10-29 10:38:35 +03:00
|
|
|
if (value === 'false') {
|
2018-06-09 21:11:05 +02:00
|
|
|
return false
|
2019-02-26 13:13:01 +02:00
|
|
|
}
|
|
|
|
|
2021-10-29 10:38:35 +03:00
|
|
|
if (value === Number(value).toString()) {
|
|
|
|
return Number(value)
|
2019-02-26 13:13:01 +02:00
|
|
|
}
|
|
|
|
|
2021-10-29 10:38:35 +03:00
|
|
|
if (value === '' || value === 'null') {
|
2018-06-09 21:11:05 +02:00
|
|
|
return null
|
|
|
|
}
|
|
|
|
|
2021-10-29 10:38:35 +03:00
|
|
|
return value
|
2018-06-09 21:11:05 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function normalizeDataKey(key) {
|
2019-10-31 06:58:09 +01:00
|
|
|
return key.replace(/[A-Z]/g, chr => `-${chr.toLowerCase()}`)
|
2018-06-09 21:11:05 +02:00
|
|
|
}
|
|
|
|
|
2017-09-05 14:35:52 +02:00
|
|
|
const Manipulator = {
|
2017-09-15 16:07:24 +02:00
|
|
|
setDataAttribute(element, key, value) {
|
2020-11-20 14:43:13 +05:30
|
|
|
element.setAttribute(`data-bs-${normalizeDataKey(key)}`, value)
|
2017-09-15 16:07:24 +02:00
|
|
|
},
|
|
|
|
|
|
|
|
removeDataAttribute(element, key) {
|
2020-11-20 14:43:13 +05:30
|
|
|
element.removeAttribute(`data-bs-${normalizeDataKey(key)}`)
|
2018-06-09 21:11:05 +02:00
|
|
|
},
|
|
|
|
|
|
|
|
getDataAttributes(element) {
|
2019-02-13 20:25:08 +01:00
|
|
|
if (!element) {
|
2018-06-09 21:11:05 +02:00
|
|
|
return {}
|
|
|
|
}
|
|
|
|
|
2020-11-11 12:07:04 +05:30
|
|
|
const attributes = {}
|
2021-07-30 09:28:51 +03:00
|
|
|
const bsKeys = Object.keys(element.dataset).filter(key => key.startsWith('bs'))
|
2017-09-15 16:07:24 +02:00
|
|
|
|
2021-07-30 09:28:51 +03:00
|
|
|
for (const key of bsKeys) {
|
|
|
|
let pureKey = key.replace(/^bs/, '')
|
|
|
|
pureKey = pureKey.charAt(0).toLowerCase() + pureKey.slice(1, pureKey.length)
|
|
|
|
attributes[pureKey] = normalizeData(element.dataset[key])
|
|
|
|
}
|
2018-06-09 21:11:05 +02:00
|
|
|
|
|
|
|
return attributes
|
|
|
|
},
|
|
|
|
|
|
|
|
getDataAttribute(element, key) {
|
2020-11-20 14:43:13 +05:30
|
|
|
return normalizeData(element.getAttribute(`data-bs-${normalizeDataKey(key)}`))
|
2017-09-26 09:09:40 +02:00
|
|
|
},
|
|
|
|
|
2017-09-25 09:09:01 +02:00
|
|
|
offset(element) {
|
|
|
|
const rect = element.getBoundingClientRect()
|
|
|
|
|
|
|
|
return {
|
2021-07-28 16:23:32 +02:00
|
|
|
top: rect.top + window.pageYOffset,
|
|
|
|
left: rect.left + window.pageXOffset
|
2017-09-25 09:09:01 +02:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
position(element) {
|
|
|
|
return {
|
|
|
|
top: element.offsetTop,
|
|
|
|
left: element.offsetLeft
|
|
|
|
}
|
2017-09-05 14:35:52 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default Manipulator
|