미디어위키:Responsive-arrow.js: 두 판 사이의 차이
(테스트 (빌드 시스템)) |
(오류 처리) 태그: 되돌려진 기여 |
||
| 1번째 줄: | 1번째 줄: | ||
// [[틀:반응형 화살표]] | |||
{ | { | ||
const arrowArray = document.getElementsByClassName('arrow-dataset'); | const arrowArray = document.getElementsByClassName('arrow-dataset'); | ||
for (const arrowElement of arrowArray) { | for (const arrowElement of arrowArray) { | ||
const data = Object.create( | const dataSet = arrowElement.dataset; | ||
data.thick = Number(data.thick); | const data = Object.create(dataSet); | ||
data.pointLength = Number(data.pointLength); | data.thick = Number(dataSet.thick); | ||
data.pointDeg = Number(data.pointDeg); | if (Number.isNaN(data.thick)) { | ||
arrowElement.innerHTML = `thick is not a number`; | |||
} | |||
data.pointLength = Number(dataSet.pointLength); | |||
if (Number.isNaN(data.pointLength)) { | |||
arrowElement.innerHTML = `pointLength is not a number`; | |||
} | |||
data.pointDeg = Number(dataSet.pointDeg); | |||
if (Number.isNaN(data.pointDeg)) { | |||
arrowElement.innerHTML = `pointDeg is not a number`; | |||
} | |||
const arrowBox = arrowElement.parentElement; | const arrowBox = arrowElement.parentElement; | ||
const arrowPoint = arrowElement.nextElementSibling; | const arrowPoint = arrowElement.nextElementSibling; | ||
const arrowShaft = arrowPoint.nextElementSibling; | const arrowShaft = arrowPoint.nextElementSibling; | ||
arrowPoint.style.position = arrowShaft.style.position = 'absolute'; | arrowPoint.style.position = arrowShaft.style.position = 'absolute'; | ||
arrowPoint.style.borderRadius = arrowShaft.style.borderRadius = '100px'; | arrowPoint.style.borderRadius = arrowShaft.style.borderRadius = '100px'; | ||
arrowPoint.style.transformBox = 'fill-box'; | arrowPoint.style.transformBox = 'fill-box'; | ||
arrowPoint.style.borderWidth = | |||
arrowShaft.style.borderWidth = `${data.thick}px`; | |||
if (data.color) | |||
arrowPoint.style.background = | |||
arrowPoint.style.borderColor = | |||
arrowShaft.style.background = | |||
arrowShaft.style.borderColor = | |||
data.color; | |||
switch (data.direction) { | switch (data.direction) { | ||
case 'left': | case 'left': | ||
arrowBox.style.alignItems = | |||
data.pointDirection === 'right' ? 'flex-end' : 'flex-start'; | |||
arrowPoint.style.transformOrigin = 'left'; | arrowPoint.style.transformOrigin = 'left'; | ||
arrowPoint.style.left = | arrowPoint.style.left = '0px'; | ||
break; | break; | ||
case 'right': | case 'right': | ||
arrowBox.style.alignItems = | |||
data.pointDirection === 'right' ? 'flex-start' : 'flex-end'; | |||
arrowPoint.style.transformOrigin = 'right'; | arrowPoint.style.transformOrigin = 'right'; | ||
arrowPoint.style.right = | arrowPoint.style.right = '0px'; | ||
break; | break; | ||
case 'up': | case 'up': | ||
arrowBox.style.justifyContent = | |||
data.pointDirection === 'right' ? 'flex-start' : 'flex-end'; | |||
arrowPoint.style.transformOrigin = 'top'; | arrowPoint.style.transformOrigin = 'top'; | ||
arrowPoint.style.top = | arrowPoint.style.top = '0px'; | ||
break; | break; | ||
case 'down': | case 'down': | ||
arrowBox.style.justifyContent = | |||
data.pointDirection === 'right' ? 'flex-end' : 'flex-start'; | |||
arrowPoint.style.transformOrigin = 'bottom'; | arrowPoint.style.transformOrigin = 'bottom'; | ||
arrowPoint.style.bottom = | arrowPoint.style.bottom = '0px'; | ||
break; | break; | ||
default: | default: | ||
| 67번째 줄: | 62번째 줄: | ||
case 'left': | case 'left': | ||
case 'right': | case 'right': | ||
arrowPoint.style.width = `${data.pointLength}px`; | arrowPoint.style.width = `${data.pointLength}px`; | ||
arrowPoint.style.height = '0px'; | |||
arrowShaft.style.left = arrowShaft.style.right = '0px'; | |||
arrowBox.style.minHeight = `${data.pointLength * | arrowBox.style.minHeight = `${data.pointLength * | ||
Math.sin((data.pointDeg * Math.PI) / 180) * | Math.sin((data.pointDeg * Math.PI) / 180) * | ||
| 74번째 줄: | 70번째 줄: | ||
data.thick + | data.thick + | ||
1}px`; | 1}px`; | ||
arrowBox.style.width = data.length ? `${data.length}px` : | arrowBox.style.width = data.length ? `${data.length}px` : ''; | ||
break; | break; | ||
case 'up': | case 'up': | ||
case 'down': | case 'down': | ||
arrowPoint.style.width = | arrowPoint.style.width = '0px'; | ||
arrowPoint.style.height = `${data.pointLength}px`; | arrowPoint.style.height = `${data.pointLength}px`; | ||
arrowShaft.style.top = arrowShaft.style.bottom = '0px'; | |||
arrowBox.style.minWidth = `${data.pointLength * | arrowBox.style.minWidth = `${data.pointLength * | ||
Math.sin((data.pointDeg * Math.PI) / 180) * | Math.sin((data.pointDeg * Math.PI) / 180) * | ||
| 87번째 줄: | 83번째 줄: | ||
1}px`; | 1}px`; | ||
arrowBox.style.height = `${data.length || 100}px`; | arrowBox.style.height = `${data.length || 100}px`; | ||
break; | break; | ||
} | } | ||
| 101번째 줄: | 96번째 줄: | ||
const arrowPoint2 = arrowPoint.cloneNode(true); | const arrowPoint2 = arrowPoint.cloneNode(true); | ||
arrowPoint2.style.rotate = `${-data.pointDeg}deg`; | arrowPoint2.style.rotate = `${-data.pointDeg}deg`; | ||
arrowBox.appendChild(arrowPoint2); | |||
arrowBox.style.alignItems = 'center'; | arrowBox.style.alignItems = 'center'; | ||
arrowBox.style.justifyContent = 'center'; | arrowBox.style.justifyContent = 'center'; | ||
break; | break; | ||
} | } | ||
2025년 8월 7일 (목) 14:04 판
// [[틀:반응형 화살표]]
{
const arrowArray = document.getElementsByClassName('arrow-dataset');
for (const arrowElement of arrowArray) {
const dataSet = arrowElement.dataset;
const data = Object.create(dataSet);
data.thick = Number(dataSet.thick);
if (Number.isNaN(data.thick)) {
arrowElement.innerHTML = `thick is not a number`;
}
data.pointLength = Number(dataSet.pointLength);
if (Number.isNaN(data.pointLength)) {
arrowElement.innerHTML = `pointLength is not a number`;
}
data.pointDeg = Number(dataSet.pointDeg);
if (Number.isNaN(data.pointDeg)) {
arrowElement.innerHTML = `pointDeg is not a number`;
}
const arrowBox = arrowElement.parentElement;
const arrowPoint = arrowElement.nextElementSibling;
const arrowShaft = arrowPoint.nextElementSibling;
arrowPoint.style.position = arrowShaft.style.position = 'absolute';
arrowPoint.style.borderRadius = arrowShaft.style.borderRadius = '100px';
arrowPoint.style.transformBox = 'fill-box';
arrowPoint.style.borderWidth =
arrowShaft.style.borderWidth = `${data.thick}px`;
if (data.color)
arrowPoint.style.background =
arrowPoint.style.borderColor =
arrowShaft.style.background =
arrowShaft.style.borderColor =
data.color;
switch (data.direction) {
case 'left':
arrowBox.style.alignItems =
data.pointDirection === 'right' ? 'flex-end' : 'flex-start';
arrowPoint.style.transformOrigin = 'left';
arrowPoint.style.left = '0px';
break;
case 'right':
arrowBox.style.alignItems =
data.pointDirection === 'right' ? 'flex-start' : 'flex-end';
arrowPoint.style.transformOrigin = 'right';
arrowPoint.style.right = '0px';
break;
case 'up':
arrowBox.style.justifyContent =
data.pointDirection === 'right' ? 'flex-start' : 'flex-end';
arrowPoint.style.transformOrigin = 'top';
arrowPoint.style.top = '0px';
break;
case 'down':
arrowBox.style.justifyContent =
data.pointDirection === 'right' ? 'flex-end' : 'flex-start';
arrowPoint.style.transformOrigin = 'bottom';
arrowPoint.style.bottom = '0px';
break;
default:
break;
}
switch (data.direction) {
case 'left':
case 'right':
arrowPoint.style.width = `${data.pointLength}px`;
arrowPoint.style.height = '0px';
arrowShaft.style.left = arrowShaft.style.right = '0px';
arrowBox.style.minHeight = `${data.pointLength *
Math.sin((data.pointDeg * Math.PI) / 180) *
(data.pointDirection === 'both' ? 2 : 1) +
data.thick +
1}px`;
arrowBox.style.width = data.length ? `${data.length}px` : '';
break;
case 'up':
case 'down':
arrowPoint.style.width = '0px';
arrowPoint.style.height = `${data.pointLength}px`;
arrowShaft.style.top = arrowShaft.style.bottom = '0px';
arrowBox.style.minWidth = `${data.pointLength *
Math.sin((data.pointDeg * Math.PI) / 180) *
(data.pointDirection === 'both' ? 2 : 1) +
data.thick +
1}px`;
arrowBox.style.height = `${data.length || 100}px`;
break;
}
switch (data.pointDirection) {
case 'left':
arrowPoint.style.rotate = `${data.pointDeg}deg`;
break;
case 'right':
arrowPoint.style.rotate = `${-data.pointDeg}deg`;
break;
case 'both': {
arrowPoint.style.rotate = `${data.pointDeg}deg`;
const arrowPoint2 = arrowPoint.cloneNode(true);
arrowPoint2.style.rotate = `${-data.pointDeg}deg`;
arrowBox.appendChild(arrowPoint2);
arrowBox.style.alignItems = 'center';
arrowBox.style.justifyContent = 'center';
break;
}
}
}
}