{"id":162797,"date":"2025-06-02T10:58:19","date_gmt":"2025-06-02T03:58:19","guid":{"rendered":"https:\/\/www.hashmicro.com\/id\/blog\/?p=162797"},"modified":"2026-04-24T14:51:56","modified_gmt":"2026-04-24T07:51:56","slug":"forecast-barang","status":"publish","type":"post","link":"https:\/\/www.hashmicro.com\/id\/blog\/forecast-barang\/","title":{"rendered":"Forecast Barang: Jenis dan Peran Strategisnya dalam Bisnis"},"content":{"rendered":"<p><a href=\"https:\/\/www.mckinsey.com\/industries\/industrials\/our-insights\/distribution-blog\/harnessing-the-power-of-ai-in-distribution-operations\" target=\"_blank\" rel=\"nofollow noopener\">McKinsey mencatat<\/a> bahwa AI dapat menurunkan level inventory sebesar 20\u201330% melalui peningkatan demand forecasting barang, seperti dynamic segmentation dan machine learning, serta optimasi inventory dengan tools yang lebih efisien.<\/p>\n<p>Angka tersebut menunjukkan bahwa kualitas prediksi dan cara bisnis menerjemahkannya ke keputusan stok memang berdampak langsung ke kebutuhan persediaan.<\/p>\n<p>Bagian berikut merangkum konsep forecast barang, pilihan metode yang umum dipakai, strategi peningkatan akurasi, serta contoh penerapannya.<\/p>\n<style>\r\n\t.takeaways-container {\r\n\t\tmargin: 20px 0;\r\n\t\tfont-family: sans-serif;\r\n\t}\r\n\t.box-content {\r\n\t\tbackground-color: #fffacd;\r\n\t\tbox-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);\r\n\t\tborder-radius: 25px;\r\n\t\tpadding: 25px;\r\n\t}\r\n\t.title {\r\n\t\tmargin-bottom: 20px;\r\n\t}\r\n\t.title p {\r\n\t\tdisplay: inline-block;\r\n\t\tbackground-color: #8A0E19;\r\n\t\tcolor: #ffffff;\r\n\t\tpadding: 8px 15px;\r\n\t\tborder-radius: 8px;\r\n\t\tfont-size: 22px;\r\n\t\tfont-weight: bold;\r\n\t\tmargin: 0;\r\n\t}\r\n\t.item {\r\n\t\tdisplay: flex;\r\n\t\talign-items: flex-start;\r\n\t\tmargin-bottom: 12px;\r\n\t}\r\n\t.item .circle {\r\n\t\twidth: 8px;\r\n\t\theight: 8px;\r\n\t\tbackground-color: #000000;\r\n\t\tborder-radius: 50%;\r\n\t\tmargin-right: 12px;\r\n\t\tflex-shrink: 0;\r\n\t\tmargin-top: 8px;\r\n\t}\r\n\t.item p {\r\n\t\tmargin: 0;\r\n\t\tfont-size: 16px;\r\n\t\tline-height: 1.6;\r\n\t}\r\n\t.item p a {\r\n\t\tcolor: #8A0E19;\r\n\t\tfont-weight: normal;\r\n\t\ttext-decoration: none;\r\n\t}\r\n\t.item p a:hover {\r\n\t\ttext-decoration: underline;\r\n\t}\r\n\t.button-wrapper {\r\n\t\tmargin-top: 25px;\r\n\t}\r\n\t.submit-button {\r\n\t\tbackground-color: #8a0e19;\r\n\t\tcolor: #fff !important;\r\n\t\ttransition: all .3s ease;\r\n\t\tpadding: 12px 28px;\r\n\t\tdisplay: inline-block;\r\n\t\tborder-radius: 12px;\r\n\t\tfont-size: 16px;\r\n\t\tfont-weight: bold;\r\n\t\ttext-decoration: none;\r\n\t}\r\n\t.submit-button:hover {\r\n\t\tbackground-color: #991b26;\r\n\t}\r\n\t@media (max-width: 767px) {\r\n\t\t.takeaways-container {\r\n\t\t\theight: auto;\r\n\t\t\tpadding: 0;\r\n\t\t}\r\n\t\t.box-content {\r\n\t\t\tpadding: 24px;\r\n\t\t}\r\n\t\t.content,\r\n\t\t.main-content,\r\n\t\t.list-item {\r\n\t\t\twidth: 100%;\r\n\t\t}\r\n\t}\r\n<\/style>\r\n\r\n<div class=\"takeaways-container\">\r\n\t<div class=\"box-content\">\r\n\t\t<div class=\"content\">\r\n\t\t\t<div class=\"title\">\r\n\t\t\t\t<p>Key Takeaways<\/p>\r\n\t\t\t<\/div>\r\n\t\t\t<div class=\"main-content\">\r\n\t\t\t\t<div class=\"list-item\">\r\n\t\t\t\t\t<div class=\"item\">    <div class=\"circle\"><\/div>    <p><a href=\"#apa-itu-forecast-barang\">Forecast barang<\/a> adalah proses memprediksi kebutuhan produk di masa depan berdasarkan data historis dan tren pasar agar stok terkelola dengan efisien.<\/p><\/div><div class=\"item\">    <div class=\"circle\"><\/div>    <p>Metode forecast barang sederhana <a href=\"#metode-forecast-barang-yang-tepat-untuk-setiap-pola-permintaan\">cocok untuk demand stabil<\/a>, sementara demand seasonal butuh metode yang lebih mengakomodasi.<\/p><\/div><div class=\"item\">    <div class=\"circle\"><\/div>    <p><a href=\"#strategi-membuat-forecast-barang-lebih-akurat\">Akurasi forecast naik<\/a> signifikan ketika SKU disegmentasi (ABC\/XYZ) dan ada evaluasi error (MAPE\/WAPE).<\/p><\/div>\t\t\t\t<\/div>\r\n\t\t\t<\/div>\r\n<!-- \t\t\t<div class=\"button-wrapper\">\r\n\t\t\t\t<a href=\"https:\/\/www.equiperp.com\/tour-produk-gratis\/?medium=key-takeaways\" class=\"submit-button\">Klik untuk Demo Gratis!<\/a>\r\n\t\t\t<\/div> -->\r\n\t\t<\/div>\r\n\t<\/div>\r\n<\/div>\n<div id=\"toc_group_article\" style=''>\r\n\t<p style='font-size:25px;font-weight:bold; margin-bottom:0px'>\r\n\t\tDaftar Isi:\r\n\t<\/p>\r\n\t<ul id=\"list_toc\" class='list_toc'><\/ul>\r\n<\/div>\r\n\r\n<div id=\"placeholder-toc\"><\/div>\r\n<div id=\"toc\">\r\n    <div class=\"header\">\r\n\t<span class=\"toc-title\" id=\"toc-title\">Daftar Isi<\/span>\t\r\n\t <i class=\"toc-icon\">\r\n        <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"30\" height=\"30\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"#000\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" class=\"header-icon\">\r\n          <path d=\"m6 9 6 6 6-6\" \/>\r\n        <\/svg>\r\n      <\/i>\r\n\t<\/div>\r\n    <div class=\"list\">\r\n      <ul id=\"toc-list\"><\/ul>\r\n    <\/div>\r\n <\/div>\r\n\r\n<style>\r\n\/* Simple styling for the TOC *\/\r\n\t\r\n\t#toc ul li:last-child {\r\n    padding-bottom: 16px; \/* Adjust the value as needed *\/\r\n}\r\n\r\n.td-fix-index {\r\n\t transform: unset !important;\r\n     -webkit-transform: unset !important; \r\n}\r\n.footer-contact .td-fix-index {\r\n\t transform: translateZ(0) !important;\r\n     -webkit-transform: translateZ(0) !important; \r\n}\r\n\t.tdb_single_content .tdb-block-inner.td-fix-index{\r\n\t\tposition: static;\r\n\t}\r\n\t\r\n\r\n\r\n\t\r\n#toc {\r\n  background-color: #FFF;\r\n\tpadding: 17px 24px 0px 24px !important;\r\n  margin-bottom: 20px;\r\n\/*   border: 1px solid #9C171E; *\/\r\n  border-radius: 6px;\r\n\tdisplay: none;\r\n  max-width: 100%;\r\n  transition: .4s ease height;\r\n\tmargin-left: 0;\r\n\toverflow: hidden;\r\n}\r\n\r\n#toc .header{\r\n  display: flex;\r\n  align-items: center;\r\n  justify-content: space-between;\r\n\tbackground-color: transparent;\r\n}\r\n\t\r\n\t#toc.sticky .header{\r\n\t\tpadding: 4px 0;\r\n\t}\r\n\t\r\n.header p{\r\n  font-size: 18px !important;\r\n  font-weight: 600 !important;\r\n  color: #393939;\r\n   margin-bottom: 0;\r\n  \/* margin-top: 20px; *\/\r\n}\r\n\r\n.toc-icon{\r\n  float: right;\r\n\/*   visibility: hidden; *\/\r\n}\r\n\r\n\t.toc-title{\r\n\t\tmargin-right: auto;\r\n\/* \t\tpadding-left: 20px; *\/\r\n\t\tfont-weight: 600;\r\n\t\talign-self: center;\t}\t\r\n\r\n#toc ul {\r\n  list-style-type: none;\r\n  padding-left: 0;\r\n}\r\n\t\r\n#toc.sticky ul{\r\n\toverflow-y: auto;\r\n\tmax-height: 250px;\r\n\tmargin-top: 0px;\r\n\tpadding-top: 20px;\r\n\/* \tborder-top: 1px solid #d3d3d3; *\/\r\n}\r\n\t\r\n#toc ul li {\r\n\/*   margin-bottom: 10px; *\/\r\n  margin-bottom: 10px;\r\n\tmargin-left: 0;\r\n\ttransition: .2s ease;\r\n\tcursor: pointer;\r\n}\r\n\t\r\n\t#toc.sticky ul li {\r\n\t  margin-right: 10px;\r\n\t}\r\n\t\r\n.td-post-content #toc-list li a:hover, .td-post-content #toc-list a.active{\r\n\tbackground-color: #FFF;\r\n\/* \tpadding: 8px 16px 8px 16px; *\/\r\n\tpadding: 4px 16px 4px 16px;\r\n\tborder-radius: 6px;\r\n\tcolor: #9c171e !important;\r\n\tfont-weight: 600 !important;\r\n}\r\n\t\r\n\t.td-post-content #toc-list li:hover a, .td-post-content #toc-list a.active{\r\n\t\tcolor: #9C171E !important;\r\n\t\tfont-weight: 600 !important;\r\n\t}\r\n\t\r\n.td-post-content #toc-list a.active{\r\n\tfont-weight: bold !important;\r\n\tcolor: #9C171E !important;\r\n}\r\n\t\r\n#toc a, .td-post-content #toc-list a {\r\n  text-decoration: none;\r\n  color: #ea1717 !important;\r\n  transition: .2s ease;\r\n\tfont-weight: 400 !important;\r\n\tdisplay: block;\r\n\t\r\n\tpadding: 4px 16px 4px 0;\r\n}\r\n\r\n#toc.sticky {\r\n  position: fixed;\r\n\/*   top: 73px; *\/\r\n\tbottom: 0;\r\n  z-index: 100; \r\n  box-shadow: 0 2px 5px rgba(0,0,0,0.1); \r\n\twidth: 100%; \r\n\tbackground-color: #FFF;\r\n\/* \tbackground-color: #FFF1F1; *\/\r\n\tborder-bottom: 1px solid #ea1717;\r\n\/*   border: 1px solid #393939; *\/\r\n  box-shadow: 0px 0px 14px 0px #00000040;\r\n  cursor: pointer;\r\n\tanimation: fadein .3s ease;\r\n\tpadding: 12px 16px !important;\r\n}\r\n\t\r\n\t.fadein{\r\n\t\tanimation: fadein .3s ease;\r\n\t}\r\n\t\r\n\t.fadeout{\r\n\t\tanimation: fadeout .3s ease;\r\n\t}\r\n\t\r\n\t\r\n\t@keyframes fadein{\r\n\t\t0% {\r\n\t\t\topacity: 0;\r\n\t\t}\r\n\t\t100%{\r\n\t\t\topacity: 1;\r\n\t\t}\r\n\t}\r\n\t\r\n\t@keyframes fadeout{\r\n\t\t0% {\r\n\t\t\topacity: 1;\r\n\t\t}\r\n\t\t100%{\r\n\t\t\topacity: 0;\r\n\t\t}\r\n\t}\r\n\r\n\t\r\n#toc.sticky .header p{\r\n\tmargin-bottom: 10px;\r\n\tmargin-top: 10px;\r\n}\r\n\r\n#toc.sticky .toc-icon{\r\n  visibility: visible;\r\n\/* \ttransition: 0.4s ease; *\/\r\n}\r\n\t\r\n\t.toc-icon{\r\n\t\talign-items: center;\r\n    \tdisplay: flex;\r\n\t}\r\n\t\r\n\tsvg.header-icon{\r\n\/* \t\tbackground-color: #9c171e; *\/\r\n\t\tbackground-color: #FFF;\r\n\t\tborder-radius: 30px;\r\n\t\tpadding: 5px;\r\n\t}\r\n\r\n#toc.sticky .list{\r\n\/*   max-height: 0; *\/\r\n  transition: height 0.4s ease;\r\n}\r\n\t\r\n\t#toc .list{\r\n\/*   max-height: 0; *\/\r\n  transition: height 0.4s ease;\r\n}\r\n\r\n#toc .header.active .toc-icon{\r\n\ttransform: rotate(0deg); \r\n\topacity: 1;\r\n}\r\n\r\n\t#toc .header.active + .list {\r\n\t  max-height: 200px; \/* Adjust this value as needed *\/\r\n\t  opacity: 1;\r\n\t}\r\n\t\r\n\t#placeholder-toc{\r\n\/* \t\tdisplay: none; *\/\r\n\t}\r\n\t\r\n\t@media (min-width: 768px) and (max-width: 991px){\r\n\t\t#toc.sticky{\r\n\/* \t\t\ttop: 104px; *\/\r\n\t\t\tbottom: 0px;\r\n\t\t}\r\n\t\t\r\n\t\t#toc{\r\n\t\t\twidth: unset !important;\r\n\t\t}\r\n\t}\r\n\t\r\n\t@media (max-width: 767px){\r\n\t\t#toc{\r\n\t\t\twidth: 100% !important;\r\n\t\t\tdisplay: inline-block;\r\n\t\t}\r\n\t\t\r\n\t\t#toc.sticky{\r\n\t\t\twidth: 90% !important;\r\n\/* \t\t\ttop: 81px; *\/\r\n\t\t\tbottom: 60px;\r\n\t\t\tmargin-left: auto;\r\n\t\t\tmargin-right: auto;\r\n\t\t\tpadding: 0 16px;\r\n\t\t\tright: 5%;\r\n\t\t}\r\n\t}\r\n\t\r\n\t<\/style>\r\n\r\n<style>\r\n\t#list_toc li {margin-bottom: 0;margin-top: 5px;}\r\n\t#list_toc > li > ul {padding-left: 20px;margin-bottom: 0;}\r\n\t#list_toc{height:max-content;transition:ease-in-out}\r\n\t#list_toc li {margin-bottom: 0;margin-top: 5px;}\r\n\t#list_toc_float li.active > a {color:#b1252d;background: #ffe1e3;}\r\n\t#list_toc_float li a {padding:3px 7px}\r\n\t#list_toc_float li a {\r\n\t\tdisplay: block;\r\n\t\tcolor:#000;\r\n\t\tmargin-bottom: 10px;\r\n\t\ttransition:all 0.2s ease-in-out;\r\n\t\tfont-size:15px\r\n\t}\r\n\t#list_toc_float li{list-style:none;list-style-position:inside; margin-left:0;}\r\n\t#list_toc_float a:hover{color:#b1252d;}\r\n\t\r\n\t#list_toc_float li a{margin-bottom:0px}\r\n\t#toc_group_float{\r\n\t\tline-height: 24px;\r\n\t\tmax-height: calc(100vh - 100px);\r\n\t\toverflow: auto;\r\n\t\tz-index: 99;\r\n\t\tdisplay:none!important;\r\n\t\tbackground:#fff;\r\n\t\ttransition:all 0.5s linear\r\n\t}\r\n\t\r\n\t@media (min-width:1019px){\r\n\t\t#toc_group_float {\r\n\t\t\tdisplay:block!important;\r\n\t\t\t}\r\n\t\t#toc_group_article {\r\n\t\t\tdisplay:none;\r\n\t\t}\r\n\t}\r\n\t\r\n\t@media (max-width:768px){\r\n\t\t#toc_group_article {\r\n\t\t\tdisplay:none;\r\n\t\t}\r\n\t}\r\n\t\r\n\t \/* custom scrollbar style *\/\r\n::-webkit-scrollbar {\r\n    width: 7px;\r\n}\r\n::-webkit-scrollbar-track {\r\n    background: #d7a2a4;\r\n}\r\n::-webkit-scrollbar-thumb {\r\n    background: #b1252d;\r\n    border-radius: 15px;\r\n}\t\t\r\n\r\n<\/style>\r\n\r\n<script>\r\n\tdocument.addEventListener('DOMContentLoaded', function() {\r\n\t\t\/\/ Fungsi untuk menangani klik pada semua elemen <a> dengan href yang dimulai dengan #\r\n\t\tfunction handleTitleClick(event) {\r\n\t\t\tevent.preventDefault();\r\n\t\t\tconst targetId = this.getAttribute('href').substring(1);\r\n\t\t\tconst targetElement = document.getElementById(targetId);\r\n\r\n\t\t\tif (targetElement) {\r\n\t\t\t\tconst headerHeight = document.querySelector('#toc .header').offsetHeight;\r\n\t\t\t\tconst navbarHeight = document.getElementById('tdi_34') ? document.getElementById('tdi_34').offsetHeight : 0;\r\n\t\t\t\tconst windowHeight = window.innerHeight;\r\n\t\t\t\tconst targetOffset = targetElement.offsetTop;\r\n\t\t\t\tconst scrollTo = targetOffset + (windowHeight \/ 2) + (headerHeight) - navbarHeight - 40;\r\n\r\n\t\t\t\twindow.scrollTo({\r\n\t\t\t\t\ttop: scrollTo,\r\n\t\t\t\t\tbehavior: 'smooth'\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t\/\/ Tambahkan event listener untuk semua elemen <a> di toc-list dan list-toc\r\n\t\tconst titleLinks = document.querySelectorAll('#toc-list a, #list_toc a');\r\n\t\ttitleLinks.forEach(link => {\r\n\t\t\tlink.addEventListener('click', handleTitleClick);\r\n\t\t});\r\n\t});\r\n<\/script>\r\n\r\n<!-- ToC List for mobile -->\r\n<script>\r\n \/\/ Generate TOC based on headings\r\ndocument.addEventListener(\"DOMContentLoaded\", function() {\r\n  \/\/ Get the element that will contain the TOC\r\n  const tocList = document.getElementById('toc-list');\r\n\r\n  \/\/ Get the element with the ID 'article-left'\r\n  const article = document.querySelector('.td-post-content');\r\n\r\n  \/\/ Find all h2 elements within 'myarticle'\r\n  const headers = article.getElementsByTagName('h2');\r\n\r\n  \/\/ Loop through the h2 elements and create a list item for each one\r\n  for (let i = 0; i < headers.length; i++) {\r\n    const header = headers[i];\r\n    const headerText = header.textContent;\r\n\/\/     const headerId = 'header-' + i;\r\n    const headerId = headerText\r\n    .toLowerCase()\r\n    .trim()\r\n    .replace(\/[^\\w\\s-]\/g, '')  \/\/ hapus tanda baca\r\n    .replace(\/\\s+\/g, '-'); \/\/ ganti spasi jadi \"-\"\r\n\r\n    \/\/ Set an ID for the header if it doesn't have one\r\n    header.setAttribute('id', headerId);\r\n\r\n    \/\/ Create a list item for the TOC\r\n    const listItem = document.createElement('li');\r\n\r\n    \/\/ Create a link for the list item\r\n    const link = document.createElement('a');\r\n    link.setAttribute('href', '#' + headerId);\r\n    link.textContent = headerText;\r\n\r\n    \/\/ Append the link to the list item\r\n    listItem.appendChild(link);\r\n\r\n    \/\/ Append the list item to the TOC list\r\n    tocList.appendChild(listItem);\r\n  }\r\n});\r\n\r\n\/\/ Keep height and placement of content using placeholder in place of TOC\r\ndocument.addEventListener(\"DOMContentLoaded\", function() {\r\n  const toc = document.querySelector('#toc');\r\n  const placeholderToc = document.querySelector('#placeholder-toc');\r\n\r\n  function setPlaceholderHeight() {\r\n    placeholderToc.style.height = `${toc.offsetHeight}px`;\r\n  }\r\n\r\n  \/\/ Set the initial height of the placeholder\r\n  setPlaceholderHeight();\r\n\r\n  \/\/ Update the height on window resize\r\n  window.addEventListener('resize', setPlaceholderHeight);\r\n});\r\n  const tocTitle = document.querySelector('#toc-title'); \/\/ Assuming header-faq is the element for TOC title\r\n\r\n\/\/ Sticky TOC and update heading\r\n\/\/ document.addEventListener(\"DOMContentLoaded\", function() {\r\n\/\/   const toc = document.querySelector('#toc');\r\n\/\/   const footer = document.querySelector('.td-footer-template-wrap');\r\n\/\/   const tocParent = toc.parentElement;\r\n\/\/   const divTop = tocParent.getBoundingClientRect().top + window.pageYOffset;\r\n\/\/   const tocHeight = toc.offsetHeight;\r\n\/\/   const triggerPoint = divTop + tocHeight + 700;\r\n\/\/   const footerHeight = footer.offsetHeight;\r\n\/\/   const triggerFooterPoint = footer.getBoundingClientRect().top + window.pageYOffset - footerHeight - footerHeight - footerHeight;\r\n\/\/   const phtoc = document.querySelector('#placeholder-toc');\r\n\/\/   const headers = document.querySelectorAll('.td-post-content h2');\r\n\/\/   const navLinks = document.querySelectorAll('#toc-list a');\r\n\t\r\n\/\/ \tconst panel2 = document.querySelector(\"#toc .list\");\r\n\/\/ \tvar icon = document.querySelector(\".toc-icon\");\r\n\r\n\/\/   let activeLink = null; \/\/ Declare activeLink outside the loop\r\n\t\r\n\/\/   \/\/ Function to handle scroll and add\/remove .sticky class\r\n\/\/   function handleScroll() {\r\n\/\/     const windowTop = window.pageYOffset || document.documentElement.scrollTop;\r\n\/\/     let currentHeader = '';\r\n\r\n\/\/     \/\/ Highlight user progress as the heading comes\r\n\/\/     headers.forEach(header => {\r\n\/\/ \t\tconst headerTop = header.offsetTop;\r\n\/\/ \t\tconst headerHeight = header.clientHeight;\r\n\/\/ \/\/ \t\tif (window.scrollY >= (headerTop - headerHeight + 700)) {\r\n\/\/ \/\/ \t\t\tconst currentHeaderId = header.getAttribute('id');\r\n\/\/ \/\/ \t\t\tconst currentHeaderText = document.getElementById(currentHeaderId).textContent;\r\n\/\/ \/\/ \t\t\tconsole.log(\"current header text:\", currentHeaderText);\r\n\/\/ \/\/ \t\t\ttocTitle.textContent = currentHeaderText;\r\n\/\/ \/\/ \t\t\tcurrentHeader = currentHeaderId;\r\n\t\t\t\r\n\/\/ \/\/ \t\t\tif(window.innerWidth < 767){\r\n\/\/ \/\/ \t\t\t\ttocTitle.textContent = 'Daftar Isi';\r\n\/\/ \/\/ \t\t\t}\r\n\/\/ \/\/ \t\t}\r\n\/\/ \t\tif(window.innerWidth < 767){\r\n\/\/ \t\t\ttocTitle.textContent = 'Daftar Isi'; \/\/ Selalu pertahankan judul ini di mobile\r\n\/\/ \t\t} else {\r\n\/\/ \t\t\tif (window.scrollY >= (headerTop - headerHeight + 700)) {\r\n\/\/ \t\t\t\tconst currentHeaderId = header.getAttribute('id');\r\n\/\/ \t\t\t\tconst currentHeaderText = document.getElementById(currentHeaderId).textContent;\r\n\/\/ \t\t\t\ttocTitle.textContent = currentHeaderText;\r\n\/\/ \t\t\t\tcurrentHeader = currentHeaderId;\r\n\/\/ \t\t\t}\r\n\/\/ \t\t}\r\n\/\/ \t});\r\n\r\n\/\/     navLinks.forEach(link => {\r\n\/\/       link.classList.remove('active');\r\n\/\/       if(currentHeader != '') {\r\n\/\/ \t\t  if (link.getAttribute('href').includes(currentHeader)) {\r\n\/\/ \t\t\t  link.classList.add('active');\r\n\/\/ \t\t  }\r\n\/\/ \t  }\r\n\/\/     });\r\n\/\/ \/\/     if (windowTop < triggerFooterPoint) {\r\n\/\/ \/\/         toc.style.display = 'block';\r\n\/\/ \/\/ \t}else{\r\n\/\/ \/\/         toc.style.display = 'none';\r\n\/\/ \/\/ \t}\r\n\/\/     \/\/ Update TOC title if sticky\r\n\/\/     if (windowTop > triggerPoint) {\r\n\/\/       if (!toc.classList.contains('sticky')) {\r\n\/\/         phtoc.style.display = \"block\";\r\n\/\/         toc.classList.add('sticky');\r\n\/\/         toc.style.width = `${tocParent.offsetWidth}px`; \/\/ Set width to match the parent element\r\n\/\/         toc.setAttribute('style', 'width: ' + tocParent.offsetWidth + 'px !important;');\r\n\/\/         toc.style.backgroundColor = \"#FFF\";\r\n\/\/ \t\tpanel2.style.height = '0px';\r\n\/\/ \t\t  icon.style.transform = \"rotate(180deg)\";\r\n\/\/ \t\t  if(window.innerWidth < 767){\r\n\/\/ \/\/ \t\t\t  const tocs = document.querySelector('#toc.sticky');\r\n\/\/ \t\t\t  tocTitle.textContent = 'Daftar Isi'; \/\/ Reset title\r\n\/\/        \t\t  toc.style.width = '150px'; \/\/ Set width to match the parent element\r\n\/\/ \t\t  }\r\n\/\/       }\r\n\/\/       if (currentHeader) {\r\n\/\/ \/\/         console.log(\"activeLink:\", activeLink);\r\n\/\/         if (activeLink) {\r\n\/\/ \/\/           tocTitle.textContent = activeLink.textContent; \/\/ Update TOC title\r\n\/\/           tocTitle.textContent = activeLink ? activeLink.textContent : \"\"; \/\/ Update title only if activeLink exists\r\n\/\/         }\r\n\/\/       }\r\n\/\/     } else {\r\n\/\/       toc.classList.remove('sticky');\r\n\/\/       phtoc.style.display = \"none\";\r\n\/\/       toc.style.width = 'unset'; \/\/ Reset to original width\r\n\/\/       toc.style.backgroundColor = \"#FFF\";\r\n\/\/       tocTitle.textContent = 'Daftar isi'; \/\/ Reset title\r\n\/\/ \t\tpanel2.style.height = panel2.scrollHeight + \"px\";\r\n\/\/ \t\ticon.style.transform = \"rotate(180deg)\";\r\n\/\/     }\r\n\/\/   }\r\n\r\n\/\/     \/\/ Attach the scroll event listener to the window\r\n\/\/     window.addEventListener('scroll', handleScroll);\r\n\r\n\/\/     \/\/ Initial call to handleScroll to set the correct state on load\r\n\/\/     handleScroll();\r\n\/\/ });\r\n\t\r\n\/\/ \t\/\/ Open toggle TOC\r\n\/\/ \t  document.addEventListener(\"DOMContentLoaded\", function() {\r\n\/\/ \t\tvar tocHeader = document.querySelector(\"#toc .header\");\r\n\/\/ \t\tvar toc = document.querySelector(\"#toc\");\r\n\/\/ \t\tvar icon = document.querySelector(\".toc-icon\");\r\n\/\/ \t\tconst tocTitle = document.querySelector('#toc-title');\r\n\/\/ \t\tconst tocs = document.querySelector('#toc.sticky');\r\n\/\/  \t\tconst tocParent = toc.parentElement;\t\t  \r\n\r\n\/\/ \t\t  tocHeader.addEventListener(\"click\", function() {\r\n\/\/ \t\t\tvar panel = this.nextElementSibling;\r\n\/\/ \t\t\tif (panel.style.height !== '0px') { \/\/ Check if height is not 0px\r\n\/\/ \t\t\t  panel.style.height = '0px'; \/\/ Set height to 0 for full collapse\r\n\/\/ \t\t\t  icon.style.transform = \"rotate(180deg)\";\r\n\/\/ \/\/ \t\t\t\ttoc.style.paddingBottom = '6px'; \r\n\/\/ \t\t\t\tif(window.innerWidth > 768){\r\n\/\/ \t\t\t\t\tif(!toc.classList.contains('sticky')){\r\n\/\/ \t\t\t\t\t\ttoc.style.width = \"unset\";\r\n\/\/ \/\/ \t\t\t\t\t\ttoc.setAttribute('style', 'width: ' + tocParent.offsetWidth + 'px !important;');\r\n\/\/ \t\t\t\t\t}\r\n\/\/ \t\t\t\t\tif (toc.classList.contains('sticky')){\r\n\/\/ \t\t\t\t\t\ttoc.style.width = '${tocParent.offsetWidth}px';\r\n\/\/ \t\t\t\t\t\ttoc.setAttribute('style', 'width: ' + tocParent.offsetWidth + 'px !important;');\r\n\/\/ \t\t\t\t\t}\r\n\/\/ \t\t\t\t}\r\n\/\/ \t\t\t\tif(window.innerWidth < 767){\r\n\/\/ \t\t\t\t\ttoc.style.width = \"unset\"; \/\/ Reset width\r\n\/\/ \t\t\t\t}\r\n\/\/ \t\t\t\ttoc.style.backgroundColor = \"#FFF1F1\";\r\n\/\/ \t\t\t} else {\r\n\/\/ \t\t\t  panel.style.height = panel.scrollHeight + \"px\";\r\n\/\/ \t\t\t  icon.style.transform = \"rotate(0deg)\";\r\n\/\/ \t\t\t  toc.style.backgroundColor = \"#FFF\";\r\n\/\/ \t\t\t  tocTitle.textContent = 'Daftar isi'; \/\/ Reset title\r\n\/\/ \t\t\t\ttoc.style.paddingBottom = '24px';\r\n\/\/ \t\t\t \tif(window.innerWidth < 767){\r\n\/\/ \t\t\t\t\ttoc.style.width = `${tocParent.offsetWidth}px`; \/\/ Set width to match the parent element\r\n\/\/ \t\t\t\t\ttoc.setAttribute('style', 'width: ' + tocParent.offsetWidth + 'px !important;');\r\n\/\/ \t\t\t\t}\r\n\/\/ \t\t\t}\r\n\/\/ \t\t  });\r\n\r\n\/\/ \t\t  \/\/ Close TOC when a link inside it is clicked\r\n\/\/ \t\t  var tocLinks = document.querySelectorAll(\"#toc .list a\");\r\n\/\/ \t\t  tocLinks.forEach(function(link) {\r\n\/\/ \t\t\tlink.addEventListener(\"click\", function() {\r\n\/\/ \t\t\t  var panel = document.querySelector(\"#toc .list\");\r\n\/\/ \t\t\t  panel.style.height = '0px'; \/\/ Set height to 0 for full collapse\r\n\/\/ \t\t\t  icon.style.transform = \"rotate(180deg)\";\r\n\/\/ \t\t\t  toc.style.backgroundColor = \"#FFF\";\r\n\/\/ \t\t\t});\r\n\/\/ \t\t  });\r\n\/\/ \t\t});\r\n\r\n\/\/ START new JS for ToC improvements\r\ndocument.addEventListener(\"DOMContentLoaded\", function() {\r\n  const toc = document.querySelector('#toc');\r\n  const footer = document.querySelector('.td-footer-template-wrap');\r\n  const tocParent = toc.parentElement;\r\n  const divTop = tocParent.getBoundingClientRect().top + window.pageYOffset;\r\n  const tocHeight = toc.offsetHeight;\r\n  const triggerPoint = divTop + tocHeight + 1750;\r\n\tconsole.log(triggerPoint)\r\n  const footerHeight = footer.offsetHeight;\r\n  const triggerFooterPoint = footer.getBoundingClientRect().top + window.pageYOffset - footerHeight*3;\r\n  const phtoc = document.querySelector('#placeholder-toc');\r\n  const headers = document.querySelectorAll('.td-post-content h2');\r\n  const navLinks = document.querySelectorAll('#toc-list a');\r\n  \r\n  const panel2 = document.querySelector(\"#toc .list\");\r\n  const icon = document.querySelector(\".toc-icon\");\r\n  const tocTitle = document.querySelector('#toc-title');\r\n\r\n  let activeLink = null;\r\n  let userClosedTOC = false; \/\/ Flag user menutup TOC\r\n\r\n  function handleScroll() {\r\n    const windowTop = window.pageYOffset || document.documentElement.scrollTop;\r\n    let currentHeader = '';\r\n\r\n    \/\/ Update TOC title sesuai header yang terlihat\r\n    headers.forEach(header => {\r\n      const headerTop = header.offsetTop;\r\n      const headerHeight = header.clientHeight;\r\n      if(window.innerWidth < 767){\r\n        tocTitle.textContent = 'Daftar Isi'; \r\n      } else {\r\n        if (window.scrollY >= (headerTop - headerHeight + 1750)) {\r\n          const currentHeaderId = header.getAttribute('id');\r\n          const currentHeaderText = document.getElementById(currentHeaderId).textContent;\r\n          tocTitle.textContent = currentHeaderText;\r\n          currentHeader = currentHeaderId;\r\n        }\r\n      }\r\n    });\r\n\r\n    navLinks.forEach(link => {\r\n      link.classList.remove('active');\r\n      if(currentHeader && link.getAttribute('href').includes(currentHeader)) {\r\n        link.classList.add('active');\r\n      }\r\n    });\r\n\r\n    if (windowTop > triggerPoint) {\r\n      if (!toc.classList.contains('sticky')) {\r\n        phtoc.style.display = \"block\";\r\n        toc.classList.add('sticky');\r\n        toc.style.width = `${tocParent.offsetWidth}px`;\r\n        toc.style.backgroundColor = \"#FFF\";\r\n        \/\/ Saat sticky, TOC otomatis tertutup\r\n        panel2.style.height = '0px';\r\n        icon.style.transform = \"rotate(180deg)\";\r\n        userClosedTOC = true; \/\/ Set flag supaya tidak terbuka saat scroll\r\n      }\r\n      \r\n      if(window.innerWidth < 767){\r\n        tocTitle.textContent = 'Daftar Isi'; \r\n        toc.style.width = '150px';\r\n      }\r\n\r\n    } else {\r\n      toc.classList.remove('sticky');\r\n      phtoc.style.display = \"none\";\r\n      toc.style.width = 'unset';\r\n      toc.style.backgroundColor = \"#FFF\";\r\n      tocTitle.textContent = 'Daftar isi'; \r\n\r\n      \/\/ Kembalikan panel jika user belum menutup manual\r\n      if(!userClosedTOC) {\r\n        panel2.style.height = panel2.scrollHeight + \"px\";\r\n        icon.style.transform = \"rotate(0deg)\";\r\n      }\r\n    }\r\n  }\r\n\r\n  window.addEventListener('scroll', handleScroll);\r\n  handleScroll();\r\n\r\n  \/\/ Toggle TOC saat user klik\r\n  const tocHeader = document.querySelector(\"#toc .header\");\r\n  tocHeader.addEventListener(\"click\", function() {\r\n    const panel = panel2;\r\n    if (panel.style.height !== '0px') {\r\n      panel.style.height = '0px';\r\n      icon.style.transform = \"rotate(180deg)\";\r\n      userClosedTOC = true;\r\n    } else {\r\n      panel.style.height = panel.scrollHeight + \"px\";\r\n      icon.style.transform = \"rotate(0deg)\";\r\n      userClosedTOC = false;\r\n    }\r\n  });\r\n\r\n  \/\/ Close TOC saat link diklik\r\n  document.querySelectorAll(\"#toc .list a\").forEach(link => {\r\n    link.addEventListener(\"click\", function() {\r\n      panel2.style.height = '0px';\r\n      icon.style.transform = \"rotate(180deg)\";\r\n      userClosedTOC = true;\r\n    });\r\n  });\r\n});\r\n\/\/ END new JS for ToC improvements\r\n\r\n\t\r\n\/\/ \tmake the heading at the center of the viewport\r\n\/\/ \tdocument.addEventListener('DOMContentLoaded', function() {\r\n\/\/     \/\/ Add click event listener to all links in the TOC list\r\n\/\/     document.querySelectorAll('#toc-list a').forEach(anchor => {\r\n\/\/         anchor.addEventListener('click', function (e) {\r\n\/\/             e.preventDefault(); \/\/ Prevent the default behavior of jumping to the anchor\r\n\/\/ \/\/ \t\t\tconsole.log(\"prevent default\");\r\n\/\/             const targetId = this.getAttribute('href').substring(1); \/\/ Get the ID of the target element\r\n\/\/             const targetElement = document.getElementById(targetId); \/\/ Get the target element\r\n\r\n\/\/             if (targetElement) {\r\n\/\/                 const headerHeight = document.querySelector('#toc .header').offsetHeight; \/\/ Get the height of the fixed header\r\n\/\/                 const windowHeight = window.innerHeight; \/\/ Get the height of the viewport\r\n\/\/                 const targetOffset = targetElement.offsetTop; \/\/ Get the top offset of the target element\r\n\/\/                 const scrollTo = targetOffset + (windowHeight \/ 2) + (headerHeight); \/\/ Calculate the scroll position to center the target element\r\n\r\n\/\/                 \/\/ Scroll to the calculated position smoothly\r\n\/\/                 window.scrollTo({\r\n\/\/                     top: scrollTo,\r\n\/\/                     behavior: 'smooth'\r\n\/\/                 });\r\n\/\/             }\r\n\/\/         });\r\n\/\/     });\r\n\/\/ });\r\n<\/script>\r\n\r\n<script>\r\n    \/\/ Scrollspy function to highlight the active TOC item based on the scroll position\r\n  function scrollSpy(tocClass) {\r\n    const scrollPosition = window.scrollY;\r\n\r\n    \/\/ Find the active h2 and h3 headings based on their position in the corresponding TOC\r\n    let activeH2 = null;\r\n    let activeH3 = null;\r\n\r\n    const tocItems = document.querySelectorAll(`.${tocClass} li`);\r\n    tocItems.forEach(item => {\r\n      const a = item.querySelector('a');\r\n      if (!a) return;\r\n      const href = a.getAttribute('href');\r\n      const targetId = href.substring(1); \/\/ Remove the '#' from the href to get the target ID\r\n      const targetElement = document.getElementById(targetId);\r\n      if (!targetElement) return;\r\n\r\n      const targetTop = targetElement.getBoundingClientRect().top + scrollPosition;\r\n      const nextItem = item.nextElementSibling;\r\n      const nextTop = nextItem ? nextItem.getBoundingClientRect().top + scrollPosition : Infinity;\r\n\r\n      if (targetTop <= scrollPosition + 150) {\r\n        if (a.parentElement.parentElement === tocItems) {\r\n          \/\/ The h2 heading is at the root level of the TOC\r\n          activeH2 = { id: targetId, level: 'h2' };\r\n        } \r\n\t\t  else {\r\n          \/\/ The h3 heading is nested under an h2 heading\r\n          const parentH2 = a.parentElement.parentElement.previousElementSibling;\r\n          if (parentH2) {\r\n            const h2Link = parentH2.querySelector('a');\r\n            if (h2Link) {\r\n              const h2Href = h2Link.getAttribute('href');\r\n              const h2Id = h2Href.substring(1);\r\n              activeH2 = { id: h2Id, level: 'h2' };\r\n            }\r\n          }\r\n          activeH3 = { id: targetId, level: 'h3' };\r\n        }\r\n      }\r\n\r\n      if (targetTop > scrollPosition + 150 && nextTop > scrollPosition + 150 && !activeH3) {\r\n        \/\/ Reset the activeH2 when there are no more active h3 headings\r\n        activeH2 = null;\r\n      }\r\n    });\r\n\r\n    \/\/ Update the active state for the TOC items\r\n    tocItems.forEach(item => {\r\n      item.classList.remove('active');\r\n      const a = item.querySelector('a');\r\n      if (a) {\r\n        const href = a.getAttribute('href');\r\n        const targetId = href.substring(1);\r\n        if ((activeH2 && activeH2.id === targetId) || (activeH3 && activeH3.id === targetId)) {\r\n          item.classList.add('active');\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  \/\/ Call scrollSpy for each TOC on window scroll\r\n  const tocClasses = ['list_toc', 'list_toc_float']; \/\/ Add other TOC class names here if you have more than two instances\r\n  tocClasses.forEach(tocClass => {\r\n    window.addEventListener('scroll', () => scrollSpy(tocClass));\r\n  });\r\n<\/script>\r\n\r\n<!-- ToC List for desktop side bar, diganti jadi inject by php, di code snippet \"Sidebar Accordion\" -->\r\n<!-- <script>\r\n\tdocument.addEventListener(\"DOMContentLoaded\", function() {\r\n\r\n        \/\/ Fungsi untuk membuat nested list\r\n        function createNestedList(parentNode, children) {\r\n            if (children.length === 0) return;\r\n\r\n            const nestedUl = document.createElement('ul');\r\n            children.forEach(child => {\r\n                const nestedLi = document.createElement('li');\r\n                const nestedA = document.createElement('a');\r\n                nestedA.textContent = child.title;\r\n                nestedA.href = `#${child.id}`;\r\n                nestedLi.appendChild(nestedA);\r\n                nestedUl.appendChild(nestedLi);\r\n\r\n                if (child.children.length > 0) {\r\n                    createNestedList(nestedLi, child.children);\r\n                }\r\n            });\r\n\r\n            parentNode.appendChild(nestedUl);\r\n        }\r\n\r\n        \/\/ Membuat objek untuk menyimpan daftar h2 dan h3 beserta judulnya\r\n        const headings = [];\r\n\r\n           \/\/ Mengambil semua elemen h2 dan h3\r\n        \/\/ Mengambil semua elemen h2 dan h3\r\n\t\tconst elements = document.querySelectorAll('.td-post-content h2');\r\n\r\n\t\t\tfunction newFormatId(text) {\r\n\t\t\t\tif(text.toLowerCase() === \"key takeaways\") {\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\t\t\t\t\r\n\t\t\t\tconst result = text.toLowerCase()\r\n\t\t\t\t.trim()\r\n\t\t\t\t.replace(\/[^\\w\\s-]\/g, '')  \/\/ hapus tanda baca\r\n\t\t\t\t.replace(\/\\s+\/g, '-'); \/\/ ganti spasi jadi \"-\"\r\n\r\n\t\t\t\treturn result;\r\n\t\t\t}\r\n\t\r\n\t\telements.forEach(element => {\r\n\t\t\tif (element.tagName === 'H2') {\r\n\t\t\t\tconst id = newFormatId(element.textContent); \/\/ Hasilkan ID baru\r\n\t\t\t\telement.id = id; \/\/ Tetapkan ID ke elemen h2\r\n\t\t\t\tif (element.textContent.toLowerCase() === \"key takeaways\") {return;} \/\/ Kalau Key Takeaways, jangan dimasukin\r\n\t\t\t\theadings.push({ level: 'h2', id: id, title: element.textContent, children: [] });\r\n\t\t\t} else if (element.tagName === 'H3') {\r\n\t\t\t\tconst id = newFormatId(element.textContent); \/\/ Hasilkan ID baru\r\n\t\t\t\telement.id = id; \/\/ Tetapkan ID ke elemen h3\r\n\t\t\t\tif (headings.length > 0) {\r\n\t\t\t\t\theadings[headings.length - 1].children.push({ level: 'h3', id: id, title: element.textContent, children: [] });\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n       \/\/ Membuat list HTML dari objek headings\r\n\t\tconst ul = document.getElementById('list_toc');\r\n\t\tlet currentUl = ul;\r\n\t\theadings.forEach(heading => {\r\n\t\t\tconst li = document.createElement('li');\r\n\t\t\tconst a = document.createElement('a');\r\n\t\t\ta.textContent = heading.title;\r\n\t\t\ta.href = `#${heading.id}`; \/\/ Gunakan ID yang baru dihasilkan\r\n\t\t\tli.appendChild(a);\r\n\r\n\t\t\tif (heading.level === 'h2') {\r\n\t\t\t\tcurrentUl = li;\r\n\t\t\t\tul.appendChild(li);\r\n\t\t\t} else if (heading.level === 'h3') {\r\n\t\t\t\tif (!currentUl.lastElementChild || currentUl.lastElementChild.tagName !== 'UL') {\r\n\t\t\t\t\tconst nestedUl = document.createElement('ul');\r\n\t\t\t\t\tcurrentUl.appendChild(nestedUl);\r\n\t\t\t\t\tcurrentUl = nestedUl;\r\n\t\t\t\t}\r\n\t\t\t\tcurrentUl.appendChild(li);\r\n\t\t\t}\r\n\r\n\t\t\tcreateNestedList(li, heading.children);\r\n\t\t});\r\n\t\t\/\/ Dapatkan elemen ul dengan id 'list_toc'\r\n\t\tconst ulFloat = document.getElementById('list_toc');\r\n\r\n\t\t\/\/ Dapatkan isi (child elements) dari ul dengan id 'list_toc'\r\n\t\tconst clonedChildren = ulFloat.cloneNode(true).children;\r\n\r\n\t\t\/\/ Dapatkan elemen ul dengan id 'list_toc_float'\r\n\t\tconst ulToc = document.getElementById('list_toc_float');\r\n\r\n\t\t\/\/ Tambahkan isi yang telah didapatkan dari 'list_toc' ke ul dengan id 'list_toc_float'\r\n\t\tulToc.append(...clonedChildren);\r\n\r\n\r\n        \/\/ Fungsi untuk mengambil tinggi navbar\r\n\t\tfunction getNavbarHeight() {\r\n\t\t\tconst navbar = document.getElementById('tdi_34');\r\n\t\t\treturn navbar ? navbar.offsetHeight : 0;\r\n\t\t}\r\n\r\n\t\t\/\/ Fungsi untuk menambahkan offset posisi scroll\r\n\t\tfunction scrollToElementWithOffset(elementId) {\r\n\t\t\tconst element = document.getElementById(elementId);\r\n\t\t\tif (element) {\r\n\t\t\t\tconst offset = getNavbarHeight();\r\n\t\t\t\tconst elementPosition = element.getBoundingClientRect().top;\r\n\t\t\t\tconst offsetPosition = elementPosition - offset - 40;\r\n\r\n\t\t\t\twindow.scrollBy({\r\n\t\t\t\t\ttop: offsetPosition,\r\n\t\t\t\t\tbehavior: 'smooth'\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t\/\/ Fungsi untuk menangani klik pada tautan judul\r\n\t\tfunction handleTitleClick(event) {\r\n\t\t\tevent.preventDefault();\r\n\t\t\tconst href = event.target.getAttribute('href').substr(1);\r\n\t\t\tscrollToElementWithOffset(href);\r\n\t\t}\r\n\r\n\t\t\/\/ Tambahkan event listener untuk semua tautan judul\r\n\t\tconst titleLinks = document.querySelectorAll('a[href^=\"#\"]');\r\n\t\ttitleLinks.forEach(link => {\r\n\t\t\tlink.addEventListener('click', handleTitleClick);\r\n\t\t});\r\n\t\t\r\n\t});\r\n    <\/script> -->\r\n\n<p><span id=\"definisi-forecast-barang\">\r\n\r\n<script>\r\n    \/\/ check which image to use based on screensize\r\n    document.addEventListener(\"DOMContentLoaded\", function() {\r\n        function updateImageSource() {\r\n            var images = document.querySelectorAll('.responsive-image-banner');\r\n            var screenWidth = window.innerWidth;\r\n\r\n            images.forEach(function(img) {\r\n                var mobileSrc = img.getAttribute('data-mobile-src');\r\n                var desktopSrc = img.getAttribute('data-desktop-src');\r\n\r\n                if (screenWidth < 576 && mobileSrc) {\r\n                    img.setAttribute('src', mobileSrc);\r\n                } else {\r\n                    img.setAttribute('src', desktopSrc);\r\n                }\r\n            });\r\n        }\r\n\r\n        \/\/ Initial check\r\n        updateImageSource();\r\n\r\n        \/\/ Update on resize\r\n        window.addEventListener('resize', updateImageSource);\r\n    });\r\n<\/script><\/span><\/p>\n<h2><strong><span id=\"a\">Apa itu Forecast Barang?<\/span><\/strong><\/h2>\n<p>Forecast barang adalah <a href=\"https:\/\/www.hashmicro.com\/id\/blog\/make-to-stock-mts\/\">perkiraan kebutuhan stok di masa depan<\/a> berdasarkan data penjualan, tren pasar, dan pola permintaan pelanggan. Proses ini dilakukan dengan menganalisis data historis dan faktor eksternal untuk menentukan jumlah barang yang tepat agar operasional lebih efisien.<\/p>\n<p>Tujuan utama forecast barang adalah memastikan ketersediaan stok yang cukup untuk memenuhi permintaan tanpa kelebihan dan mengurangi risiko kehabisan stok yang bisa mengganggu penjualan serta mengoptimalkan modal kerja.<\/p>\n<p>Selain berperan dalam pengelolaan inventaris, forecast barang juga menjadi alat penting dalam pengambilan keputusan strategis bisnis sehingga bisnis dapat meningkatkan layanan pelanggan sekaligus mengoptimalkan biaya operasional.<\/p>\n<h2><strong>Sumber Data yang Dipakai untuk Forecast Barang<\/strong><\/h2>\n<p><a href=\"https:\/\/www.hashmicro.com\/id\/blog\/forecasting-adalah\/\">Forecast barang yang rapi<\/a> hampir selalu dimulai dari data yang siap pakai. Di bawah ini sumber data yang paling umum dipakai tim inventory untuk menyusun forecast.<\/p>\n<h3><strong>1. Histori penjualan per SKU dan per kanal<\/strong><\/h3>\n<p>Data transaksi penjualan jadi fondasi utama untuk melihat pola permintaan. Idealnya dipisah per SKU, per cabang\/gudang, serta per kanal (offline, marketplace, B2B) karena ritmenya sering berbeda.<\/p>\n<h3><strong>2. Kalender promosi dan perubahan harga<\/strong><\/h3>\n<p>Promo bundling, diskon periode tertentu, cashback, sampai price change biasanya mengubah demand secara signifikan. Data ini penting supaya lonjakan permintaan tidak terbaca sebagai tren normal dan tidak menyesatkan forecast periode berikutnya.<\/p>\n<h3><strong>3. Data stockout dan lost sales<\/strong><\/h3>\n<p>Saat stok habis, penjualan tercatat nol, padahal demand bisa saja tetap ada. Catatan stockout (tanggal\/jam, SKU, lokasi) <a href=\"https:\/\/www.hashmicro.com\/id\/blog\/cara-mengatasi-selisih-stock-opname\/\">membantu mengurangi adanya selisih stock<\/a> sehingga\u00a0tim memperkirakan demand yang hilang agar baseline forecast tidak turun karena data &#8216;nol&#8217; yang misleading.<\/p>\n<h3><strong>4. Lead time supplier dan reliabilitas pengiriman<\/strong><\/h3>\n<p>Forecast dipakai untuk menentukan kapan order harus dibuat, jadi data lead time wajib masuk. Selain rata-rata lead time, catat juga variasinya (sering molor atau tidak) untuk menentukan safety stock yang realistis.<\/p>\n<h3><strong>5. Data inventory on-hand, inbound, dan reserve<\/strong><\/h3>\n<p>Jumlah stok tersedia, stok dalam perjalanan, serta stok yang sudah di-reserve untuk sales order memengaruhi keputusan replenishment. Data ini membantu tim membedakan kebutuhan order karena demand versus order karena stok tersangkut.<\/p>\n<h3><strong>6. Retur, refund, dan barang rusak<\/strong><\/h3>\n<p>Retur bisa kembali jadi stok layak jual, atau masuk kategori reject. Kalau retur tinggi dan tidak dipisahkan statusnya, <a href=\"https:\/\/www.hashmicro.com\/id\/blog\/sales-forecasting\/\">sales forecasting<\/a> bisa meleset karena supply yang terlihat naik, padahal yang layak jual tidak bertambah.<\/p>\n<h3><strong>7. Pola musiman dan event operasional<\/strong><\/h3>\n<p>Musim liburan, Ramadan, tahun ajaran baru, sampai event industri (pameran, campaign brand) sering membentuk pola berulang. Data musiman yang dicatat rapi memudahkan pemilihan metode (misalnya seasonal model) dan penentuan stok untuk periode puncak.<\/p>\n<h3><strong>8. Rencana bisnis: target penjualan, ekspansi, dan perubahan assortment<\/strong><\/h3>\n<p>Launch produk baru, stop produk lama, buka cabang baru, atau perubahan paket bundling perlu masuk sebagai catatan asumsi. Ini biasanya datang dari tim sales\/marketing\/operational planning agar forecast tidak hanya mengikuti pola masa lalu.<\/p>\n<h2><strong><span id=\"b\">Metode Forecast Barang yang Tepat untuk Setiap Pola Permintaan<\/span><\/strong><\/h2>\n<p>Berikut adalah beberapa <a href=\"https:\/\/www.hashmicro.com\/id\/blog\/mengenal-metode-forecasting-dan-manfaatnya-bagi-perusahaan-anda\/\">metode forecasting<\/a> yang umum yang dapat Anda gunakan dalam pengelolaan stok:<\/p>\n<h3><strong>1. Pola permintaan stabil dan volume relatif rata<\/strong><\/h3>\n<p>Untuk SKU dengan penjualan yang cenderung konsisten dari periode ke periode, metode seperti moving average atau exponential smoothing (simple) biasanya cukup.<\/p>\n<p>Moving average cocok saat Anda ingin membaca pola dari beberapa periode terakhir (3\u20136 periode), sedangkan smoothing lebih enak dipakai kalau ingin data terbaru punya pengaruh lebih besar.<\/p>\n<h3><strong>2. Ada tren naik atau turun yang konsisten<\/strong><\/h3>\n<p>Kalau permintaan terlihat meningkat atau menurun secara bertahap, pakai exponential smoothing dengan komponen tren (Holt) atau regresi linier agar proyeksi mengikuti arah pergerakannya.<\/p>\n<p>Supaya hasilnya tidak bias, pastikan histori datanya cukup panjang dan ada catatan perubahan harga atau promo yang bisa mengubah pola permintaan.<\/p>\n<h3><strong>3. Musiman dan berulang tiap periode<\/strong><\/h3>\n<p>Untuk demand yang sering naik di momen tertentu seperti Ramadan, liburan, atau back-to-school, metode seasonal time-series (keluarga ARIMA\/seasonal model) lebih relevan karena bisa menangkap pola musiman.<\/p>\n<p>Pada tahap eksekusi, data promo dan event sebaiknya dicatat jelas supaya baseline permintaan tidak tercampur dengan efek campaign.<\/p>\n<h3><strong>4. Demand lumpy (jarang laku, tetapi sekali laku bisa besar)<\/strong><\/h3>\n<p>Pada SKU seperti sparepart, item proyek, atau barang slow-moving, pendekatan intermittent demand lebih cocok karena fokusnya ada di pola permintaan yang tidak rutin. Praktiknya sering dimulai dari klasifikasi SKU lalu diturunkan ke aturan reorder, termasuk minimum order, service level, dan safety stock yang disesuaikan dengan variasi lead time.<\/p>\n<h3><strong>5. Produk baru atau data historis minim<\/strong><\/h3>\n<p>Untuk SKU baru atau saat masuk channel baru, forecast biasanya dimulai dari judgment\/Delphi lalu dibandingkan dengan produk analog yang punya karakter permintaan mirip. Setelah transaksi mulai terkumpul, update forecast secara berkala (misalnya mingguan) agar asumsi awal cepat terkoreksi dan lebih dekat dengan demand aktual.<\/p>\n<p>Banyak faktor eksternal yang memengaruhi demand<br \/>\nKalau permintaan sangat dipengaruhi harga, promo, musim, channel, atau perbedaan lokasi, gunakan regresi atau model berbasis variabel supaya faktor-faktor tersebut masuk ke perhitungan.<\/p>\n<p>Berikut ringkasan metode forecast barang yang umum digunakan untuk memprediksi kebutuhan stok secara lebih akurat:<\/p>\n<table>\n<tbody>\n<tr>\n<td style=\"background-color: #990000; color: #ffffff; padding: 5px; text-align: center;\"><strong>Metode Forecast<\/strong><\/td>\n<td style=\"background-color: #990000; color: #ffffff; padding: 5px; text-align: center;\"><strong>Penjelasan Singkat<\/strong><\/td>\n<\/tr>\n<tr>\n<td><strong data-start=\"624\" data-end=\"642\">Moving Average<\/strong><\/td>\n<td>Menghitung rata-rata penjualan dari beberapa periode sebelumnya, cocok untuk tren stabil.<\/td>\n<\/tr>\n<tr>\n<td><strong data-start=\"746\" data-end=\"771\">Exponential Smoothing<\/strong><\/td>\n<td>Memberi bobot lebih pada data terbaru, ideal untuk tren naik\/turun bertahap.<\/td>\n<\/tr>\n<tr>\n<td><strong data-start=\"866\" data-end=\"884\">Regresi Linier<\/strong><\/td>\n<td>Menghubungkan permintaan dengan variabel lain seperti harga atau promosi.<\/td>\n<\/tr>\n<tr>\n<td><strong>ARIMA<\/strong><\/td>\n<td>Menganalisis tren dan musiman dalam data deret waktu untuk prediksi jangka menengah.<\/td>\n<\/tr>\n<tr>\n<td><strong data-start=\"1105\" data-end=\"1122\">Delphi Method<\/strong><\/td>\n<td>Berdasarkan opini para ahli melalui diskusi berulang, cocok untuk produk baru.<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h2><strong><span id=\"c\">Strategi Membuat Forecast Barang Lebih Akurat<\/span><\/strong><\/h2>\n<p>Setelah mengetahui metode forecasting yang pas, Anda juga perlu mengetahui bagaimana mengimplementasinya dengan tepat dan tidak asal-asalan.<\/p>\n<h3><strong>1. Rapikan data historis per SKU dan per lokasi<\/strong><\/h3>\n<p>Pastikan histori penjualan tersimpan rapi per SKU, per cabang\/gudang, dan per kanal penjualan. Pakai periode yang cukup representatif agar pola mingguan dan bulanan kebaca, termasuk perubahan saat musim tertentu.<\/p>\n<h3><strong>2. Catat promo, perubahan harga, dan event operasional<\/strong><\/h3>\n<p>Kalender promo, bundling, diskon periode, serta price change perlu masuk sebagai catatan data. Anda bisa membedakan demand normal dengan lonjakan akibat campaign, jadi forecast periode berikutnya tetap realistis.<\/p>\n<h3><strong>3. Pisahkan demand dengan penjualan yang terhambat stockout<\/strong><\/h3>\n<p>Saat stok kosong, penjualan bisa terlihat turun padahal permintaan masih ada. Simpan data stockout (tanggal, durasi, SKU, lokasi) agar baseline forecast tidak ikut turun karena angka penjualan &#8216;nol&#8217; yang sebenarnya bukan demand nol.<\/p>\n<h3><strong>4. Masukkan data lead time dan variasinya<\/strong><\/h3>\n<p>Forecast dipakai untuk menentukan kapan order dibuat, jadi lead time supplier perlu dihitung dan dipantau per pemasok. Selain rata-rata lead time, catat juga variasinya supaya safety stock dan reorder point bisa dihitung lebih masuk akal.<\/p>\n<h3><strong>5. Gunakan segmentasi SKU untuk menentukan tingkat ketelitian<\/strong><\/h3>\n<p>Terapkan analisis ABC agar item prioritas (A) diforecast dengan perhatian lebih detail, termasuk review lebih sering dan parameter yang lebih ketat. Item B dan C bisa memakai pendekatan yang lebih sederhana selama tetap ada batas minimum stok.<\/p>\n<h3><strong>6. Tetapkan metrik evaluasi dan jadwal review<\/strong><\/h3>\n<p>Tentukan metrik evaluasi forecast yang dipakai secara konsisten (mis. MAPE atau WAPE), lalu review rutin per periode. Dengan cara ini, tim bisa tahu metode mana yang paling mendekati realisasi untuk tiap kategori SKU.<\/p>\n<h3><strong>7. Uji metode per kategori SKU<\/strong><\/h3>\n<p>Metode yang cocok untuk demand stabil belum tentu cocok untuk musiman atau lumpy demand. Uji beberapa opsi per kategori, lalu pilih yang paling konsisten performanya berdasarkan hasil evaluasi.<\/p>\n<h3><strong>8. Satukan input lintas tim<\/strong><\/h3>\n<p>Libatkan sales, marketing, operasional, dan finance untuk mengisi asumsi yang berdampak langsung ke demand, seperti target campaign dan perubahan assortment. Catatan dari tim ini sebaiknya ditulis sebagai asumsi, bukan menggantikan data historis.<\/p>\n<p>Pendekatan ini mencerminkan prinsip continuous improvement untuk memastikan sistem forecasting tetap presisi dan adaptif.<\/p>\n<h2><strong>Cara Menghitung Forecast Barang<\/strong><\/h2>\n<p>Forecast barang bisa dihitung dengan beberapa cara sederhana. Metode yang dipilih biasanya mengikuti pola demand: ada yang stabil, ada yang pelan-pelan naik, ada juga yang dipengaruhi banyak faktor.<\/p>\n<p>Di bawah ini beberapa metode yang paling sering dipakai, lengkap dengan contoh hitungnya.<\/p>\n<h3><strong>1. Metode moving average<\/strong><\/h3>\n<p>Moving average menghitung rata-rata permintaan dari beberapa periode terakhir. Cara ini cocok kalau demand cenderung stabil dan fluktuasinya tidak ekstrem.<\/p>\n<table>\n<tbody>\n<tr>\n<td style=\"background-color: #990000; color: #ffffff; padding: 5px; text-align: center;\"><b>Forecast = (Jumlah permintaan dalam n periode terakhir) \/ n<\/b><\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>Contoh:<br \/>\nJika penjualan selama 3 bulan terakhir adalah 100, 120, dan 110 unit, maka:<\/p>\n<p><strong>Forecast = (100 + 120 + 110) \/ 3 = 110 unit<\/strong><\/p>\n<p>Angka 110 unit bisa dipakai sebagai estimasi kebutuhan bulan berikutnya. Metode ini praktis, tapi responsnya lebih lambat saat tren berubah cepat.<\/p>\n<h3><strong>2. Metode exponential smoothing<\/strong><\/h3>\n<p>Exponential smoothing memberi bobot lebih besar pada data terbaru. Metode ini enak dipakai kalau demand bergerak pelan, misalnya perlahan naik atau perlahan turun.<\/p>\n<table>\n<tbody>\n<tr>\n<td style=\"background-color: #990000; color: #ffffff; padding: 5px; text-align: center;\"><b>\u00a0Forecast= \u03b1 \u00d7 Permintaan terbaru + (1 \u2212 \u03b1) \u00d7 Forecast sebelumnya<\/b><\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><strong>Keterangan:<\/strong><\/p>\n<ul>\n<li>\u03b1 = smoothing constant (0 &lt; \u03b1 &lt; 1)<\/li>\n<li>Forecast = proyeksi untuk periode saat ini<\/li>\n<li>Permintaan terbaru = data permintaan aktual periode terakhir<\/li>\n<li>Forecast sebelumnya = hasil peramalan periode sebelumnya<\/li>\n<\/ul>\n<p><strong>Contoh:<\/strong><br \/>\nJika permintaan terbaru adalah 120 unit, forecast sebelumnya 115 unit, dan \u03b1 = 0.3:<\/p>\n<p><strong>Forecast = 0.3 \u00d7 120 + 0.7 \u00d7 115 = 116.5 unit<\/strong><\/p>\n<p>Exponential smoothing ideal untuk produk yang mengalami pertumbuhan atau penurunan bertahap, serta digunakan secara luas karena efisiensinya dalam pembaruan data.<\/p>\n<h3><strong>3. Metode regresi linier<\/strong><\/h3>\n<p>Regresi linier dipakai saat demand punya tren yang cukup konsisten, misalnya naik seiring waktu, atau dipengaruhi faktor tertentu seperti promosi dan harga. Metode ini membantu membaca hubungan antara variabel dan membuat proyeksi yang lebih terarah.<\/p>\n<table>\n<tbody>\n<tr>\n<td style=\"background-color: #990000; color: #ffffff; padding: 5px; text-align: center;\"><b>Y = a + bX<\/b><\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><strong>Keterangan:<\/strong><\/p>\n<ul>\n<li>Y = permintaan yang diproyeksikan<\/li>\n<li>a = permintaan awal<\/li>\n<li>b = kenaikan rata-rata per periode<\/li>\n<li>X = periode waktu<\/li>\n<\/ul>\n<p>Nilai a dan b biasanya dihitung dari data historis, dan praktiknya sering dibantu Excel. Metode ini cocok untuk tren yang relatif rapi dan tidak terlalu acak.<\/p>\n<h3><strong>4. Penambahan safety stock (stok pengaman)<\/strong><\/h3>\n<p>Setelah punya angka forecast, stok pengaman dipakai untuk berjaga kalau ada keterlambatan supplier atau lonjakan demand. Tujuannya sederhana: operasional tetap jalan meski ada deviasi.<\/p>\n<table>\n<tbody>\n<tr>\n<td style=\"background-color: #990000; color: #ffffff; padding: 5px; text-align: center;\"><b>Safety Stock = (Maksimum Lead Time \u2212 Rata-rata Lead Time) \u00d7 Rata-rata Permintaan Harian<\/b><\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><strong>Contoh:<\/strong><br \/>\nJika lead time maksimum 6 hari, rata-rata lead time 3 hari, dan permintaan harian 20 unit:<\/p>\n<p><strong>Safety Stock = (6 \u2212 3) \u00d7 20 = 60 unit<\/strong><\/p>\n<h3><strong>5. Total kebutuhan stok<\/strong><\/h3>\n<p>Total stok yang disiapkan biasanya gabungan dari forecast dan safety stock. Angka ini bisa dipakai sebagai dasar rencana pemesanan.<\/p>\n<table>\n<tbody>\n<tr>\n<td style=\"background-color: #990000; color: #ffffff; padding: 5px; text-align: center;\"><b>Total Stok = Forecast + Safety Stock<\/b><\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>Contoh:<\/p>\n<ul>\n<li>Forecast = 110 unit<\/li>\n<li>Safety Stock = 60 unit<\/li>\n<\/ul>\n<p><strong>Total Stok = 110 + 60 = 170 unit<\/strong><\/p>\n<p>Dari sini, tim bisa menentukan forecast order, seperti berapa yang perlu dipesan, dan kapan waktu pesan yang paling aman.<\/p>\n<h2><strong>Contoh Forecast Barang<\/strong><\/h2>\n<p>Agar konsep forecasting barang lebih mudah untuk Anda pahami, berikut adalah contoh perhitungan sederhana menggunakan metode moving average dan exponential smoothing. Contoh ini dapat membantu pelaku usaha kecil maupun menengah dalam mengambil keputusan pengadaan berdasarkan data historis yang tersedia.<\/p>\n<h3><strong>Contoh 1: menggunakan metode moving average<\/strong><\/h3>\n<p>Misalkan sebuah toko memiliki data penjualan produk A selama empat bulan terakhir:<\/p>\n<table>\n<tbody>\n<tr>\n<td style=\"background-color: #990000; color: #ffffff; padding: 5px; text-align: center;\"><b>Periode<\/b><\/td>\n<td style=\"background-color: #990000; color: #ffffff; padding: 5px; text-align: center;\"><b>Unit<\/b><\/td>\n<\/tr>\n<tr>\n<td><b>Januari<\/b><\/td>\n<td><strong>100<\/strong><\/td>\n<\/tr>\n<tr>\n<td><strong>Februari<\/strong><\/td>\n<td><strong>120<\/strong><\/td>\n<\/tr>\n<tr>\n<td><strong>Maret<\/strong><\/td>\n<td><strong>110<\/strong><\/td>\n<\/tr>\n<tr>\n<td><strong>April<\/strong><\/td>\n<td><strong>130<\/strong><\/td>\n<\/tr>\n<tr>\n<td style=\"background-color: #990000; color: #ffffff; padding: 5px; text-align: center;\"><strong>Total<\/strong><\/td>\n<td style=\"background-color: #990000; color: #ffffff; padding: 5px; text-align: center;\"><strong>460<\/strong><\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>&nbsp;<\/p>\n<p>Untuk menghitung forecast bulan Mei menggunakan metode <strong>3-period moving average<\/strong>, ambil rata-rata dari tiga bulan terakhir (Februari\u2013April):<\/p>\n<p><strong>Forecast Mei = (120 + 110 + 130) \/ 3 = 360 \/ 3 = 120 unit<\/strong><\/p>\n<p>Artinya, estimasi kebutuhan stok produk A untuk bulan Mei adalah 120 unit. Jika toko memiliki sistem pengadaan rutin bulanan, angka ini bisa menjadi dasar untuk pemesanan.<\/p>\n<h3><strong>Contoh 2: menggunakan metode exponential smoothing<\/strong><\/h3>\n<p>Gunakan data yang sama, namun kali ini menggunakan metode exponential smoothing.<\/p>\n<p>Asumsikan:<\/p>\n<ul>\n<li>Forecast April = 115 unit (dari periode sebelumnya)<\/li>\n<li>Permintaan April = 130 unit<\/li>\n<li>\u03b1 (alpha) = 0.3<\/li>\n<\/ul>\n<p><strong>Forecast Mei = (0.3 \u00d7 130) + (0.7 \u00d7 115) = 39 + 80.5 = 119.5 unit<\/strong><\/p>\n<p>Dengan pembulatan, forecast untuk Mei adalah 120 unit. Nilai ini sangat mirip dengan hasil moving average, namun metode exponential smoothing lebih responsif terhadap perubahan tren.<\/p>\n<h3><strong>Contoh 3: Menambahkan Safety Stock<\/strong><\/h3>\n<p>Misalnya, toko menghadapi ketidakpastian dalam waktu pengiriman barang dari supplier.<\/p>\n<ul>\n<li>Lead time maksimum: 7 hari<\/li>\n<li>Rata-rata lead time: 5 hari<\/li>\n<li>Permintaan harian rata-rata: 25 unit<\/li>\n<\/ul>\n<p>Safety Stock = (7 \u2212 5) \u00d7 25 = 50 unit<\/p>\n<h3><strong>Total kebutuhan stok<\/strong><\/h3>\n<p>Jika mengambil forecast dari metode moving average, maka hasilnya adalah 120 unit dan safety stock yang dibutuhkan sebanyak 50 unit, maka:<\/p>\n<p><strong>Total Kebutuhan Stok = 120 + 50 = 170 unit<\/strong><\/p>\n<p>Jadi, untuk memastikan ketersediaan barang dan menghindari kehabisan stok, toko disarankan untuk memiliki 170 unit produk A selama bulan Mei.<\/p>\n<p>Contoh-contoh ini menunjukkan bahwa forecasting merupakan proses terukur yang dapat membantu pengusaha dalam menyusun strategi pengadaan, mengurangi biaya penyimpanan, dan meningkatkan kepuasan pelanggan.<\/p>\n<p>Bahkan, jika terintegrasi dengan software inventory, perhitungan seperti ini bisa Anda lakukan secara otomatis dengan tingkat akurasi yang tinggi.<\/p>\n<h2><strong>Menentukan Siklus Review Forecast yang Tepat untuk Bisnis<\/strong><\/h2>\n<p>Akurasi forecast tidak ditentukan sekali saat perhitungan awal, melainkan oleh konsistensi evaluasi di setiap level operasional. Semakin cepat perusahaan mendeteksi penyimpangan antara prediksi dan realisasi, semakin kecil risiko stockout maupun overstock yang merugikan.<\/p>\n<p>Karena itu, setiap bisnis perlu menetapkan ritme review yang jelas mulai dari pemantauan harian hingga kalibrasi metode per kuartal. Berikut gambaran siklus review forecast yang umum diterapkan perusahaan dengan manajemen stok yang matang:<\/p>\n<div style=\"width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; margin: 30px 0; padding: 10px 0;\">\n<div style=\"min-width: 780px; background-color: #f4f1ec; border-radius: 12px; padding: 30px 25px; font-family: Arial,sans-serif;\">\n<h3 style=\"text-align: center; color: #3d3d3d; font-size: 20px; margin: 0 0 8px 0; font-weight: bold;\">Timeline Siklus Review Forecast<\/h3>\n<p style=\"text-align: center; color: #6b6b6b; font-size: 14px; margin: 0 0 30px 0;\">Ritme evaluasi agar prediksi stok tetap akurat di setiap level operasional<\/p>\n<div style=\"position: relative; padding: 20px 0;\">\n<div style=\"position: absolute; top: 55px; left: 5%; right: 5%; height: 4px; background: linear-gradient(90deg,#8a7f6e 0%,#6b6055 100%); border-radius: 2px; z-index: 1;\"><\/div>\n<div style=\"display: flex; justify-content: space-between; align-items: flex-start; position: relative; z-index: 2;\">\n<div style=\"flex: 1; text-align: center; padding: 0 10px;\">\n<div style=\"width: 70px; height: 70px; background-color: #8a7f6e; color: #ffffff; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 15px auto; font-size: 22px; font-weight: bold; border: 4px solid #f4f1ec; box-shadow: 0 2px 6px rgba(0,0,0,0.15);\">01<\/div>\n<div style=\"background-color: #ffffff; border-radius: 8px; padding: 15px 12px; box-shadow: 0 2px 4px rgba(0,0,0,0.06);\">\n<h4 style=\"color: #3d3d3d; font-size: 15px; margin: 0 0 6px 0; font-weight: bold;\">Harian<\/h4>\n<p style=\"color: #555555; font-size: 13px; line-height: 1.5; margin: 0;\">Monitoring stockout, lonjakan penjualan, dan error sistem real-time.<\/p>\n<\/div>\n<\/div>\n<div style=\"flex: 1; text-align: center; padding: 0 10px;\">\n<div style=\"width: 70px; height: 70px; background-color: #7a7060; color: #ffffff; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 15px auto; font-size: 22px; font-weight: bold; border: 4px solid #f4f1ec; box-shadow: 0 2px 6px rgba(0,0,0,0.15);\">02<\/div>\n<div style=\"background-color: #ffffff; border-radius: 8px; padding: 15px 12px; box-shadow: 0 2px 4px rgba(0,0,0,0.06);\">\n<h4 style=\"color: #3d3d3d; font-size: 15px; margin: 0 0 6px 0; font-weight: bold;\">Mingguan<\/h4>\n<p style=\"color: #555555; font-size: 13px; line-height: 1.5; margin: 0;\">Evaluasi akurasi forecast vs aktual, penyesuaian pemesanan ulang.<\/p>\n<\/div>\n<\/div>\n<div style=\"flex: 1; text-align: center; padding: 0 10px;\">\n<div style=\"width: 70px; height: 70px; background-color: #6b6055; color: #ffffff; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 15px auto; font-size: 22px; font-weight: bold; border: 4px solid #f4f1ec; box-shadow: 0 2px 6px rgba(0,0,0,0.15);\">03<\/div>\n<div style=\"background-color: #ffffff; border-radius: 8px; padding: 15px 12px; box-shadow: 0 2px 4px rgba(0,0,0,0.06);\">\n<h4 style=\"color: #3d3d3d; font-size: 15px; margin: 0 0 6px 0; font-weight: bold;\">Bulanan<\/h4>\n<p style=\"color: #555555; font-size: 13px; line-height: 1.5; margin: 0;\">Review MAPE\/WAPE per SKU, identifikasi produk slow moving.<\/p>\n<\/div>\n<\/div>\n<div style=\"flex: 1; text-align: center; padding: 0 10px;\">\n<div style=\"width: 70px; height: 70px; background-color: #5c5248; color: #ffffff; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 15px auto; font-size: 22px; font-weight: bold; border: 4px solid #f4f1ec; box-shadow: 0 2px 6px rgba(0,0,0,0.15);\">04<\/div>\n<div style=\"background-color: #ffffff; border-radius: 8px; padding: 15px 12px; box-shadow: 0 2px 4px rgba(0,0,0,0.06);\">\n<h4 style=\"color: #3d3d3d; font-size: 15px; margin: 0 0 6px 0; font-weight: bold;\">Kuartalan<\/h4>\n<p style=\"color: #555555; font-size: 13px; line-height: 1.5; margin: 0;\">Kalibrasi metode forecast, assortment planning, strategi musiman.<\/p>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<p style=\"text-align: center; color: #8a7f6e; font-size: 12px; margin: 20px 0 0 0; font-style: italic;\">Konsistensi review mingguan + bulanan paling berdampak terhadap akurasi jangka panjang.<\/p>\n<\/div>\n<\/div>\n<h2><strong>Kesimpulan<\/strong><\/h2>\n<p>Forecast barang membantu bisnis menentukan kebutuhan stok berdasarkan pola permintaan, lead time, dan momen musiman yang relevan. Dengan perencanaan yang rapi, tim bisa menjaga ketersediaan barang lebih konsisten tanpa menumpuk persediaan yang tidak perlu.<\/p>\n<p>Akurasi forecast juga berpengaruh langsung ke biaya penyimpanan, ketepatan pengadaan, sampai <a href=\"https:\/\/www.hashmicro.com\/id\/blog\/profit-loss-forecast\/\">keuntungan dan kerugian perusahaan<\/a>. Karena itu, penting untuk memakai data yang bersih, memilih metode yang sesuai pola permintaan, lalu mengevaluasi hasilnya secara rutin.<\/p>\n<p>Agar proses forecasting berjalan lebih presisi, diskusikan kebutuhan bisnis Anda melalui <a href=\"https:\/\/www.hashmicro.com\/id\/tour-produk-gratis\/\">konsultasi gratis bersama tim ahli<\/a>. Dapatkan rekomendasi software inventory yang sesuai skala operasional dan kompleksitas SKU perusahaan, lengkap dengan demo produk.<\/p>\n<a href=\"https:\/\/www.hashmicro.com\/id\/inventaris?medium=moneysite-banner\" target=\"_blank\"><img decoding=\"async\" loading=\"lazy\" src=\"https:\/\/www.hashmicro.com\/id\/blog\/wp-content\/uploads\/2026\/01\/inventory-definitive.webp\" data-desktop-src=\"https:\/\/www.hashmicro.com\/id\/blog\/wp-content\/uploads\/2026\/01\/inventory-definitive.webp\" data-mobile-src=\"https:\/\/www.hashmicro.com\/id\/blog\/wp-content\/uploads\/2026\/01\/inventory-definitive-m.webp\" alt=\"Inventory_Definisi\" class=\"responsive-image-banner\"><\/a>\r\n\r\n<script>\r\n    \/\/ check which image to use based on screensize\r\n    document.addEventListener(\"DOMContentLoaded\", function() {\r\n        function updateImageSource() {\r\n            var images = document.querySelectorAll('.responsive-image-banner');\r\n            var screenWidth = window.innerWidth;\r\n\r\n            images.forEach(function(img) {\r\n                var mobileSrc = img.getAttribute('data-mobile-src');\r\n                var desktopSrc = img.getAttribute('data-desktop-src');\r\n\r\n                if (screenWidth < 576 && mobileSrc) {\r\n                    img.setAttribute('src', mobileSrc);\r\n                } else {\r\n                    img.setAttribute('src', desktopSrc);\r\n                }\r\n            });\r\n        }\r\n\r\n        \/\/ Initial check\r\n        updateImageSource();\r\n\r\n        \/\/ Update on resize\r\n        window.addEventListener('resize', updateImageSource);\r\n    });\r\n<\/script>\n<h2 style=\"margin: 24px 0 14px; font-size: 22px; line-height: 1.25;\"><strong>Pertanyaan Seputar Forecast Barang<\/strong><\/h2>\n<div style=\"border: 1px solid #f0d6d6; background: #fff7f7; border-radius: 12px; padding: 14px;\">\n<div style=\"border: 1px solid #f0d6d6; background: #ffffff; border-radius: 10px; padding: 14px; margin: 0 0 12px;\">\n<h3 style=\"margin: 0 0 10px; font-size: 16px; line-height: 1.35;\"><strong>Apa saja hal yang harus dipertimbangkan saat melakukan forecasting barang?<\/strong><\/h3>\n<details>\n<summary style=\"cursor: pointer; list-style: none; outline: none;\"><span style=\"display: inline-flex; align-items: center; gap: 10px; font-weight: bold; color: #8a1f1f;\"><br \/>\n<span style=\"display: inline-block; width: 22px; height: 22px; border-radius: 999px; background: #8a1f1f; color: #fff; text-align: center; line-height: 22px; font-size: 14px;\">+<\/span><br \/>\nLihat jawaban<br \/>\n<\/span><\/summary>\n<div style=\"margin-top: 10px; color: #222; line-height: 1.65;\">Saat forecasting barang, penting untuk mempertimbangkan data penjualan sebelumnya, tren pasar, pola musiman, kondisi ekonomi, dan kapasitas produksi. Selain itu, perhatikan juga faktor persaingan dan keandalan rantai pasokan. Pemilihan metode forecasting yang tepat juga sangat menentukan akurasi prediksi.<\/div>\n<\/details>\n<\/div>\n<div style=\"border: 1px solid #f0d6d6; background: #ffffff; border-radius: 10px; padding: 14px; margin: 0 0 12px;\">\n<h3 style=\"margin: 0 0 10px; font-size: 16px; line-height: 1.35;\"><strong>Mengapa forecast barang penting dalam dunia perdagangan?<\/strong><\/h3>\n<details>\n<summary style=\"cursor: pointer; list-style: none; outline: none;\"><span style=\"display: inline-flex; align-items: center; gap: 10px; font-weight: bold; color: #8a1f1f;\"><br \/>\n<span style=\"display: inline-block; width: 22px; height: 22px; border-radius: 999px; background: #8a1f1f; color: #fff; text-align: center; line-height: 22px; font-size: 14px;\">+<\/span><br \/>\nLihat jawaban<br \/>\n<\/span><\/summary>\n<div style=\"margin-top: 10px; color: #222; line-height: 1.65;\">Forecast barang membantu bisnis mengelola stok dengan tepat dan mencegah kelebihan atau kekurangan barang. Dengan penerapan forecast yang akurat, perusahaan dapat merencanakan produksi dan pengadaan secara efisien, menjaga kepuasan pelanggan, serta meningkatkan profitabilitas dan daya saing di pasar.<\/div>\n<\/details>\n<\/div>\n<div style=\"border: 1px solid #f0d6d6; background: #ffffff; border-radius: 10px; padding: 14px; margin: 0;\">\n<h3 style=\"margin: 0 0 10px; font-size: 16px; line-height: 1.35;\"><strong>Apa risiko yang terjadi jika forecast barang tidak akurat?<\/strong><\/h3>\n<details>\n<summary style=\"cursor: pointer; list-style: none; outline: none;\"><span style=\"display: inline-flex; align-items: center; gap: 10px; font-weight: bold; color: #8a1f1f;\"><br \/>\n<span style=\"display: inline-block; width: 22px; height: 22px; border-radius: 999px; background: #8a1f1f; color: #fff; text-align: center; line-height: 22px; font-size: 14px;\">+<\/span><br \/>\nLihat jawaban<br \/>\n<\/span><\/summary>\n<div style=\"margin-top: 10px; color: #222; line-height: 1.65;\">Forecast yang tidak akurat bisa menyebabkan overstock yang mengikat modal dan meningkatkan biaya penyimpanan, serta stockout yang membuat pelanggan kecewa dan kehilangan penjualan. Selain itu, perencanaan produksi dan operasi menjadi tidak optimal, sehingga berpotensi menimbulkan kerugian dan gangguan bisnis.<\/div>\n<\/details>\n<\/div>\n<\/div>\n<p><script type=\"application\/ld+json\">\n{\n  \"@context\": \"https:\/\/schema.org\",\n  \"@type\": \"FAQPage\",\n  \"mainEntity\": [\n    {\n      \"@type\": \"Question\",\n      \"name\": \"Apa saja hal yang harus dipertimbangkan saat melakukan forecasting barang?\",\n      \"acceptedAnswer\": {\n        \"@type\": \"Answer\",\n        \"text\": \"Saat forecasting barang, penting untuk mempertimbangkan data penjualan sebelumnya, tren pasar, pola musiman, kondisi ekonomi, dan kapasitas produksi. Selain itu, perhatikan juga faktor persaingan dan keandalan rantai pasokan. Pemilihan metode forecasting yang tepat juga sangat menentukan akurasi prediksi.\"\n      }\n    },\n    {\n      \"@type\": \"Question\",\n      \"name\": \"Mengapa forecast barang penting dalam dunia perdagangan?\",\n      \"acceptedAnswer\": {\n        \"@type\": \"Answer\",\n        \"text\": \"Forecast barang membantu bisnis mengelola stok dengan tepat dan mencegah kelebihan atau kekurangan barang. Dengan penerapan forecast yang akurat, perusahaan dapat merencanakan produksi dan pengadaan secara efisien, menjaga kepuasan pelanggan, serta meningkatkan profitabilitas dan daya saing di pasar.\"\n      }\n    },\n    {\n      \"@type\": \"Question\",\n      \"name\": \"Apa risiko yang terjadi jika forecast barang tidak akurat?\",\n      \"acceptedAnswer\": {\n        \"@type\": \"Answer\",\n        \"text\": \"Forecast yang tidak akurat bisa menyebabkan overstock yang mengikat modal dan meningkatkan biaya penyimpanan, serta stockout yang membuat pelanggan kecewa dan kehilangan penjualan. Selain itu, perencanaan produksi dan operasi menjadi tidak optimal, sehingga berpotensi menimbulkan kerugian dan gangguan bisnis.\"\n      }\n    }\n  ]\n}\n<\/script><\/p>\n","protected":false},"excerpt":{"rendered":"<p>McKinsey mencatat bahwa AI dapat menurunkan level inventory sebesar 20\u201330% melalui peningkatan demand forecasting barang, seperti dynamic segmentation dan machine learning, serta optimasi inventory dengan tools yang lebih efisien. Angka tersebut menunjukkan bahwa kualitas prediksi dan cara bisnis menerjemahkannya ke keputusan stok memang berdampak langsung ke kebutuhan persediaan. Bagian berikut merangkum konsep forecast barang, pilihan [&hellip;]<\/p>\n","protected":false},"author":160,"featured_media":162819,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[88],"tags":[],"class_list":{"0":"post-162797","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"has-post-thumbnail","7":"category-inventory"},"acf":{"post_reviewer":""},"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v25.1 (Yoast SEO v27.5) - https:\/\/yoast.com\/product\/yoast-seo-premium-wordpress\/ -->\n<title>Forecast Barang: Jenis dan Peran Strategisnya dalam Bisnis<\/title>\n<meta name=\"description\" content=\"Forecast barang adalah kunci memperkirakan kebutuhan stok. Simak penjelasan lengkapnya untuk hindari kelebihan atau kekurangan persediaan!\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.hashmicro.com\/id\/blog\/forecast-barang\/\" \/>\n<meta property=\"og:locale\" content=\"id_ID\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Forecast Barang: Jenis dan Peran Strategisnya dalam Bisnis\" \/>\n<meta property=\"og:description\" content=\"Forecast barang adalah kunci memperkirakan kebutuhan stok. Simak penjelasan lengkapnya untuk hindari kelebihan atau kekurangan persediaan!\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.hashmicro.com\/id\/blog\/forecast-barang\/\" \/>\n<meta property=\"og:site_name\" content=\"HashMicro Indonesia\" \/>\n<meta property=\"article:publisher\" content=\"https:\/\/www.facebook.com\/hashmicro\" \/>\n<meta property=\"article:published_time\" content=\"2025-06-02T03:58:19+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2026-04-24T07:51:56+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/www.hashmicro.com\/id\/blog\/wp-content\/uploads\/2025\/05\/Forecast-Barang-HashMicro.webp\" \/>\n\t<meta property=\"og:image:width\" content=\"1200\" \/>\n\t<meta property=\"og:image:height\" content=\"675\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/webp\" \/>\n<meta name=\"author\" content=\"Jessica Wijaya\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:creator\" content=\"@hashmicro\" \/>\n<meta name=\"twitter:site\" content=\"@hashmicro\" \/>\n<meta name=\"twitter:label1\" content=\"Ditulis oleh\" \/>\n\t<meta name=\"twitter:data1\" content=\"Jessica Wijaya\" \/>\n\t<meta name=\"twitter:label2\" content=\"Estimasi waktu membaca\" \/>\n\t<meta name=\"twitter:data2\" content=\"14 menit\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/forecast-barang\\\/#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/forecast-barang\\\/\"},\"author\":{\"name\":\"Jessica Wijaya\",\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/#\\\/schema\\\/person\\\/4d83ca1a7056c0a44f813f8721086980\"},\"headline\":\"Forecast Barang: Jenis dan Peran Strategisnya dalam Bisnis\",\"datePublished\":\"2025-06-02T03:58:19+00:00\",\"dateModified\":\"2026-04-24T07:51:56+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/forecast-barang\\\/\"},\"wordCount\":2397,\"publisher\":{\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/#organization\"},\"image\":{\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/forecast-barang\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/wp-content\\\/uploads\\\/2025\\\/05\\\/Forecast-Barang-HashMicro.webp\",\"articleSection\":[\"Inventory\"],\"inLanguage\":\"id\"},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/forecast-barang\\\/\",\"url\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/forecast-barang\\\/\",\"name\":\"Forecast Barang: Jenis dan Peran Strategisnya dalam Bisnis\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/forecast-barang\\\/#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/forecast-barang\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/wp-content\\\/uploads\\\/2025\\\/05\\\/Forecast-Barang-HashMicro.webp\",\"datePublished\":\"2025-06-02T03:58:19+00:00\",\"dateModified\":\"2026-04-24T07:51:56+00:00\",\"description\":\"Forecast barang adalah kunci memperkirakan kebutuhan stok. Simak penjelasan lengkapnya untuk hindari kelebihan atau kekurangan persediaan!\",\"breadcrumb\":{\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/forecast-barang\\\/#breadcrumb\"},\"inLanguage\":\"id\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/forecast-barang\\\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"id\",\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/forecast-barang\\\/#primaryimage\",\"url\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/wp-content\\\/uploads\\\/2025\\\/05\\\/Forecast-Barang-HashMicro.webp\",\"contentUrl\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/wp-content\\\/uploads\\\/2025\\\/05\\\/Forecast-Barang-HashMicro.webp\",\"width\":1200,\"height\":675,\"caption\":\"forecast barang\"},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/forecast-barang\\\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Forecast Barang: Jenis dan Peran Strategisnya dalam Bisnis\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/#website\",\"url\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/\",\"name\":\"HashMicro Indonesia\",\"description\":\"Blog Software Manajemen Bisnis Indonesia #1\",\"publisher\":{\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"id\"},{\"@type\":\"Organization\",\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/#organization\",\"name\":\"HashMicro Indonesia\",\"url\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"id\",\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\",\"url\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/wp-content\\\/uploads\\\/2023\\\/11\\\/hashmicro-logo-blog.webp\",\"contentUrl\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/wp-content\\\/uploads\\\/2023\\\/11\\\/hashmicro-logo-blog.webp\",\"width\":924,\"height\":121,\"caption\":\"HashMicro Indonesia\"},\"image\":{\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\"},\"sameAs\":[\"https:\\\/\\\/www.facebook.com\\\/hashmicro\",\"https:\\\/\\\/x.com\\\/hashmicro\",\"https:\\\/\\\/www.linkedin.com\\\/company\\\/hashmicro\"]},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/#\\\/schema\\\/person\\\/4d83ca1a7056c0a44f813f8721086980\",\"name\":\"Jessica Wijaya\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"id\",\"@id\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/wp-content\\\/uploads\\\/2025\\\/10\\\/Jessica-Wijaya-1-1-96x96.webp\",\"url\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/wp-content\\\/uploads\\\/2025\\\/10\\\/Jessica-Wijaya-1-1-96x96.webp\",\"contentUrl\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/wp-content\\\/uploads\\\/2025\\\/10\\\/Jessica-Wijaya-1-1-96x96.webp\",\"caption\":\"Jessica Wijaya\"},\"description\":\"Selama lebih dari 5 tahun sebagai Senior Content Writer, Jessica telah menulis topik yang mengulas tentang bidang inventory dan warehouse management. Keahliannya mencakup penulisan artikel manajemen stok dan persediaan, perencanaan kebutuhan, multi-warehouse management, dan integrasi sistem digital untuk pengelolaan barang.\",\"sameAs\":[\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/\"],\"gender\":\"Perempuan\",\"knowsAbout\":[\"Inventory\",\"inventory management\",\"manajemen inventaris\"],\"knowsLanguage\":[\"Inggris\",\"Indonesia\"],\"jobTitle\":\"Senior Content Writer\",\"url\":\"https:\\\/\\\/www.hashmicro.com\\\/id\\\/blog\\\/author\\\/jessicawijaya\\\/\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"Forecast Barang: Jenis dan Peran Strategisnya dalam Bisnis","description":"Forecast barang adalah kunci memperkirakan kebutuhan stok. Simak penjelasan lengkapnya untuk hindari kelebihan atau kekurangan persediaan!","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.hashmicro.com\/id\/blog\/forecast-barang\/","og_locale":"id_ID","og_type":"article","og_title":"Forecast Barang: Jenis dan Peran Strategisnya dalam Bisnis","og_description":"Forecast barang adalah kunci memperkirakan kebutuhan stok. Simak penjelasan lengkapnya untuk hindari kelebihan atau kekurangan persediaan!","og_url":"https:\/\/www.hashmicro.com\/id\/blog\/forecast-barang\/","og_site_name":"HashMicro Indonesia","article_publisher":"https:\/\/www.facebook.com\/hashmicro","article_published_time":"2025-06-02T03:58:19+00:00","article_modified_time":"2026-04-24T07:51:56+00:00","og_image":[{"width":1200,"height":675,"url":"https:\/\/www.hashmicro.com\/id\/blog\/wp-content\/uploads\/2025\/05\/Forecast-Barang-HashMicro.webp","type":"image\/webp"}],"author":"Jessica Wijaya","twitter_card":"summary_large_image","twitter_creator":"@hashmicro","twitter_site":"@hashmicro","twitter_misc":{"Ditulis oleh":"Jessica Wijaya","Estimasi waktu membaca":"14 menit"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.hashmicro.com\/id\/blog\/forecast-barang\/#article","isPartOf":{"@id":"https:\/\/www.hashmicro.com\/id\/blog\/forecast-barang\/"},"author":{"name":"Jessica Wijaya","@id":"https:\/\/www.hashmicro.com\/id\/blog\/#\/schema\/person\/4d83ca1a7056c0a44f813f8721086980"},"headline":"Forecast Barang: Jenis dan Peran Strategisnya dalam Bisnis","datePublished":"2025-06-02T03:58:19+00:00","dateModified":"2026-04-24T07:51:56+00:00","mainEntityOfPage":{"@id":"https:\/\/www.hashmicro.com\/id\/blog\/forecast-barang\/"},"wordCount":2397,"publisher":{"@id":"https:\/\/www.hashmicro.com\/id\/blog\/#organization"},"image":{"@id":"https:\/\/www.hashmicro.com\/id\/blog\/forecast-barang\/#primaryimage"},"thumbnailUrl":"https:\/\/www.hashmicro.com\/id\/blog\/wp-content\/uploads\/2025\/05\/Forecast-Barang-HashMicro.webp","articleSection":["Inventory"],"inLanguage":"id"},{"@type":"WebPage","@id":"https:\/\/www.hashmicro.com\/id\/blog\/forecast-barang\/","url":"https:\/\/www.hashmicro.com\/id\/blog\/forecast-barang\/","name":"Forecast Barang: Jenis dan Peran Strategisnya dalam Bisnis","isPartOf":{"@id":"https:\/\/www.hashmicro.com\/id\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www.hashmicro.com\/id\/blog\/forecast-barang\/#primaryimage"},"image":{"@id":"https:\/\/www.hashmicro.com\/id\/blog\/forecast-barang\/#primaryimage"},"thumbnailUrl":"https:\/\/www.hashmicro.com\/id\/blog\/wp-content\/uploads\/2025\/05\/Forecast-Barang-HashMicro.webp","datePublished":"2025-06-02T03:58:19+00:00","dateModified":"2026-04-24T07:51:56+00:00","description":"Forecast barang adalah kunci memperkirakan kebutuhan stok. Simak penjelasan lengkapnya untuk hindari kelebihan atau kekurangan persediaan!","breadcrumb":{"@id":"https:\/\/www.hashmicro.com\/id\/blog\/forecast-barang\/#breadcrumb"},"inLanguage":"id","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.hashmicro.com\/id\/blog\/forecast-barang\/"]}]},{"@type":"ImageObject","inLanguage":"id","@id":"https:\/\/www.hashmicro.com\/id\/blog\/forecast-barang\/#primaryimage","url":"https:\/\/www.hashmicro.com\/id\/blog\/wp-content\/uploads\/2025\/05\/Forecast-Barang-HashMicro.webp","contentUrl":"https:\/\/www.hashmicro.com\/id\/blog\/wp-content\/uploads\/2025\/05\/Forecast-Barang-HashMicro.webp","width":1200,"height":675,"caption":"forecast barang"},{"@type":"BreadcrumbList","@id":"https:\/\/www.hashmicro.com\/id\/blog\/forecast-barang\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/www.hashmicro.com\/id\/blog\/"},{"@type":"ListItem","position":2,"name":"Forecast Barang: Jenis dan Peran Strategisnya dalam Bisnis"}]},{"@type":"WebSite","@id":"https:\/\/www.hashmicro.com\/id\/blog\/#website","url":"https:\/\/www.hashmicro.com\/id\/blog\/","name":"HashMicro Indonesia","description":"Blog Software Manajemen Bisnis Indonesia #1","publisher":{"@id":"https:\/\/www.hashmicro.com\/id\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.hashmicro.com\/id\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"id"},{"@type":"Organization","@id":"https:\/\/www.hashmicro.com\/id\/blog\/#organization","name":"HashMicro Indonesia","url":"https:\/\/www.hashmicro.com\/id\/blog\/","logo":{"@type":"ImageObject","inLanguage":"id","@id":"https:\/\/www.hashmicro.com\/id\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/www.hashmicro.com\/id\/blog\/wp-content\/uploads\/2023\/11\/hashmicro-logo-blog.webp","contentUrl":"https:\/\/www.hashmicro.com\/id\/blog\/wp-content\/uploads\/2023\/11\/hashmicro-logo-blog.webp","width":924,"height":121,"caption":"HashMicro Indonesia"},"image":{"@id":"https:\/\/www.hashmicro.com\/id\/blog\/#\/schema\/logo\/image\/"},"sameAs":["https:\/\/www.facebook.com\/hashmicro","https:\/\/x.com\/hashmicro","https:\/\/www.linkedin.com\/company\/hashmicro"]},{"@type":"Person","@id":"https:\/\/www.hashmicro.com\/id\/blog\/#\/schema\/person\/4d83ca1a7056c0a44f813f8721086980","name":"Jessica Wijaya","image":{"@type":"ImageObject","inLanguage":"id","@id":"https:\/\/www.hashmicro.com\/id\/blog\/wp-content\/uploads\/2025\/10\/Jessica-Wijaya-1-1-96x96.webp","url":"https:\/\/www.hashmicro.com\/id\/blog\/wp-content\/uploads\/2025\/10\/Jessica-Wijaya-1-1-96x96.webp","contentUrl":"https:\/\/www.hashmicro.com\/id\/blog\/wp-content\/uploads\/2025\/10\/Jessica-Wijaya-1-1-96x96.webp","caption":"Jessica Wijaya"},"description":"Selama lebih dari 5 tahun sebagai Senior Content Writer, Jessica telah menulis topik yang mengulas tentang bidang inventory dan warehouse management. Keahliannya mencakup penulisan artikel manajemen stok dan persediaan, perencanaan kebutuhan, multi-warehouse management, dan integrasi sistem digital untuk pengelolaan barang.","sameAs":["https:\/\/www.hashmicro.com\/id\/"],"gender":"Perempuan","knowsAbout":["Inventory","inventory management","manajemen inventaris"],"knowsLanguage":["Inggris","Indonesia"],"jobTitle":"Senior Content Writer","url":"https:\/\/www.hashmicro.com\/id\/blog\/author\/jessicawijaya\/"}]}},"focus_keyword":"forecast barang","order_j":"","_links":{"self":[{"href":"https:\/\/www.hashmicro.com\/id\/blog\/wp-json\/wp\/v2\/posts\/162797","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.hashmicro.com\/id\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.hashmicro.com\/id\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.hashmicro.com\/id\/blog\/wp-json\/wp\/v2\/users\/160"}],"replies":[{"embeddable":true,"href":"https:\/\/www.hashmicro.com\/id\/blog\/wp-json\/wp\/v2\/comments?post=162797"}],"version-history":[{"count":15,"href":"https:\/\/www.hashmicro.com\/id\/blog\/wp-json\/wp\/v2\/posts\/162797\/revisions"}],"predecessor-version":[{"id":192845,"href":"https:\/\/www.hashmicro.com\/id\/blog\/wp-json\/wp\/v2\/posts\/162797\/revisions\/192845"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.hashmicro.com\/id\/blog\/wp-json\/wp\/v2\/media\/162819"}],"wp:attachment":[{"href":"https:\/\/www.hashmicro.com\/id\/blog\/wp-json\/wp\/v2\/media?parent=162797"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.hashmicro.com\/id\/blog\/wp-json\/wp\/v2\/categories?post=162797"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.hashmicro.com\/id\/blog\/wp-json\/wp\/v2\/tags?post=162797"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}