Three years ago, Xianying Tan helped
me add the SearchBuilder extension of DataTables to the DT package. This
extension did not exist when I first started developing DT, otherwise I
would not have spent countless hours on creating a variety of filters in DT
by myself and make them work in both the client and server modes. This extension
is much, much more flexible than my clumsy “homemade” filters.
Yes, SearchBuilder has been made available to DT three years ago, but the
problem is that it only works on the client side. That is, if you render a table
in Shiny, you cannot DT::renderDT(server = TRUE) and can only do
server = FALSE. The filtering logic is not implemented on the server side.
Users have been asking how to make it work in the server mode, and one asked again last week. Unfortunately I do not really have time for this task, but I think it is an interesting little project, so I’m sharing tips on how it could be possibly implemented, in the hope that someone could pick it up and get it done. I do not think it is technically hard, but it definitely requires some focus time.
Basically, you need to inspect the object q during debugging the internal
function DT:::dataTablesFilter, and you will see parameters sent from
SearchBuilder in q$searchBuilder. You need to implement the filters by
dealing with these parameters with R code. Here is how you can get started:
debug(DT:::dataTablesFilter)
library(shiny)
shinyApp(
fluidPage(DT::DTOutput('foo')),
function(input, output) {
output$foo = DT::renderDT(
data.frame(
a = sample(26), b = letters,
c = factor(rep(c('a', 'b'), 13)),
d = Sys.Date() + 1:26,
e = Sys.time() + 1000 * (1:26)
),
options = list(dom = 'Qlfrtip'),
extensions = c('SearchBuilder', 'DateTime')
)
}
)
In DT:::dataTablesFilter, you can see how I implemented searching, pagination,
and sorting with R code. Similar things need to be done for parameters in
q$searchBuilder.
Please let me know if you need more guidance. I’m sure at least a few users will be grateful if this could be done, and so will I.
Donate
As a freelancer (currently working as a contractor) and a dad of three kids, I truly appreciate your donation to support my writing and open-source software development! Your contribution helps me cope with financial uncertainty better, so I can spend more time on producing high-quality content and software. You can make a donation through methods below.
-
Venmo:
@yihui_xie, or Zelle:xie@yihui.name -
Paypal
-
If you have a Paypal account, you can follow the link https://paypal.me/YihuiXie or find me on Paypal via my email
xie@yihui.name. Please choose the payment type as “Family and Friends” (instead of “Goods and Services”) to avoid extra fees. -
If you don’t have Paypal, you may donate through this link via your debit or credit card. Paypal will charge a fee on my side.
-
-
Other ways:
WeChat Pay (微信支付:谢益辉) Alipay (支付宝:谢益辉) 

When sending money, please be sure to add a note “gift” or “donation” if possible, so it won’t be treated as my taxable income but a genuine gift. Needless to say, donation is completely voluntary and I appreciate any amount you can give.
Please feel free to email me if you prefer a different way to give. Thank you very much!
I’ll give back a significant portion of the donations to the open-source community and charities. For the record, I received about $30,000 in total (before tax) in 2024-25, and gave back about $15,000 (after tax).