Сервер FTS для статических блогов; использует SQLite под капюшоном.
# npm -g i nfts
Чтобы показать, как настоящий статический блог может быть дополнен с FTS, мы собираемся использовать репо для блога ROR:
$ git clone https://github.com/rails/weblog.git
$ cd weblog
$ bundle install
$ jekyll s --no-watch
Откройте http://127.0.0.1:4000, чтобы просмотреть блог.
Из терминала DIFF:
$ cd weblog
$ nfts-create -o db.sqlite3 -p _posts/ _posts/*
$ nfts-server db.sqlite3
Чтобы проверить сервер:
$ curl 'http://localhost:3000/?q=omg'
Это должно вернуть массив фрагментов.
Сейчас
Редактировать _includes/navigation.html , чтобы добавить ссылку, которая собирается вызвать диалог поиска:
<li><a id="nfts__dialog_toggle" href="#">Search</a></li>
Скопируйте файл web.js из установки NFTS DIR в weblog Dir и переименовать его в nfts.js Это ES6 UMD W/ 0 зависимости.
Добавить в _config.yml :
nfts:
dialog_toggle_btn: '#nfts__dialog_toggle'
parent_container: 'main > article'
server: http://localhost:3000
debounce: 200
Добавьте инициализацию NFTS в _includes/navigation.html :
<script src="/nfts.js"></script>
<script>
document.addEventListener('DOMContentLoaded', () => {
new NftsDialog(JSON.parse('{{site.nfts | jsonify }}'),
file => { // post
let prefix = NftsDialog.date_fmt(file.slice(0,10))
let basename = file.slice(10+1).replace(/.[^.]+$/, '')
return '{{site.url}}' + '/' + prefix + '/' + basename
})
})
</script>
Интеграция NFTS завершена. Перезапустите Jekyll, убедитесь, что он завершил регенерацию сайта и обновите страницу блога в браузере, нажмите «Поиск» и введите «OMG» (вам не нужно нажимать Enter).
Тодо.
Грань