pricehistory
Version:
Transforms raw OHLCV series data into enriched candles with technical indicators, pattern recognition, and trend analysis.
77 lines • 3.12 kB
JavaScript
;
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
var ownKeys = function(o) {
ownKeys = Object.getOwnPropertyNames || function (o) {
var ar = [];
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
return ar;
};
return ownKeys(o);
};
return function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
__setModuleDefault(result, mod);
return result;
};
})();
Object.defineProperty(exports, "__esModule", { value: true });
const utilN = __importStar(require("@nameer/utils"));
const halvingDates = [
new Date("2009-01-03"), // genesis
new Date("2012-11-28"),
new Date("2016-07-09"),
new Date("2020-05-11"),
new Date("2024-04-19"),
];
const averageDuration = (halvingDates[halvingDates.length - 1].getTime() -
halvingDates[0].getTime()) /
(halvingDates.length - 1);
const now = Date.now();
while (halvingDates[halvingDates.length - 1].getTime() < now) {
halvingDates.push(new Date(halvingDates[halvingDates.length - 1].getTime() + averageDuration));
}
// Cache timestamps for fast comparison in hot loop
const halvingTimestamps = halvingDates.map((d) => d.getTime());
const firstTimestamp = halvingTimestamps[0];
const lastTimestamp = halvingTimestamps[halvingTimestamps.length - 1];
function setCandleHalving(opt, candle) {
if (opt.halving !== true || candle.date === undefined)
return;
const t = candle.date.getTime();
if (t < firstTimestamp || t > lastTimestamp)
return;
let epoch = 0;
for (let i = 0; i < halvingTimestamps.length - 1; i++) {
if (t >= halvingTimestamps[i] && t < halvingTimestamps[i + 1]) {
epoch = i;
break;
}
}
const halvingStart = halvingTimestamps[epoch];
const elapsed = t - halvingStart;
const duration = halvingTimestamps[epoch + 1] - halvingStart;
candle.halvingDate = halvingDates[epoch];
candle.halvingEpoch = epoch;
candle.halvingYear = Math.floor(elapsed / utilN.date.MS_PER_YEAR) + 1;
candle.halvingProgress = utilN.math.num((elapsed / duration) * 100);
}
exports.default = setCandleHalving;
//# sourceMappingURL=candle.setHalving.js.map