@rpg-engine/long-bow 0.6.49 → 0.6.51

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -32129,44 +32129,29 @@ var ProgressBarContainer = /*#__PURE__*/styled__default.div.withConfig({
32129
32129
  var SkillProgressBar = function SkillProgressBar(_ref) {
32130
32130
  var bgColor = _ref.bgColor,
32131
32131
  skillName = _ref.skillName,
32132
- initialLevel = _ref.level,
32133
- initialSkillPoints = _ref.skillPoints,
32134
- initialSkillPointsToNextLevel = _ref.skillPointsToNextLevel,
32132
+ level = _ref.level,
32133
+ currentSkillPoints = _ref.skillPoints,
32135
32134
  texturePath = _ref.texturePath,
32136
32135
  _ref$showSkillPoints = _ref.showSkillPoints,
32137
32136
  showSkillPoints = _ref$showSkillPoints === void 0 ? true : _ref$showSkillPoints,
32138
32137
  atlasIMG = _ref.atlasIMG,
32139
32138
  atlasJSON = _ref.atlasJSON,
32140
32139
  buffAndDebuff = _ref.buffAndDebuff;
32141
- var _useState = React.useState(initialLevel),
32142
- level = _useState[0],
32143
- setLevel = _useState[1];
32144
- var _useState2 = React.useState(initialSkillPoints),
32145
- skillPoints = _useState2[0],
32146
- setSkillPoints = _useState2[1];
32147
- var _useState3 = React.useState(initialSkillPointsToNextLevel || shared.getSPForLevel(initialLevel + 1)),
32148
- skillPointsToNextLevel = _useState3[0],
32149
- setSkillPointsToNextLevel = _useState3[1];
32150
- // Update skill points and level from props when they change
32151
- React.useEffect(function () {
32152
- setLevel(initialLevel);
32153
- setSkillPoints(initialSkillPoints);
32154
- setSkillPointsToNextLevel(initialSkillPointsToNextLevel || shared.getSPForLevel(initialLevel + 1));
32155
- }, [initialLevel, initialSkillPoints, initialSkillPointsToNextLevel]);
32156
- React.useEffect(function () {
32157
- if (skillPoints >= skillPointsToNextLevel) {
32158
- var excessSkillPoints = skillPoints - skillPointsToNextLevel;
32159
- var newLevel = level + 1;
32160
- setLevel(newLevel);
32161
- setSkillPoints(excessSkillPoints);
32162
- setSkillPointsToNextLevel(shared.getSPForLevel(newLevel + 1));
32163
- }
32164
- }, [skillPoints, skillPointsToNextLevel, level]);
32165
- // Calculate the ratio, ensuring it doesn't exceed 100%
32166
- var ratio = Math.min(skillPoints / skillPointsToNextLevel * 100, 100);
32140
+ // Base skill points for the previous level (0 for level 1)
32141
+ var baseSkillPointsPrevLevel = level > 1 ? shared.getSPForLevel(level - 1) : 0;
32142
+ // Total skill points needed for the next level
32143
+ var nextLevelSkillPoints = shared.getSPForLevel(level + 1);
32144
+ // Calculate excess skill points above the previous level
32145
+ var excessSkillPoints = currentSkillPoints - baseSkillPointsPrevLevel;
32146
+ // Calculate progress percentage towards the next level
32147
+ var progress = nextLevelSkillPoints > baseSkillPointsPrevLevel ? Math.max(Math.min(excessSkillPoints / (nextLevelSkillPoints - baseSkillPointsPrevLevel) * 100, 100), 0) : 0;
32167
32148
  var skillsBuffsCalc = function skillsBuffsCalc(level, buffAndDebuff) {
32168
32149
  var result = level * (buffAndDebuff / 100);
32169
- return result > 0 ? "+" + result : "" + result;
32150
+ if (result > 0) {
32151
+ return "+" + result.toFixed(2);
32152
+ } else {
32153
+ return "" + result.toFixed(2);
32154
+ }
32170
32155
  };
32171
32156
  return React__default.createElement(React__default.Fragment, null, React__default.createElement(ProgressTitle, null, buffAndDebuff !== undefined && React__default.createElement(React__default.Fragment, null, buffAndDebuff > 0 ? React__default.createElement(BuffAndDebuffContainer, null, React__default.createElement(TitleNameContainer, null, React__default.createElement(TitleNameBuff, null, skillName), React__default.createElement(TitleNameBuff, null, "lv ", level, " (", skillsBuffsCalc(level, buffAndDebuff), ")")), React__default.createElement(TitleNameBuffContainer, null, React__default.createElement(TitleNameBuff, null, "(+", buffAndDebuff, "%)"))) : buffAndDebuff < 0 ? React__default.createElement(React__default.Fragment, null, React__default.createElement(TitleNameContainer, null, React__default.createElement(TitleNameDebuff, null, skillName), React__default.createElement(TitleNameDebuff, null, "lv ", level, " (", skillsBuffsCalc(level, buffAndDebuff), ")")), React__default.createElement("div", null, React__default.createElement(TitleNameDebuff, null, "(", buffAndDebuff, "%)"))) : React__default.createElement(TitleName, null, skillName)), !buffAndDebuff && React__default.createElement(TitleNameContainer, null, React__default.createElement(TitleName, null, skillName), React__default.createElement(ValueDisplay, null, "lv ", level))), React__default.createElement(ProgressBody, null, React__default.createElement(ProgressIconContainer, null, atlasIMG && atlasJSON ? React__default.createElement(SpriteContainer$2, null, React__default.createElement(ErrorBoundary, null, React__default.createElement(SpriteFromAtlas, {
32172
32157
  atlasIMG: atlasIMG,
@@ -32176,9 +32161,9 @@ var SkillProgressBar = function SkillProgressBar(_ref) {
32176
32161
  grayScale: true,
32177
32162
  opacity: 0.5
32178
32163
  }))) : React__default.createElement(React__default.Fragment, null)), React__default.createElement(ProgressBarContainer$1, null, React__default.createElement(SimpleProgressBar, {
32179
- value: ratio,
32164
+ value: progress,
32180
32165
  bgColor: bgColor
32181
- }))), showSkillPoints && React__default.createElement(SkillDisplayContainer, null, React__default.createElement(SkillPointsDisplay, null, skillPoints, " / ", skillPointsToNextLevel, " (", ratio.toFixed(2), "%)")));
32166
+ }))), showSkillPoints && React__default.createElement(SkillDisplayContainer, null, React__default.createElement(SkillPointsDisplay, null, progress.toFixed(2), "%")));
32182
32167
  };
32183
32168
  var ProgressBarContainer$1 = /*#__PURE__*/styled__default.div.withConfig({
32184
32169
  displayName: "SkillProgressBar__ProgressBarContainer",