-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathREADME
101 lines (79 loc) · 3.92 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
Lucid Prism - a user interface framework designed specifically for Apache Solr.
Current capabilities:
* Direct Solr pass-through /solr action
* LucidWorks Enterprise /lwe action, hardcoded using role => DEFAULT, to LWE's /lucid handler
Prerequisites:
* Launch LucidWorks Enterprise
* JRuby 1.6.5 (rvm use jruby-1.6.5), with Sinatra gem installed (jruby -S gem install sinatra)
Launching Prism:
Launch: jruby -rubygems -Ilib lib/prism.rb
Browse: http://localhost:4567/lwe
Known issues:
* Parameter arrays don't work as they do with Solr
/search?fq=one&fq=two only passes through one of the fq values.
fq[] is the way to get arrays, so this works to pass through fq's to Solr:
/search?fq[]=one&fq[]=two
We'll fix this lame one right away!
Features Roadmap:
* LucidWorks Enterprise integration, including:
- authorization
- click logging
- saved search alerts
* Auto suggest
* Auto search
* User Interface viz goodies
- SIMILE Timeline and Exhibit
- Facet pie charts
- Query overlap Venn diagrams
- sparklines (if we must, for the Tuftee's among you)
* mobile interface - jQTouch? PhoneGap?
* interaction configurator:
- facet configurator:
- pick field (or eventually by range, query, and pivot too)
- tweak appropriate params (mincount, sort, etc)
- see live http query params (encoded/unencoded) and view of facets
- query configurator (relevancy workbenchy?)
- pick query parser, set parser-specific params
- peel off any number of tabs/windows set (by named configuration) to compare
Configuration:
- TBD exactly, but the idea is to allow end users to simply configure Solr
and add simple UI templates.
- Convention over configuration? Sort of, but less magic and
more "just build the search UI intuitively".
FAQ
Why?
Because Solr search UI still isn't trivial enough to build for the
masses. We need something lean, clean, extensible, with all the modern
day sparkly things built in.
Why is it called Prism?
Solr light shines through, pretty colors come out.
Why JRuby?
JRuby makes the Prism world a better place in a few ways -
* Literally "run anywhere" without additional environmental impact;
no need to install Ruby into your operating system.
* Secret sauce: Velocity templating. Opininated? Sure.
But for good reason*. However, Prism itself, via Sinatra, will use any Ruby
templating technology you'd like.
* Advanced users will likely enjoy being able to integrate Java libraries
for enterprisey things.
How about non-(J)Ruby deployment?
Deploying into another Ruby runtime shouldn't be a problem. For the
moment, the development is proceeding with only JRuby and Velocity,
but Prism is just a Sinatra Ruby app and can use ERb or other templating
technologies.
If you want an ERb-based search UI for LucidWorks Enterprise,
there is one built directly into LWE already.
For other Ruby-based Solr search UI, consider starting with Blacklight
or borrowing bits from Flare.
For non-Ruby Solr search UI, there are many projects in a variety of
technologies floating out there. Search around.
For non-Solr search UI: Solr is a mighty fine search engine that you
should strongly consider, if only for this snazzy Prism search UI :)
* Why Velocity?
It's leaner, cleaner, and sports a number of powerful features that Prism
will leverage including dynamically controlled template loaders and
macros. A basic comparison of Velocity versus ERb:
$var versus <%=@var%>. Less typing, less junk, easier to document, no
Ruby or Java knowledge necessary. We'll likely bring in Velocity through
the Velaro (https://github.com/erikhatcher/velaro) project, and fleshing
out the JRuby/Velocity integration there.