Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/matdombrock/tuxearch2
A searchable database for command line tools and code snippets.
https://github.com/matdombrock/tuxearch2
Last synced: 7 days ago
JSON representation
A searchable database for command line tools and code snippets.
- Host: GitHub
- URL: https://github.com/matdombrock/tuxearch2
- Owner: matdombrock
- Created: 2019-08-02T01:58:45.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2019-08-03T23:39:24.000Z (over 5 years ago)
- Last Synced: 2024-11-07T04:44:33.816Z (about 2 months ago)
- Language: JavaScript
- Homepage: https://mzero.space/Tuxearch2
- Size: 168 KB
- Stars: 0
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Tuxearch v2
***Pronounced: (tux-search)***![alt text](https://i.imgur.com/PsAOAia.gif)
(Due to GIF compression, the color of the actual product may vary)
[DEMO ON GITHUB PAGES](https://mzero.space/Tuxearch2)
## About
Tuxearch is a tool made to help developers, system admins and command-line enthusiasts store and retrieve their most commonly used commands in a quick and easy way.This software is built with VueJS and runs 100% client side. You commands are saved and retrieved from a simple JSON "database".
This is a total re-write of my original [Tuxearch Project](https://github.com/matdombrock/Tuxearch/blob/master/README.md). However, it is fully backwards compatible with original Tuxearch databases.
Tuxearch has no external dependencies outside of VueJS.
## Install
This is 100% front-end Javascript and HTML. There is no need to configure a database, but this does need to run on some kind of web server.1. Clone this project into a new directory on your active web server.
2. Change the application URL in the ```config/config.js``` file to reflect the URL where you are hosting the software.
3. Confirm the software is working correctly by visiting the URL you just configured.## Usage
To use the software simply start typing your search query into the search bar and the available commands will automatically filter down to show just the ones that are most relevant to your search criteria.## Working With The Database
Adding to the database is actually really easy. Just edit "db/database.json" and append the new data to the bottom of the file as follows:
```json
{
"INFO" : "info about your command",
"COMMAND" : "actual command #1",
"TAGS" : "tags split by space not commas"
},
{
"INFO" : "info about another command",
"COMMAND" : "actual command #2",
"TAGS" : "tags split by space not commas"
}
```
**Notes:**
* Make sure you are adding valid JSON and that you do not break the JSON formatting.
* If you need yo check your JSON for validity you can use a tool like [JSON Lint](https://jsonlint.com/).
* A search is preformed against all elements of a database item, so you don't need to add words as tags if they are already mentioned in the command or info elements.## Configuration
You can edit the file ```config/config.js``` to easily make some changes to the software as needed.Here is a copy of the default configuration settings:
```js
const config = [];// Application URL with trailing slash
config.url = "https://mzero.space/Tuxearch2/";// What is the name of our database file in the 'db' directory?
config.databaseName = "db.json";// Do we want to display all database items if the search bar is empty?
config.displayAllResultsOnEmptySearch = true;// Do we want to display how many points an item was given according to the search criteria?
config.displayItemPoints = false;// Do we want to display the items tags?
config.displayItemTags = false;// Do you want to take all of the credit for making this?
config.hideCredits = false;
```
**Notes:**
* databaseName, can be changed to match the name of a custom database file that you put into the ```db/``` directory. Make sure to include ```.json``` as the filetype.
* displayItemPoints, displays the amount of "points" that a database item received when being checked by the search/ranking algorithm. The more points and item gets, the higher it is in the search rank. Each element of the database item is checked against each term in your search adn assigned one point for a match, so the more search terms you use the more possible points that can be awarded.
* displayItemTags, displays that tags that each search item has. This is mainly useful for troubleshooting.## FAQs
### Why Is This Software Named Tuxearch?
The name "Tuxearch" is a portmanteau of "Tux" (the Linux mascot) and the word "search". Of of the software names I could think of that did NOT abuse the English language were taken.### Why The Rewrite?
The old code was very cumbersome and required NodeJS + Electron just to run. This was not necessary to the do what this does so I decided to remove it. There is just no reason this software can't be 100% client side code. However, the old code was coupled too tightly with the idea of having a back-end, so I decided it would be faster to just re-write it.### Why VueJS?
I was able to re-write this app in an afternoon because of how easy Vue is to use. Before, the rendering logic was all custom javascript, but now Vue is handling all of that for me, and doing a much better job.### Why No "Formal" Database?:
A database requires a back-end and an API. Both of those things add complexity to the software and don't really offer anything in return in this case. Since the software never writes to the database, as far as it's concerned, the data is read-only. This helps offer much easier deployment and opens up hosting options like GitHub pages.### Is This Backwards Compatible With The Old Code Base?
Yes! The JSON files that you were using on with the original version of Tuxearch will work here too without any modification at all. You can just place them in the ```db/``` directory and change the configuration setting.