Langsung ke konten utama

Documentation Index

Fetch the complete documentation index at: https://docs2.openclaw.ai/llms.txt

Use this file to discover all available pages before exploring further.

Draf progres membuat giliran agen yang berjalan lama terasa hidup di chat tanpa mengubah percakapan menjadi tumpukan balasan status sementara. Saat draf progres diaktifkan, OpenClaw membuat satu pesan pekerjaan-sedang-berjalan yang terlihat hanya setelah giliran tersebut terbukti melakukan pekerjaan nyata, memperbaruinya saat agen membaca, merencanakan, memanggil alat, atau menunggu persetujuan, lalu mengubah draf itu menjadi jawaban akhir saat saluran dapat melakukannya dengan aman.
Shelling...
📖 from docs/concepts/progress-drafts.md
🔎 Web Search: for "discord edit message"
🛠️ Bash: run tests
Gunakan draf progres saat Anda menginginkan satu pesan status yang rapi selama pekerjaan yang banyak memakai alat dan jawaban akhir saat giliran selesai.

Mulai cepat

Aktifkan draf progres per saluran dengan streaming.mode: "progress":
{
  channels: {
    discord: {
      streaming: {
        mode: "progress",
      },
    },
  },
}
Itu biasanya sudah cukup. OpenClaw akan memilih label satu kata otomatis, menunggu hingga pekerjaan berlangsung setidaknya lima detik atau memancarkan peristiwa kerja kedua, menambahkan baris progres ringkas saat pekerjaan yang berguna berlangsung, dan menekan obrolan progres mandiri duplikat untuk giliran tersebut.

Yang dilihat pengguna

Draf progres memiliki dua bagian:
BagianTujuan
LabelBaris awal/status singkat seperti Thinking... atau Shelling....
Baris progresPembaruan proses yang ringkas menggunakan ikon alat dan pemformat detail yang sama seperti keluaran verbose.
Label muncul setelah agen memulai pekerjaan bermakna dan tetap sibuk selama lima detik atau memancarkan peristiwa kerja kedua. Label merupakan bagian dari daftar baris progres bergulir, sehingga status awal akan tergulir keluar setelah cukup banyak pekerjaan konkret muncul. Balasan teks saja tidak menampilkan draf progres. Baris progres ditambahkan hanya saat agen memancarkan pembaruan kerja yang berguna, misalnya 🛠️ Bash: run tests, 🔎 Web Search: for "discord edit message", atau ✍️ Write: to /tmp/file. Secara default, baris tersebut menggunakan mode penjelasan ringkas yang sama seperti /verbose; atur agents.defaults.toolProgressDetail: "raw" saat debugging dan Anda juga ingin perintah/detail mentah ditambahkan. Jawaban akhir menggantikan draf jika memungkinkan; jika tidak, OpenClaw mengirim jawaban akhir seperti biasa dan membersihkan atau berhenti memperbarui draf sesuai transport saluran.

Pilih mode

channels.<channel>.streaming.mode mengontrol perilaku sedang-berjalan yang terlihat:
ModePaling cocok untukYang muncul di chat
offSaluran yang tenangHanya jawaban akhir.
partialMelihat teks jawaban munculSatu draf diedit dengan teks jawaban terbaru.
blockPotongan pratinjau jawaban lebih besarSatu pratinjau diperbarui atau ditambahkan dalam potongan lebih besar.
progressGiliran yang banyak memakai alat atau berjalan lamaSatu draf status, lalu jawaban akhir.
Pilih progress saat pengguna lebih peduli dengan “apa yang sedang terjadi” daripada melihat teks jawaban mengalir token demi token. Pilih partial saat jawaban itu sendiri adalah sinyal progres. Pilih block saat Anda menginginkan pembaruan pratinjau draf dalam potongan teks yang lebih besar. Di Discord dan Telegram, streaming.mode: "block" tetap berupa streaming pratinjau, bukan pengiriman blok normal. Gunakan streaming.block.enabled atau blockStreaming lama saat Anda menginginkan balasan blok normal.

Konfigurasikan label

Label progres berada di bawah channels.<channel>.streaming.progress. Label default adalah auto, yang memilih dari kumpulan label bawaan OpenClaw satu-kata-dengan-elipsis:
Thinking...
Shelling...
Scuttling...
Clawing...
Pinching...
Molting...
Bubbling...
Tiding...
Reefing...
Cracking...
Sifting...
Brining...
Nautiling...
Krilling...
Barnacling...
Lobstering...
Tidepooling...
Pearling...
Snapping...
Surfacing...
Gunakan label tetap:
{
  channels: {
    discord: {
      streaming: {
        mode: "progress",
        progress: {
          label: "Investigating",
        },
      },
    },
  },
}
Gunakan kumpulan label otomatis Anda sendiri:
{
  channels: {
    discord: {
      streaming: {
        mode: "progress",
        progress: {
          label: "auto",
          labels: ["Checking", "Reading", "Testing", "Finishing"],
        },
      },
    },
  },
}
Sembunyikan label dan tampilkan hanya baris progres:
{
  channels: {
    discord: {
      streaming: {
        mode: "progress",
        progress: {
          label: false,
        },
      },
    },
  },
}

Kontrol baris progres

Baris progres diaktifkan secara default dalam mode progres. Baris tersebut berasal dari peristiwa proses nyata: awal alat, pembaruan item, rencana tugas, persetujuan, keluaran perintah, ringkasan patch, dan aktivitas agen serupa. OpenClaw menggunakan pemformat yang sama untuk draf progres dan /verbose:
{
  agents: {
    defaults: {
      toolProgressDetail: "explain", // explain | raw
    },
  },
}
"explain" adalah default dan menjaga draf tetap stabil dengan label ringkas seperti 🛠️ check JS syntax for /tmp/app.js. "raw" menambahkan perintah/detail yang mendasarinya saat tersedia, yang berguna saat debugging tetapi lebih ramai di chat. Misalnya, perintah yang sama muncul berbeda tergantung mode detail:
ModeBaris progres
explain🛠️ check JS syntax for /tmp/app.js
raw🛠️ check JS syntax for /tmp/app.js, node --check /tmp/app.js
Batasi jumlah baris yang tetap terlihat:
{
  channels: {
    discord: {
      streaming: {
        mode: "progress",
        progress: {
          maxLines: 4,
        },
      },
    },
  },
}
Baris progres dipadatkan secara otomatis untuk mengurangi perubahan tata letak gelembung chat saat draf diedit. OpenClaw memotong baris progres yang panjang secara default agar pengeditan draf berulang tidak membungkus secara berbeda di setiap pembaruan. Awalan tetap mudah dibaca, dan detail panjang seperti path atau perintah mentah dipendekkan dengan elipsis. Slack dapat merender baris progres sebagai field Block Kit terstruktur alih-alih satu isi teks:
{
  channels: {
    slack: {
      streaming: {
        mode: "progress",
        progress: {
          render: "rich",
        },
      },
    },
  },
}
Rendering kaya mempertahankan fallback teks biasa yang sama sehingga saluran dan klien yang tidak mendukung bentuk yang lebih kaya tetap dapat menampilkan teks progres ringkas. Pertahankan satu draf progres tetapi sembunyikan baris alat dan tugas:
{
  channels: {
    discord: {
      streaming: {
        mode: "progress",
        progress: {
          toolProgress: false,
        },
      },
    },
  },
}
Dengan toolProgress: false, OpenClaw tetap menekan pesan progres-alat mandiri lama untuk giliran tersebut. Saluran tetap tenang secara visual hingga jawaban akhir, kecuali label jika dikonfigurasi.

Perilaku saluran

Setiap saluran menggunakan transport paling bersih yang didukungnya:
SaluranTransport progresCatatan
DiscordKirim satu pesan, lalu edit pesan itu.Teks akhir diedit di tempat saat muat dalam satu pesan pratinjau aman.
MatrixKirim satu peristiwa, lalu edit peristiwa itu.Konfigurasi streaming tingkat akun mengontrol draf tingkat akun.
Microsoft TeamsStream Teams native di chat personal.streaming.mode: "block" dipetakan ke pengiriman blok Teams.
SlackStream native atau kiriman draf yang dapat diedit.Ketersediaan thread memengaruhi apakah streaming native dapat digunakan.
TelegramKirim satu pesan, lalu edit pesan itu.Draf lama yang terlihat dapat diganti agar timestamp akhir tetap berguna.
MattermostKiriman draf yang dapat diedit.Aktivitas alat digabungkan ke dalam kiriman bergaya draf yang sama.
Saluran tanpa dukungan edit yang aman biasanya fallback ke indikator mengetik atau pengiriman hanya-akhir.

Finalisasi

Saat jawaban akhir siap, OpenClaw mencoba menjaga chat tetap bersih:
  • Jika draf dapat dengan aman menjadi jawaban akhir, OpenClaw mengeditnya di tempat.
  • Jika saluran menggunakan streaming progres native, OpenClaw memfinalisasi stream tersebut saat transport native menerima teks akhir.
  • Jika jawaban akhir memiliki media, prompt persetujuan, target balasan eksplisit, terlalu banyak potongan, atau edit/kirim gagal, OpenClaw mengirim jawaban akhir melalui jalur pengiriman saluran normal.
Jalur fallback ini disengaja. Lebih baik mengirim jawaban akhir baru daripada kehilangan teks, salah menempatkan thread balasan, atau menimpa draf dengan payload yang tidak dapat direpresentasikan saluran dengan aman.

Pemecahan masalah

Saya hanya melihat jawaban akhir. Periksa bahwa channels.<channel>.streaming.mode diatur ke progress untuk akun atau saluran yang menangani pesan. Beberapa jalur grup atau balasan-kutipan dapat menonaktifkan pratinjau draf untuk suatu giliran saat saluran tidak dapat mengedit pesan yang tepat dengan aman. Saya melihat label tetapi tidak ada baris alat. Periksa streaming.progress.toolProgress. Jika nilainya false, OpenClaw mempertahankan perilaku satu draf tetapi menyembunyikan baris progres alat dan tugas. Saya melihat pesan akhir baru alih-alih draf yang diedit. Itu adalah fallback keamanan. Ini dapat terjadi untuk balasan media, jawaban panjang, target balasan eksplisit, draf Telegram lama, target thread Slack yang hilang, pesan pratinjau yang dihapus, atau finalisasi stream native yang gagal. Saya masih melihat pesan progres mandiri. Mode progres menekan pesan progres-alat mandiri default saat sebuah draf aktif. Jika pesan mandiri masih muncul, pastikan giliran tersebut benar-benar menggunakan mode progres dan bukan streaming.mode: "off" atau jalur saluran yang tidak dapat membuat draf untuk pesan tersebut. Teams berperilaku berbeda dari Discord atau Telegram. Microsoft Teams menggunakan stream native di chat personal, bukan transport pratinjau kirim-dan-edit generik. Teams juga memperlakukan streaming.mode: "block" sebagai pengiriman blok Teams karena tidak memiliki mode blok pratinjau-draf yang sama seperti yang digunakan Discord dan Telegram.

Terkait