refactor: remove conf.query, use conf.frontend.query

This commit is contained in:
JuanZoran 2023-03-23 17:31:02 +08:00
parent 6def81f2c6
commit a3b0a21d08
4 changed files with 29 additions and 24 deletions

View File

@ -6,7 +6,6 @@
return {
---@type string the directory for database file and password file
dir = require('Trans').relative_path({ 'extra' }, true),
query = 'fallback',
debug = true,
---@type 'default' | 'dracula' | 'tokyonight' global Trans theme [see lua/Trans/style/theme.lua]
theme = 'default', -- default | tokyonight | dracula
@ -22,6 +21,7 @@ return {
---@class TransFrontendOpts
---@field keymaps table<string, string>
default = {
query = 'fallback',
border = 'rounded',
title = vim.fn.has('nvim-0.9') == 1 and {
{ '', 'TransTitleRound' },
@ -45,10 +45,10 @@ return {
height = 27,
---@type string -- see: /lua/Trans/style/spinner
spinner = 'dots',
---@type string -- TODO :support replace with {{special word}}
---@type string
fallback_message = '{{notfound}} 翻译超时或没有找到相关的翻译',
auto_resize = true,
-- strict_sentence_width = false,
unlimit_sentence_width = true,
padding = 10, -- padding for hover window width
keymaps = {
pageup = '[[',

View File

@ -79,6 +79,7 @@ local function process(opts)
local str = opts.str
if not str or str == '' then return end
-- Find in cache
if Trans.cache[str] then
local data = Trans.cache[str]
@ -87,7 +88,7 @@ local function process(opts)
end
local data = Trans.data.new(opts)
if strategy[Trans.conf.query](data) then
if strategy[data.frontend.opts.query](data) then
Trans.cache[data.str] = data
data.frontend:process(data)
else

View File

@ -19,7 +19,6 @@ end
---@field play function @Use tts to play string
local separator = vim.loop.os_uname().sysname == "Windows" and "\\" or "/"
---@class Trans
---@field style table @Style module

View File

@ -7,6 +7,10 @@ local util = require('Trans').util
---@class TransItem : TransNode
local item_meta = {
---@param self TransItem
---@param buffer TransBuffer
---@param line integer
---@param col integer
render = function(self, buffer, line, col)
if self[2] then
buffer:add_highlight(line, self[2], col, col + #self[1])
@ -48,7 +52,7 @@ end
---@param nodes {[number]: TransNode, step: string?}
---@return table
---@return TransText
local function text(nodes)
return setmetatable({
[1] = table.concat(util.list_fields(nodes, 1), nodes.step),
@ -59,6 +63,7 @@ end
---@param args {[number]: TransNode, width: integer, spin: string?}
---@return TransText
local function format(args)
local width = args.width
local spin = args.spin or " "
@ -68,8 +73,8 @@ local function format(args)
wid = wid + args[i][1]:width()
end
local space = math.max(math.floor((width - wid) / (size - 1)), 0)
local space = math.max(math.floor((width - wid) / (size - 1)), 0)
args.step = spin:rep(space)
args.width = nil
args.spin = nil