questionnaire stuff
Conflicts: vendor/built_in_modules/announcement/app/controllers/panel/announcement/front_end/bulletins_controller.rb vendor/built_in_modules/announcement/app/views/panel/announcement/front_end/bulletins/index.html.erb
This commit is contained in:
		
							parent
							
								
									32c259ac9e
								
							
						
					
					
						commit
						adc15951bb
					
				| 
						 | 
				
			
			@ -0,0 +1,112 @@
 | 
			
		|||
.o-question {
 | 
			
		||||
  font-size: 15px;
 | 
			
		||||
}
 | 
			
		||||
.o-question input[type=checkbox], .o-question input[type=radio] {
 | 
			
		||||
  margin: 0;
 | 
			
		||||
}
 | 
			
		||||
.o-question textarea {
 | 
			
		||||
  resize: vertical;
 | 
			
		||||
}
 | 
			
		||||
.o-question-topic {
 | 
			
		||||
  font-size: 2em;
 | 
			
		||||
  line-height: normal;
 | 
			
		||||
  margin: 0;
 | 
			
		||||
  padding: 0.5em 0;
 | 
			
		||||
}
 | 
			
		||||
.o-question-description {
 | 
			
		||||
  font-size: 0.9em;
 | 
			
		||||
  line-height: 1.5em;
 | 
			
		||||
}
 | 
			
		||||
.o-question-list {
 | 
			
		||||
  clear: both;
 | 
			
		||||
  margin: 40px 0;
 | 
			
		||||
  padding: 0;
 | 
			
		||||
  font-weight: bold;
 | 
			
		||||
}
 | 
			
		||||
.o-question-list > li {
 | 
			
		||||
  margin: 0 0 0 40px;
 | 
			
		||||
  padding: 16px 0;
 | 
			
		||||
  border-top: solid 1px #eee;
 | 
			
		||||
}
 | 
			
		||||
.o-question-list > li:first-child {
 | 
			
		||||
  border: 0;
 | 
			
		||||
}
 | 
			
		||||
.o-question-title {
 | 
			
		||||
  font-weight: bold;
 | 
			
		||||
}
 | 
			
		||||
.o-question-title + input[type=text], .o-question-title + textarea, .o-question-title + select {
 | 
			
		||||
  display: block;
 | 
			
		||||
}
 | 
			
		||||
.o-question-title + input[type=text], .o-question-title + textarea {
 | 
			
		||||
  border: solid 1px #ccc;
 | 
			
		||||
  padding: 6px;
 | 
			
		||||
  margin: 20px 0;
 | 
			
		||||
  line-height: 24px;
 | 
			
		||||
}
 | 
			
		||||
.o-question-title + input[type=text] {
 | 
			
		||||
  width: 40%;
 | 
			
		||||
}
 | 
			
		||||
.o-question-title + textarea {
 | 
			
		||||
  width: 70%;
 | 
			
		||||
}
 | 
			
		||||
.o-question-group {
 | 
			
		||||
  margin: 20px 0;
 | 
			
		||||
  padding: 0;
 | 
			
		||||
}
 | 
			
		||||
.o-question-option {
 | 
			
		||||
  font-weight: normal;
 | 
			
		||||
}
 | 
			
		||||
.o-question-group.view-list {
 | 
			
		||||
  list-style: none;
 | 
			
		||||
}
 | 
			
		||||
.o-question-group.view-list .o-question-option {}
 | 
			
		||||
.o-question-group.view-list > li {
 | 
			
		||||
  margin-top: 8px;
 | 
			
		||||
}
 | 
			
		||||
.o-question-group.view-list > li:first-child {
 | 
			
		||||
  margin: 0;
 | 
			
		||||
}
 | 
			
		||||
.o-question-group.view-list > li > * {
 | 
			
		||||
  display: inline-block;
 | 
			
		||||
  margin: 0;
 | 
			
		||||
  padding: 0;
 | 
			
		||||
  vertical-align: middle;
 | 
			
		||||
}
 | 
			
		||||
.o-question-group.view-list > li input + .o-question-option {
 | 
			
		||||
  margin: 0 0 0 12px;
 | 
			
		||||
}
 | 
			
		||||
.o-question-group.view-dropdown {
 | 
			
		||||
  height: 24px;
 | 
			
		||||
  line-height: 24px;
 | 
			
		||||
}
 | 
			
		||||
.o-question-group.view-grid {
 | 
			
		||||
  border-collapse: collapse;
 | 
			
		||||
  max-width: 90%;
 | 
			
		||||
  min-width: 50%;
 | 
			
		||||
}
 | 
			
		||||
.o-question-group.view-grid th, .o-question-group.view-grid td {
 | 
			
		||||
  padding: 6px;
 | 
			
		||||
}
 | 
			
		||||
.o-question-group.view-grid thead th {}
 | 
			
		||||
.o-question-group.view-grid tbody th {}
 | 
			
		||||
.o-question-group.view-grid tbody .odd .o-question-title, .o-question-group.view-grid tbody .odd td {
 | 
			
		||||
  background-color: #f6f6f6;
 | 
			
		||||
}
 | 
			
		||||
.o-question-group.view-grid tbody .odd .o-question-title {
 | 
			
		||||
  background-color: transparent;
 | 
			
		||||
}
 | 
			
		||||
.o-question-group.view-grid tbody .odd td {}
 | 
			
		||||
.o-question-group.view-grid tbody tr:hover td {
 | 
			
		||||
  background-color: #aaa;
 | 
			
		||||
}
 | 
			
		||||
.o-question-group.view-grid tbody td {
 | 
			
		||||
  vertical-align: middle;
 | 
			
		||||
  text-align: center;
 | 
			
		||||
}
 | 
			
		||||
.o-question-group.view-grid tbody td input {
 | 
			
		||||
  vertical-align: baseline;
 | 
			
		||||
}
 | 
			
		||||
.o-question-action {
 | 
			
		||||
  padding: 20px;
 | 
			
		||||
  background-color: #f6f6f6;
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,52 @@
 | 
			
		|||
@import url(http://fonts.googleapis.com/css?family=Open+Sans:400,700);
 | 
			
		||||
body {
 | 
			
		||||
  margin: 0;
 | 
			
		||||
  padding: 50px 0;
 | 
			
		||||
  background-color: #eee;
 | 
			
		||||
  font-family: 'Open Sans', sans-serif;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.wrapper {
 | 
			
		||||
  background-color: #FFFFFF;
 | 
			
		||||
  box-shadow: 0 0 50px rgba(0, 0, 0, 0.1);
 | 
			
		||||
  margin: 0 auto;
 | 
			
		||||
  overflow: hidden;
 | 
			
		||||
  width: 980px;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.wrapper > h1 {
 | 
			
		||||
  margin: 0;
 | 
			
		||||
  padding: 20px;
 | 
			
		||||
  font-family: 'Open Sans', sans-serif;
 | 
			
		||||
  font-weight: bold;
 | 
			
		||||
}
 | 
			
		||||
section {
 | 
			
		||||
  border-top: dashed 3px #eee;
 | 
			
		||||
  padding: 40px;
 | 
			
		||||
  overflow: hidden;
 | 
			
		||||
}
 | 
			
		||||
section:first-child {
 | 
			
		||||
  border: 0;
 | 
			
		||||
  padding-top: 0;
 | 
			
		||||
}
 | 
			
		||||
section > h2 {
 | 
			
		||||
  font-size: 13px;
 | 
			
		||||
  font-weight: bold;
 | 
			
		||||
  border: solid 1px #ddd;
 | 
			
		||||
  background-color: #2676C0;
 | 
			
		||||
  color: #fff;
 | 
			
		||||
  display: inline-block;
 | 
			
		||||
  padding: 0 16px;
 | 
			
		||||
  box-shadow: 0 1px 1px #fff, 0 2px 6px rgba(0,0,0,0.1);
 | 
			
		||||
}
 | 
			
		||||
.side {
 | 
			
		||||
  float: right;
 | 
			
		||||
  width: 189px;
 | 
			
		||||
  padding-left: 20px;
 | 
			
		||||
  border-left: solid 1px #eee;
 | 
			
		||||
}
 | 
			
		||||
.main {
 | 
			
		||||
  float: left;
 | 
			
		||||
  width: 710px;
 | 
			
		||||
  padding-right: 20px;
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,31 @@
 | 
			
		|||
<!DOCTYPE HTML>
 | 
			
		||||
<html class="<%= I18n.locale.to_s %>">
 | 
			
		||||
<head>
 | 
			
		||||
<meta charset="utf-8">
 | 
			
		||||
  <%= page_title(@item).html_safe %>
 | 
			
		||||
  <link rel="shortcut icon" href="<%= asset_path "ncculogo.ico" %>">
 | 
			
		||||
  <%= page_metas(@item).html_safe %>
 | 
			
		||||
  <!--[if lt IE 9]>
 | 
			
		||||
     <%= javascript_include_tag "html5" %>
 | 
			
		||||
  <![endif]-->
 | 
			
		||||
  <%= page_stylesheets(@item).html_safe %>
 | 
			
		||||
  <link href='/assets/standalone.css' rel='stylesheet' type='text/css' />
 | 
			
		||||
  <%= yield :page_stylesheets %>
 | 
			
		||||
  <%= page_javascripts(@item).html_safe %>
 | 
			
		||||
  <%= csrf_meta_tag %>
 | 
			
		||||
</head>
 | 
			
		||||
<body>
 | 
			
		||||
  <div class="wrapper">
 | 
			
		||||
    <%= yield %>
 | 
			
		||||
  </div>
 | 
			
		||||
  <% if flash[:error] %>
 | 
			
		||||
    <div class="modal alert alert-error hide" id="myModal">
 | 
			
		||||
      <p type="button" class="close" data-dismiss="modal">×</p>
 | 
			
		||||
        <%= "<strong>#{flash[:error]}</strong><br/>".html_safe%>
 | 
			
		||||
    </div>
 | 
			
		||||
    <script>
 | 
			
		||||
      $('#myModal').modal('show')
 | 
			
		||||
    </script>
 | 
			
		||||
  <% end -%>
 | 
			
		||||
</body>
 | 
			
		||||
</html>
 | 
			
		||||
| 
						 | 
				
			
			@ -288,11 +288,11 @@ Orbit::Application.routes.draw do
 | 
			
		|||
 | 
			
		||||
 | 
			
		||||
  match '/panel/:app_name/front_end/:app_action/:id(/:controller_action)' => 'pages#show_from_link', :constraints => lambda { |request|
 | 
			
		||||
    !request.query_string.include?("inner=true")
 | 
			
		||||
    !request.query_string.include?("inner=true") && !request.query_string.include?("standalone=true")
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  match '/panel/:app_name/front_end/:app_action' => 'pages#index_from_link', :constraints => lambda { |request|
 | 
			
		||||
    !request.query_string.include?("inner=true")
 | 
			
		||||
    !request.query_string.include?("inner=true") && !request.query_string.include?("standalone=true")
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  match '/share/:model/:id' => 'application#render_share'
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,31 +0,0 @@
 | 
			
		|||
<!--
 | 
			
		||||
 Licensed to the Apache Software Foundation (ASF) under one or more
 | 
			
		||||
 contributor license agreements.  See the NOTICE file distributed with
 | 
			
		||||
 this work for additional information regarding copyright ownership.
 | 
			
		||||
 The ASF licenses this file to You under the Apache License, Version 2.0
 | 
			
		||||
 (the "License"); you may not use this file except in compliance with
 | 
			
		||||
 the License.  You may obtain a copy of the License at
 | 
			
		||||
 | 
			
		||||
     http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
 | 
			
		||||
 Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
 distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
 See the License for the specific language governing permissions and
 | 
			
		||||
 limitations under the License.
 | 
			
		||||
-->
 | 
			
		||||
 | 
			
		||||
<!-- The content of this page will be statically included into the top
 | 
			
		||||
of the admin page.  Uncomment this as an example to see there the content
 | 
			
		||||
will show up.
 | 
			
		||||
 | 
			
		||||
<hr>
 | 
			
		||||
<i>This line will appear before the first table</i>
 | 
			
		||||
<tr>
 | 
			
		||||
<td colspan="2">
 | 
			
		||||
This row will be appended to the end of the first table
 | 
			
		||||
</td>
 | 
			
		||||
</tr>
 | 
			
		||||
<hr>
 | 
			
		||||
 | 
			
		||||
-->
 | 
			
		||||
| 
						 | 
				
			
			@ -1,36 +0,0 @@
 | 
			
		|||
<?xml version="1.0" encoding="UTF-8" ?>
 | 
			
		||||
<!--
 | 
			
		||||
 Licensed to the Apache Software Foundation (ASF) under one or more
 | 
			
		||||
 contributor license agreements.  See the NOTICE file distributed with
 | 
			
		||||
 this work for additional information regarding copyright ownership.
 | 
			
		||||
 The ASF licenses this file to You under the Apache License, Version 2.0
 | 
			
		||||
 (the "License"); you may not use this file except in compliance with
 | 
			
		||||
 the License.  You may obtain a copy of the License at
 | 
			
		||||
 | 
			
		||||
     http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
 | 
			
		||||
 Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
 distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
 See the License for the specific language governing permissions and
 | 
			
		||||
 limitations under the License.
 | 
			
		||||
-->
 | 
			
		||||
 | 
			
		||||
<!-- If this file is found in the config directory, it will only be
 | 
			
		||||
     loaded once at startup.  If it is found in Solr's data
 | 
			
		||||
     directory, it will be re-loaded every commit.
 | 
			
		||||
-->
 | 
			
		||||
 | 
			
		||||
<elevate>
 | 
			
		||||
 <query text="foo bar">
 | 
			
		||||
  <doc id="1" />
 | 
			
		||||
  <doc id="2" />
 | 
			
		||||
  <doc id="3" />
 | 
			
		||||
 </query>
 | 
			
		||||
 
 | 
			
		||||
 <query text="ipod">
 | 
			
		||||
   <doc id="MA147LL/A" />  <!-- put the actual ipod at the top -->
 | 
			
		||||
   <doc id="IW-02" exclude="true" /> <!-- exclude this cable -->
 | 
			
		||||
 </query>
 | 
			
		||||
 
 | 
			
		||||
</elevate>
 | 
			
		||||
| 
						 | 
				
			
			@ -1,246 +0,0 @@
 | 
			
		|||
# The ASF licenses this file to You under the Apache License, Version 2.0
 | 
			
		||||
# (the "License"); you may not use this file except in compliance with
 | 
			
		||||
# the License.  You may obtain a copy of the License at
 | 
			
		||||
#
 | 
			
		||||
#     http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
#
 | 
			
		||||
# Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
# distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
# See the License for the specific language governing permissions and
 | 
			
		||||
# limitations under the License.
 | 
			
		||||
 | 
			
		||||
# Syntax:
 | 
			
		||||
#   "source" => "target"
 | 
			
		||||
#     "source".length() > 0 (source cannot be empty.)
 | 
			
		||||
#     "target".length() >= 0 (target can be empty.)
 | 
			
		||||
 | 
			
		||||
# example:
 | 
			
		||||
#   "À" => "A"
 | 
			
		||||
#   "\u00C0" => "A"
 | 
			
		||||
#   "\u00C0" => "\u0041"
 | 
			
		||||
#   "ß" => "ss"
 | 
			
		||||
#   "\t" => " "
 | 
			
		||||
#   "\n" => ""
 | 
			
		||||
 | 
			
		||||
# À => A
 | 
			
		||||
"\u00C0" => "A"
 | 
			
		||||
 | 
			
		||||
# Á => A
 | 
			
		||||
"\u00C1" => "A"
 | 
			
		||||
 | 
			
		||||
# Â => A
 | 
			
		||||
"\u00C2" => "A"
 | 
			
		||||
 | 
			
		||||
# Ã => A
 | 
			
		||||
"\u00C3" => "A"
 | 
			
		||||
 | 
			
		||||
# Ä => A
 | 
			
		||||
"\u00C4" => "A"
 | 
			
		||||
 | 
			
		||||
# Å => A
 | 
			
		||||
"\u00C5" => "A"
 | 
			
		||||
 | 
			
		||||
# Æ => AE
 | 
			
		||||
"\u00C6" => "AE"
 | 
			
		||||
 | 
			
		||||
# Ç => C
 | 
			
		||||
"\u00C7" => "C"
 | 
			
		||||
 | 
			
		||||
# È => E
 | 
			
		||||
"\u00C8" => "E"
 | 
			
		||||
 | 
			
		||||
# É => E
 | 
			
		||||
"\u00C9" => "E"
 | 
			
		||||
 | 
			
		||||
# Ê => E
 | 
			
		||||
"\u00CA" => "E"
 | 
			
		||||
 | 
			
		||||
# Ë => E
 | 
			
		||||
"\u00CB" => "E"
 | 
			
		||||
 | 
			
		||||
# Ì => I
 | 
			
		||||
"\u00CC" => "I"
 | 
			
		||||
 | 
			
		||||
# Í => I
 | 
			
		||||
"\u00CD" => "I"
 | 
			
		||||
 | 
			
		||||
# Î => I
 | 
			
		||||
"\u00CE" => "I"
 | 
			
		||||
 | 
			
		||||
# Ï => I
 | 
			
		||||
"\u00CF" => "I"
 | 
			
		||||
 | 
			
		||||
# IJ => IJ
 | 
			
		||||
"\u0132" => "IJ"
 | 
			
		||||
 | 
			
		||||
# Ð => D
 | 
			
		||||
"\u00D0" => "D"
 | 
			
		||||
 | 
			
		||||
# Ñ => N
 | 
			
		||||
"\u00D1" => "N"
 | 
			
		||||
 | 
			
		||||
# Ò => O
 | 
			
		||||
"\u00D2" => "O"
 | 
			
		||||
 | 
			
		||||
# Ó => O
 | 
			
		||||
"\u00D3" => "O"
 | 
			
		||||
 | 
			
		||||
# Ô => O
 | 
			
		||||
"\u00D4" => "O"
 | 
			
		||||
 | 
			
		||||
# Õ => O
 | 
			
		||||
"\u00D5" => "O"
 | 
			
		||||
 | 
			
		||||
# Ö => O
 | 
			
		||||
"\u00D6" => "O"
 | 
			
		||||
 | 
			
		||||
# Ø => O
 | 
			
		||||
"\u00D8" => "O"
 | 
			
		||||
 | 
			
		||||
# Œ => OE
 | 
			
		||||
"\u0152" => "OE"
 | 
			
		||||
 | 
			
		||||
# Þ
 | 
			
		||||
"\u00DE" => "TH"
 | 
			
		||||
 | 
			
		||||
# Ù => U
 | 
			
		||||
"\u00D9" => "U"
 | 
			
		||||
 | 
			
		||||
# Ú => U
 | 
			
		||||
"\u00DA" => "U"
 | 
			
		||||
 | 
			
		||||
# Û => U
 | 
			
		||||
"\u00DB" => "U"
 | 
			
		||||
 | 
			
		||||
# Ü => U
 | 
			
		||||
"\u00DC" => "U"
 | 
			
		||||
 | 
			
		||||
# Ý => Y
 | 
			
		||||
"\u00DD" => "Y"
 | 
			
		||||
 | 
			
		||||
# Ÿ => Y
 | 
			
		||||
"\u0178" => "Y"
 | 
			
		||||
 | 
			
		||||
# à => a
 | 
			
		||||
"\u00E0" => "a"
 | 
			
		||||
 | 
			
		||||
# á => a
 | 
			
		||||
"\u00E1" => "a"
 | 
			
		||||
 | 
			
		||||
# â => a
 | 
			
		||||
"\u00E2" => "a"
 | 
			
		||||
 | 
			
		||||
# ã => a
 | 
			
		||||
"\u00E3" => "a"
 | 
			
		||||
 | 
			
		||||
# ä => a
 | 
			
		||||
"\u00E4" => "a"
 | 
			
		||||
 | 
			
		||||
# å => a
 | 
			
		||||
"\u00E5" => "a"
 | 
			
		||||
 | 
			
		||||
# æ => ae
 | 
			
		||||
"\u00E6" => "ae"
 | 
			
		||||
 | 
			
		||||
# ç => c
 | 
			
		||||
"\u00E7" => "c"
 | 
			
		||||
 | 
			
		||||
# è => e
 | 
			
		||||
"\u00E8" => "e"
 | 
			
		||||
 | 
			
		||||
# é => e
 | 
			
		||||
"\u00E9" => "e"
 | 
			
		||||
 | 
			
		||||
# ê => e
 | 
			
		||||
"\u00EA" => "e"
 | 
			
		||||
 | 
			
		||||
# ë => e
 | 
			
		||||
"\u00EB" => "e"
 | 
			
		||||
 | 
			
		||||
# ì => i
 | 
			
		||||
"\u00EC" => "i"
 | 
			
		||||
 | 
			
		||||
# í => i
 | 
			
		||||
"\u00ED" => "i"
 | 
			
		||||
 | 
			
		||||
# î => i
 | 
			
		||||
"\u00EE" => "i"
 | 
			
		||||
 | 
			
		||||
# ï => i
 | 
			
		||||
"\u00EF" => "i"
 | 
			
		||||
 | 
			
		||||
# ij => ij
 | 
			
		||||
"\u0133" => "ij"
 | 
			
		||||
 | 
			
		||||
# ð => d
 | 
			
		||||
"\u00F0" => "d"
 | 
			
		||||
 | 
			
		||||
# ñ => n
 | 
			
		||||
"\u00F1" => "n"
 | 
			
		||||
 | 
			
		||||
# ò => o
 | 
			
		||||
"\u00F2" => "o"
 | 
			
		||||
 | 
			
		||||
# ó => o
 | 
			
		||||
"\u00F3" => "o"
 | 
			
		||||
 | 
			
		||||
# ô => o
 | 
			
		||||
"\u00F4" => "o"
 | 
			
		||||
 | 
			
		||||
# õ => o
 | 
			
		||||
"\u00F5" => "o"
 | 
			
		||||
 | 
			
		||||
# ö => o
 | 
			
		||||
"\u00F6" => "o"
 | 
			
		||||
 | 
			
		||||
# ø => o
 | 
			
		||||
"\u00F8" => "o"
 | 
			
		||||
 | 
			
		||||
# œ => oe
 | 
			
		||||
"\u0153" => "oe"
 | 
			
		||||
 | 
			
		||||
# ß => ss
 | 
			
		||||
"\u00DF" => "ss"
 | 
			
		||||
 | 
			
		||||
# þ => th
 | 
			
		||||
"\u00FE" => "th"
 | 
			
		||||
 | 
			
		||||
# ù => u
 | 
			
		||||
"\u00F9" => "u"
 | 
			
		||||
 | 
			
		||||
# ú => u
 | 
			
		||||
"\u00FA" => "u"
 | 
			
		||||
 | 
			
		||||
# û => u
 | 
			
		||||
"\u00FB" => "u"
 | 
			
		||||
 | 
			
		||||
# ü => u
 | 
			
		||||
"\u00FC" => "u"
 | 
			
		||||
 | 
			
		||||
# ý => y
 | 
			
		||||
"\u00FD" => "y"
 | 
			
		||||
 | 
			
		||||
# ÿ => y
 | 
			
		||||
"\u00FF" => "y"
 | 
			
		||||
 | 
			
		||||
# ff => ff
 | 
			
		||||
"\uFB00" => "ff"
 | 
			
		||||
 | 
			
		||||
# fi => fi
 | 
			
		||||
"\uFB01" => "fi"
 | 
			
		||||
 | 
			
		||||
# fl => fl
 | 
			
		||||
"\uFB02" => "fl"
 | 
			
		||||
 | 
			
		||||
# ffi => ffi
 | 
			
		||||
"\uFB03" => "ffi"
 | 
			
		||||
 | 
			
		||||
# ffl => ffl
 | 
			
		||||
"\uFB04" => "ffl"
 | 
			
		||||
 | 
			
		||||
# ſt => ft
 | 
			
		||||
"\uFB05" => "ft"
 | 
			
		||||
 | 
			
		||||
# st => st
 | 
			
		||||
"\uFB06" => "st"
 | 
			
		||||
| 
						 | 
				
			
			@ -1,21 +0,0 @@
 | 
			
		|||
# The ASF licenses this file to You under the Apache License, Version 2.0
 | 
			
		||||
# (the "License"); you may not use this file except in compliance with
 | 
			
		||||
# the License.  You may obtain a copy of the License at
 | 
			
		||||
#
 | 
			
		||||
#     http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
#
 | 
			
		||||
# Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
# distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
# See the License for the specific language governing permissions and
 | 
			
		||||
# limitations under the License.
 | 
			
		||||
 | 
			
		||||
#-----------------------------------------------------------------------
 | 
			
		||||
# Use a protected word file to protect against the stemmer reducing two
 | 
			
		||||
# unrelated words to the same base word.
 | 
			
		||||
 | 
			
		||||
# Some non-words that normally won't be encountered,
 | 
			
		||||
# just to test that they won't be stemmed.
 | 
			
		||||
dontstems
 | 
			
		||||
zwhacky
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -1,238 +0,0 @@
 | 
			
		|||
<?xml version="1.0" encoding="UTF-8"?>
 | 
			
		||||
<!--
 | 
			
		||||
 Licensed to the Apache Software Foundation (ASF) under one or more
 | 
			
		||||
 contributor license agreements.  See the NOTICE file distributed with
 | 
			
		||||
 this work for additional information regarding copyright ownership.
 | 
			
		||||
 The ASF licenses this file to You under the Apache License, Version 2.0
 | 
			
		||||
 (the "License"); you may not use this file except in compliance with
 | 
			
		||||
 the License.  You may obtain a copy of the License at
 | 
			
		||||
 | 
			
		||||
     http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
 | 
			
		||||
 Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
 distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
 See the License for the specific language governing permissions and
 | 
			
		||||
 limitations under the License.
 | 
			
		||||
-->
 | 
			
		||||
<!--  
 | 
			
		||||
 This is the Solr schema file. This file should be named "schema.xml" and
 | 
			
		||||
 should be in the conf directory under the solr home
 | 
			
		||||
 (i.e. ./solr/conf/schema.xml by default) 
 | 
			
		||||
 or located where the classloader for the Solr webapp can find it.
 | 
			
		||||
 | 
			
		||||
 This example schema is the recommended starting point for users.
 | 
			
		||||
 It should be kept correct and concise, usable out-of-the-box.
 | 
			
		||||
 | 
			
		||||
 For more information, on how to customize this file, please see
 | 
			
		||||
 http://wiki.apache.org/solr/SchemaXml
 | 
			
		||||
 | 
			
		||||
 PERFORMANCE NOTE: this schema includes many optional features and should not
 | 
			
		||||
 be used for benchmarking.  To improve performance one could
 | 
			
		||||
  - set stored="false" for all fields possible (esp large fields) when you
 | 
			
		||||
    only need to search on the field but don't need to return the original
 | 
			
		||||
    value.
 | 
			
		||||
  - set indexed="false" if you don't need to search on the field, but only
 | 
			
		||||
    return the field as a result of searching on other indexed fields.
 | 
			
		||||
  - remove all unneeded copyField statements
 | 
			
		||||
  - for best index size and searching performance, set "index" to false
 | 
			
		||||
    for all general text fields, use copyField to copy them to the
 | 
			
		||||
    catchall "text" field, and use that for searching.
 | 
			
		||||
  - For maximum indexing performance, use the StreamingUpdateSolrServer
 | 
			
		||||
    java client.
 | 
			
		||||
  - Remember to run the JVM in server mode, and use a higher logging level
 | 
			
		||||
    that avoids logging every request
 | 
			
		||||
-->
 | 
			
		||||
<schema name="sunspot" version="1.0">
 | 
			
		||||
  <types>
 | 
			
		||||
    <!-- field type definitions. The "name" attribute is
 | 
			
		||||
       just a label to be used by field definitions.  The "class"
 | 
			
		||||
       attribute and any other attributes determine the real
 | 
			
		||||
       behavior of the fieldType.
 | 
			
		||||
         Class names starting with "solr" refer to java classes in the
 | 
			
		||||
       org.apache.solr.analysis package.
 | 
			
		||||
    -->
 | 
			
		||||
    <!-- *** This fieldType is used by Sunspot! *** -->
 | 
			
		||||
    <fieldType name="string" class="solr.StrField" omitNorms="true"/>
 | 
			
		||||
    <!-- *** This fieldType is used by Sunspot! *** -->
 | 
			
		||||
    <fieldType name="tdouble" class="solr.TrieDoubleField" omitNorms="true"/>
 | 
			
		||||
    <!-- *** This fieldType is used by Sunspot! *** -->
 | 
			
		||||
    <fieldType name="rand" class="solr.RandomSortField" omitNorms="true"/>
 | 
			
		||||
    <!-- *** This fieldType is used by Sunspot! *** -->
 | 
			
		||||
    <fieldType name="text" class="solr.TextField" omitNorms="false">
 | 
			
		||||
      <analyzer>
 | 
			
		||||
        <tokenizer class="solr.CJKTokenizerFactory"/>
 | 
			
		||||
        <filter class="solr.StandardFilterFactory"/>
 | 
			
		||||
        <filter class="solr.LowerCaseFilterFactory"/>
 | 
			
		||||
      </analyzer>
 | 
			
		||||
    </fieldType>
 | 
			
		||||
    <!-- *** This fieldType is used by Sunspot! *** -->
 | 
			
		||||
    <fieldType name="boolean" class="solr.BoolField" omitNorms="true"/>
 | 
			
		||||
    <!-- *** This fieldType is used by Sunspot! *** -->
 | 
			
		||||
    <fieldType name="date" class="solr.DateField" omitNorms="true"/>
 | 
			
		||||
    <!-- *** This fieldType is used by Sunspot! *** -->
 | 
			
		||||
    <fieldType name="sdouble" class="solr.SortableDoubleField" omitNorms="true"/>
 | 
			
		||||
    <!-- *** This fieldType is used by Sunspot! *** -->
 | 
			
		||||
    <fieldType name="sfloat" class="solr.SortableFloatField" omitNorms="true"/>
 | 
			
		||||
    <!-- *** This fieldType is used by Sunspot! *** -->
 | 
			
		||||
    <fieldType name="sint" class="solr.SortableIntField" omitNorms="true"/>
 | 
			
		||||
    <!-- *** This fieldType is used by Sunspot! *** -->
 | 
			
		||||
    <fieldType name="slong" class="solr.SortableLongField" omitNorms="true"/>
 | 
			
		||||
    <!-- *** This fieldType is used by Sunspot! *** -->
 | 
			
		||||
    <fieldType name="tint" class="solr.TrieIntField" omitNorms="true"/>
 | 
			
		||||
    <!-- *** This fieldType is used by Sunspot! *** -->
 | 
			
		||||
    <fieldType name="tfloat" class="solr.TrieFloatField" omitNorms="true"/>
 | 
			
		||||
    <!-- *** This fieldType is used by Sunspot! *** -->
 | 
			
		||||
    <fieldType name="tdate" class="solr.TrieDateField" omitNorms="true"/>
 | 
			
		||||
  </types>
 | 
			
		||||
  <fields>
 | 
			
		||||
    <!-- Valid attributes for fields:
 | 
			
		||||
     name: mandatory - the name for the field
 | 
			
		||||
     type: mandatory - the name of a previously defined type from the 
 | 
			
		||||
       <types> section
 | 
			
		||||
     indexed: true if this field should be indexed (searchable or sortable)
 | 
			
		||||
     stored: true if this field should be retrievable
 | 
			
		||||
     compressed: [false] if this field should be stored using gzip compression
 | 
			
		||||
       (this will only apply if the field type is compressable; among
 | 
			
		||||
       the standard field types, only TextField and StrField are)
 | 
			
		||||
     multiValued: true if this field may contain multiple values per document
 | 
			
		||||
     omitNorms: (expert) set to true to omit the norms associated with
 | 
			
		||||
       this field (this disables length normalization and index-time
 | 
			
		||||
       boosting for the field, and saves some memory).  Only full-text
 | 
			
		||||
       fields or fields that need an index-time boost need norms.
 | 
			
		||||
     termVectors: [false] set to true to store the term vector for a
 | 
			
		||||
       given field.
 | 
			
		||||
       When using MoreLikeThis, fields used for similarity should be
 | 
			
		||||
       stored for best performance.
 | 
			
		||||
     termPositions: Store position information with the term vector.  
 | 
			
		||||
       This will increase storage costs.
 | 
			
		||||
     termOffsets: Store offset information with the term vector. This 
 | 
			
		||||
       will increase storage costs.
 | 
			
		||||
     default: a value that should be used if no value is specified
 | 
			
		||||
       when adding a document.
 | 
			
		||||
   -->
 | 
			
		||||
    <!-- *** This field is used by Sunspot! *** -->
 | 
			
		||||
    <field name="id" stored="true" type="string" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This field is used by Sunspot! *** -->
 | 
			
		||||
    <field name="type" stored="false" type="string" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This field is used by Sunspot! *** -->
 | 
			
		||||
    <field name="class_name" stored="false" type="string" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This field is used by Sunspot! *** -->
 | 
			
		||||
    <field name="text" stored="false" type="string" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This field is used by Sunspot! *** -->
 | 
			
		||||
    <field name="lat" stored="true" type="tdouble" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This field is used by Sunspot! *** -->
 | 
			
		||||
    <field name="lng" stored="true" type="tdouble" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="random_*" stored="false" type="rand" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="_local*" stored="false" type="tdouble" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_text" stored="false" type="text" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_texts" stored="true" type="text" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_b" stored="false" type="boolean" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_bm" stored="false" type="boolean" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_bs" stored="true" type="boolean" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_bms" stored="true" type="boolean" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_d" stored="false" type="date" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_dm" stored="false" type="date" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_ds" stored="true" type="date" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_dms" stored="true" type="date" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_e" stored="false" type="sdouble" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_em" stored="false" type="sdouble" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_es" stored="true" type="sdouble" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_ems" stored="true" type="sdouble" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_f" stored="false" type="sfloat" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_fm" stored="false" type="sfloat" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_fs" stored="true" type="sfloat" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_fms" stored="true" type="sfloat" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_i" stored="false" type="sint" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_im" stored="false" type="sint" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_is" stored="true" type="sint" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_ims" stored="true" type="sint" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_l" stored="false" type="slong" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_lm" stored="false" type="slong" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_ls" stored="true" type="slong" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_lms" stored="true" type="slong" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_s" stored="false" type="string" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_sm" stored="false" type="string" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_ss" stored="true" type="string" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_sms" stored="true" type="string" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_it" stored="false" type="tint" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_itm" stored="false" type="tint" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_its" stored="true" type="tint" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_itms" stored="true" type="tint" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_ft" stored="false" type="tfloat" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_ftm" stored="false" type="tfloat" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_fts" stored="true" type="tfloat" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_ftms" stored="true" type="tfloat" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_dt" stored="false" type="tdate" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_dtm" stored="false" type="tdate" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_dts" stored="true" type="tdate" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_dtms" stored="true" type="tdate" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_textv" stored="false" termVectors="true" type="text" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_textsv" stored="true" termVectors="true" type="text" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_et" stored="false" termVectors="true" type="tdouble" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_etm" stored="false" termVectors="true" type="tdouble" multiValued="true" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_ets" stored="true" termVectors="true" type="tdouble" multiValued="false" indexed="true"/>
 | 
			
		||||
    <!-- *** This dynamicField is used by Sunspot! *** -->
 | 
			
		||||
    <dynamicField name="*_etms" stored="true" termVectors="true" type="tdouble" multiValued="true" indexed="true"/>
 | 
			
		||||
  </fields>
 | 
			
		||||
  <!-- Field to use to determine and enforce document uniqueness. 
 | 
			
		||||
      Unless this field is marked with required="false", it will be a required field
 | 
			
		||||
   -->
 | 
			
		||||
  <uniqueKey>id</uniqueKey>
 | 
			
		||||
  <!-- field for the QueryParser to use when an explicit fieldname is absent -->
 | 
			
		||||
  <defaultSearchField>text</defaultSearchField>
 | 
			
		||||
  <!-- SolrQueryParser configuration: defaultOperator="AND|OR" -->
 | 
			
		||||
  <solrQueryParser defaultOperator="AND"/>
 | 
			
		||||
  <!-- copyField commands copy one field to another at the time a document
 | 
			
		||||
        is added to the index.  It's used either to index the same field differently,
 | 
			
		||||
        or to add multiple fields to the same field for easier/faster searching.  -->
 | 
			
		||||
</schema>
 | 
			
		||||
| 
						 | 
				
			
			@ -1,24 +0,0 @@
 | 
			
		|||
# Licensed to the Apache Software Foundation (ASF) under one or more
 | 
			
		||||
# contributor license agreements.  See the NOTICE file distributed with
 | 
			
		||||
# this work for additional information regarding copyright ownership.
 | 
			
		||||
# The ASF licenses this file to You under the Apache License, Version 2.0
 | 
			
		||||
# (the "License"); you may not use this file except in compliance with
 | 
			
		||||
# the License.  You may obtain a copy of the License at
 | 
			
		||||
#
 | 
			
		||||
#     http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
#
 | 
			
		||||
# Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
# distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
# See the License for the specific language governing permissions and
 | 
			
		||||
# limitations under the License.
 | 
			
		||||
 | 
			
		||||
user=
 | 
			
		||||
solr_hostname=localhost
 | 
			
		||||
solr_port=8983
 | 
			
		||||
rsyncd_port=18983
 | 
			
		||||
data_dir=
 | 
			
		||||
webapp_name=solr
 | 
			
		||||
master_host=
 | 
			
		||||
master_data_dir=
 | 
			
		||||
master_status_dir=
 | 
			
		||||
| 
						 | 
				
			
			@ -1,934 +0,0 @@
 | 
			
		|||
<?xml version="1.0" encoding="UTF-8"?>
 | 
			
		||||
<!--
 | 
			
		||||
 Licensed to the Apache Software Foundation (ASF) under one or more
 | 
			
		||||
 contributor license agreements.  See the NOTICE file distributed with
 | 
			
		||||
 this work for additional information regarding copyright ownership.
 | 
			
		||||
 The ASF licenses this file to You under the Apache License, Version 2.0
 | 
			
		||||
 (the "License"); you may not use this file except in compliance with
 | 
			
		||||
 the License.  You may obtain a copy of the License at
 | 
			
		||||
 | 
			
		||||
     http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
 | 
			
		||||
 Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
 distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
 See the License for the specific language governing permissions and
 | 
			
		||||
 limitations under the License.
 | 
			
		||||
-->
 | 
			
		||||
<!-- 
 | 
			
		||||
     For more details about configurations options that may appear in this 
 | 
			
		||||
     file, see http://wiki.apache.org/solr/SolrConfigXml.
 | 
			
		||||
 | 
			
		||||
     Specifically, the Solr Config can support XInclude, which may make it easier to manage
 | 
			
		||||
     the configuration.  See https://issues.apache.org/jira/browse/SOLR-1167
 | 
			
		||||
-->
 | 
			
		||||
<config>
 | 
			
		||||
  <!-- Set this to 'false' if you want solr to continue working after it has 
 | 
			
		||||
       encountered an severe configuration error.  In a production environment, 
 | 
			
		||||
       you may want solr to keep working even if one handler is mis-configured.
 | 
			
		||||
 | 
			
		||||
       You may also set this to false using by setting the system property:
 | 
			
		||||
         -Dsolr.abortOnConfigurationError=false
 | 
			
		||||
     -->
 | 
			
		||||
  <abortOnConfigurationError>${solr.abortOnConfigurationError:true}</abortOnConfigurationError>
 | 
			
		||||
  <!-- lib directives can be used to instruct Solr to load an Jars identified
 | 
			
		||||
       and use them to resolve any "plugins" specified in your solrconfig.xml or
 | 
			
		||||
       schema.xml (ie: Analyzers, Request Handlers, etc...).
 | 
			
		||||
 | 
			
		||||
       All directories and paths are resolved relative the instanceDir.
 | 
			
		||||
 | 
			
		||||
       If a "./lib" directory exists in your instanceDir, all files found in it
 | 
			
		||||
       are included as if you had used the following syntax...
 | 
			
		||||
       
 | 
			
		||||
              <lib dir="./lib" />
 | 
			
		||||
    -->
 | 
			
		||||
  <!-- A dir option by itself adds any files found in the directory to the
 | 
			
		||||
       classpath, this is useful for including all jars in a directory.
 | 
			
		||||
    -->
 | 
			
		||||
  <lib dir="../../contrib/extraction/lib"/>
 | 
			
		||||
  <!-- When a regex is specified in addition to a directory, only the files in that
 | 
			
		||||
       directory which completely match the regex (anchored on both ends)
 | 
			
		||||
       will be included.
 | 
			
		||||
    -->
 | 
			
		||||
  <lib dir="../../dist/" regex="apache-solr-cell-\d.*\.jar"/>
 | 
			
		||||
  <lib dir="../../dist/" regex="apache-solr-clustering-\d.*\.jar"/>
 | 
			
		||||
  <!-- If a dir option (with or without a regex) is used and nothing is found
 | 
			
		||||
       that matches, it will be ignored
 | 
			
		||||
    -->
 | 
			
		||||
  <lib dir="../../contrib/clustering/lib/downloads/"/>
 | 
			
		||||
  <lib dir="../../contrib/clustering/lib/"/>
 | 
			
		||||
  <lib dir="/total/crap/dir/ignored"/>
 | 
			
		||||
  <!-- an exact path can be used to specify a specific file.  This will cause
 | 
			
		||||
       a serious error to be logged if it can't be loaded.
 | 
			
		||||
  <lib path="../a-jar-that-does-not-exist.jar" /> 
 | 
			
		||||
  -->
 | 
			
		||||
  <!-- Used to specify an alternate directory to hold all index data
 | 
			
		||||
       other than the default ./data under the Solr home.
 | 
			
		||||
       If replication is in use, this should match the replication configuration. -->
 | 
			
		||||
  <dataDir>${solr.data.dir:./solr/data}</dataDir>
 | 
			
		||||
  <!-- WARNING: this <indexDefaults> section only provides defaults for index writers
 | 
			
		||||
       in general. See also the <mainIndex> section after that when changing parameters
 | 
			
		||||
       for Solr's main Lucene index. -->
 | 
			
		||||
  <indexDefaults>
 | 
			
		||||
    <!-- Values here affect all index writers and act as a default unless overridden. -->
 | 
			
		||||
    <useCompoundFile>false</useCompoundFile>
 | 
			
		||||
    <mergeFactor>10</mergeFactor>
 | 
			
		||||
    <!-- If both ramBufferSizeMB and maxBufferedDocs is set, then Lucene will flush
 | 
			
		||||
     based on whichever limit is hit first.  -->
 | 
			
		||||
    <!--<maxBufferedDocs>1000</maxBufferedDocs>-->
 | 
			
		||||
    <!-- Sets the amount of RAM that may be used by Lucene indexing
 | 
			
		||||
      for buffering added documents and deletions before they are
 | 
			
		||||
      flushed to the Directory.  -->
 | 
			
		||||
    <ramBufferSizeMB>32</ramBufferSizeMB>
 | 
			
		||||
    <!-- <maxMergeDocs>2147483647</maxMergeDocs> -->
 | 
			
		||||
    <maxFieldLength>10000</maxFieldLength>
 | 
			
		||||
    <writeLockTimeout>1000</writeLockTimeout>
 | 
			
		||||
    <commitLockTimeout>10000</commitLockTimeout>
 | 
			
		||||
    <!--
 | 
			
		||||
     Expert: Turn on Lucene's auto commit capability.  This causes intermediate
 | 
			
		||||
     segment flushes to write a new lucene index descriptor, enabling it to be
 | 
			
		||||
     opened by an external IndexReader.  This can greatly slow down indexing
 | 
			
		||||
     speed.  NOTE: Despite the name, this value does not have any relation to
 | 
			
		||||
     Solr's autoCommit functionality
 | 
			
		||||
     -->
 | 
			
		||||
    <!--<luceneAutoCommit>false</luceneAutoCommit>-->
 | 
			
		||||
    <!--
 | 
			
		||||
     Expert: The Merge Policy in Lucene controls how merging is handled by
 | 
			
		||||
     Lucene.  The default in 2.3 is the LogByteSizeMergePolicy, previous
 | 
			
		||||
     versions used LogDocMergePolicy.
 | 
			
		||||
 | 
			
		||||
     LogByteSizeMergePolicy chooses segments to merge based on their size.  The
 | 
			
		||||
     Lucene 2.2 default, LogDocMergePolicy chose when to merge based on number
 | 
			
		||||
     of documents
 | 
			
		||||
 | 
			
		||||
     Other implementations of MergePolicy must have a no-argument constructor
 | 
			
		||||
     -->
 | 
			
		||||
    <!--<mergePolicy class="org.apache.lucene.index.LogByteSizeMergePolicy"/>-->
 | 
			
		||||
    <!--
 | 
			
		||||
     Expert:
 | 
			
		||||
     The Merge Scheduler in Lucene controls how merges are performed.  The
 | 
			
		||||
     ConcurrentMergeScheduler (Lucene 2.3 default) can perform merges in the
 | 
			
		||||
     background using separate threads.  The SerialMergeScheduler (Lucene 2.2
 | 
			
		||||
     default) does not.
 | 
			
		||||
     -->
 | 
			
		||||
    <!--<mergeScheduler class="org.apache.lucene.index.ConcurrentMergeScheduler"/>-->
 | 
			
		||||
    <!--
 | 
			
		||||
      This option specifies which Lucene LockFactory implementation to use.
 | 
			
		||||
      
 | 
			
		||||
      single = SingleInstanceLockFactory - suggested for a read-only index
 | 
			
		||||
               or when there is no possibility of another process trying
 | 
			
		||||
               to modify the index.
 | 
			
		||||
      native = NativeFSLockFactory  - uses OS native file locking
 | 
			
		||||
      simple = SimpleFSLockFactory  - uses a plain file for locking
 | 
			
		||||
 | 
			
		||||
      (For backwards compatibility with Solr 1.2, 'simple' is the default
 | 
			
		||||
       if not specified.)
 | 
			
		||||
    -->
 | 
			
		||||
    <lockType>native</lockType>
 | 
			
		||||
    <!--
 | 
			
		||||
     Expert:
 | 
			
		||||
    Controls how often Lucene loads terms into memory -->
 | 
			
		||||
    <!--<termIndexInterval>256</termIndexInterval>-->
 | 
			
		||||
  </indexDefaults>
 | 
			
		||||
  <mainIndex>
 | 
			
		||||
    <!-- options specific to the main on-disk lucene index -->
 | 
			
		||||
    <useCompoundFile>false</useCompoundFile>
 | 
			
		||||
    <ramBufferSizeMB>32</ramBufferSizeMB>
 | 
			
		||||
    <mergeFactor>10</mergeFactor>
 | 
			
		||||
    <!-- Deprecated -->
 | 
			
		||||
    <!--<maxBufferedDocs>1000</maxBufferedDocs>-->
 | 
			
		||||
    <!--<maxMergeDocs>2147483647</maxMergeDocs>-->
 | 
			
		||||
    <!-- inherit from indexDefaults <maxFieldLength>10000</maxFieldLength> -->
 | 
			
		||||
    <!-- If true, unlock any held write or commit locks on startup. 
 | 
			
		||||
         This defeats the locking mechanism that allows multiple
 | 
			
		||||
         processes to safely access a lucene index, and should be
 | 
			
		||||
         used with care.
 | 
			
		||||
         This is not needed if lock type is 'none' or 'single'
 | 
			
		||||
     -->
 | 
			
		||||
    <unlockOnStartup>false</unlockOnStartup>
 | 
			
		||||
    <!-- If true, IndexReaders will be reopened (often more efficient) instead
 | 
			
		||||
         of closed and then opened.  -->
 | 
			
		||||
    <reopenReaders>true</reopenReaders>
 | 
			
		||||
    <!--
 | 
			
		||||
     Expert:
 | 
			
		||||
    Controls how often Lucene loads terms into memory.  Default is 128 and is likely good for most everyone. -->
 | 
			
		||||
    <!--<termIndexInterval>256</termIndexInterval>-->
 | 
			
		||||
    <!--
 | 
			
		||||
        Custom deletion policies can specified here. The class must
 | 
			
		||||
        implement org.apache.lucene.index.IndexDeletionPolicy.
 | 
			
		||||
 | 
			
		||||
        http://lucene.apache.org/java/2_3_2/api/org/apache/lucene/index/IndexDeletionPolicy.html
 | 
			
		||||
 | 
			
		||||
        The standard Solr IndexDeletionPolicy implementation supports deleting
 | 
			
		||||
        index commit points on number of commits, age of commit point and
 | 
			
		||||
        optimized status.
 | 
			
		||||
 | 
			
		||||
        The latest commit point should always be preserved regardless
 | 
			
		||||
        of the criteria.
 | 
			
		||||
    -->
 | 
			
		||||
    <deletionPolicy class="solr.SolrDeletionPolicy">
 | 
			
		||||
      <!-- The number of commit points to be kept -->
 | 
			
		||||
      <str name="maxCommitsToKeep">1</str>
 | 
			
		||||
      <!-- The number of optimized commit points to be kept -->
 | 
			
		||||
      <str name="maxOptimizedCommitsToKeep">0</str>
 | 
			
		||||
      <!--
 | 
			
		||||
          Delete all commit points once they have reached the given age.
 | 
			
		||||
          Supports DateMathParser syntax e.g.
 | 
			
		||||
          
 | 
			
		||||
          <str name="maxCommitAge">30MINUTES</str>
 | 
			
		||||
          <str name="maxCommitAge">1DAY</str>
 | 
			
		||||
      -->
 | 
			
		||||
    </deletionPolicy>
 | 
			
		||||
    <!--  To aid in advanced debugging, you may turn on IndexWriter debug logging.
 | 
			
		||||
      Setting to true will set the file that the underlying Lucene IndexWriter
 | 
			
		||||
      will write its debug infostream to.  -->
 | 
			
		||||
    <infoStream file="INFOSTREAM.txt">false</infoStream>
 | 
			
		||||
  </mainIndex>
 | 
			
		||||
  <!--	Enables JMX if and only if an existing MBeanServer is found, use this
 | 
			
		||||
    if you want to configure JMX through JVM parameters. Remove this to disable
 | 
			
		||||
    exposing Solr configuration and statistics to JMX.
 | 
			
		||||
 | 
			
		||||
		If you want to connect to a particular server, specify the agentId
 | 
			
		||||
		e.g. <jmx agentId="myAgent" />
 | 
			
		||||
 | 
			
		||||
		If you want to start a new MBeanServer, specify the serviceUrl
 | 
			
		||||
		e.g <jmx serviceUrl="service:jmx:rmi:///jndi/rmi://localhost:9999/solr"/>
 | 
			
		||||
 | 
			
		||||
		For more details see http://wiki.apache.org/solr/SolrJmx
 | 
			
		||||
  -->
 | 
			
		||||
  <jmx/>
 | 
			
		||||
  <!-- the default high-performance update handler -->
 | 
			
		||||
  <updateHandler class="solr.DirectUpdateHandler2">
 | 
			
		||||
    <!-- A prefix of "solr." for class names is an alias that
 | 
			
		||||
         causes solr to search appropriate packages, including
 | 
			
		||||
         org.apache.solr.(search|update|request|core|analysis)
 | 
			
		||||
     -->
 | 
			
		||||
    <!-- Perform a <commit/> automatically under certain conditions:
 | 
			
		||||
         maxDocs - number of updates since last commit is greater than this
 | 
			
		||||
         maxTime - oldest uncommited update (in ms) is this long ago
 | 
			
		||||
         Instead of enabling autoCommit, consider using "commitWithin"
 | 
			
		||||
         when adding documents. http://wiki.apache.org/solr/UpdateXmlMessages
 | 
			
		||||
    <autoCommit> 
 | 
			
		||||
      <maxDocs>10000</maxDocs>
 | 
			
		||||
      <maxTime>1000</maxTime> 
 | 
			
		||||
    </autoCommit>
 | 
			
		||||
    -->
 | 
			
		||||
    <!-- The RunExecutableListener executes an external command from a
 | 
			
		||||
      hook such as postCommit or postOptimize.
 | 
			
		||||
         exe - the name of the executable to run
 | 
			
		||||
         dir - dir to use as the current working directory. default="."
 | 
			
		||||
         wait - the calling thread waits until the executable returns. default="true"
 | 
			
		||||
         args - the arguments to pass to the program.  default=nothing
 | 
			
		||||
         env - environment variables to set.  default=nothing
 | 
			
		||||
      -->
 | 
			
		||||
    <!-- A postCommit event is fired after every commit or optimize command
 | 
			
		||||
    <listener event="postCommit" class="solr.RunExecutableListener">
 | 
			
		||||
      <str name="exe">solr/bin/snapshooter</str>
 | 
			
		||||
      <str name="dir">.</str>
 | 
			
		||||
      <bool name="wait">true</bool>
 | 
			
		||||
      <arr name="args"> <str>arg1</str> <str>arg2</str> </arr>
 | 
			
		||||
      <arr name="env"> <str>MYVAR=val1</str> </arr>
 | 
			
		||||
    </listener>
 | 
			
		||||
    -->
 | 
			
		||||
    <!-- A postOptimize event is fired only after every optimize command
 | 
			
		||||
    <listener event="postOptimize" class="solr.RunExecutableListener">
 | 
			
		||||
      <str name="exe">snapshooter</str>
 | 
			
		||||
      <str name="dir">solr/bin</str>
 | 
			
		||||
      <bool name="wait">true</bool>
 | 
			
		||||
    </listener>
 | 
			
		||||
    -->
 | 
			
		||||
  </updateHandler>
 | 
			
		||||
  <!-- Use the following format to specify a custom IndexReaderFactory - allows for alternate
 | 
			
		||||
       IndexReader implementations.
 | 
			
		||||
 | 
			
		||||
       ** Experimental Feature **
 | 
			
		||||
       Please note - Using a custom IndexReaderFactory may prevent certain other features
 | 
			
		||||
       from working. The API to IndexReaderFactory may change without warning or may even
 | 
			
		||||
       be removed from future releases if the problems cannot be resolved.
 | 
			
		||||
 | 
			
		||||
       ** Features that may not work with custom IndexReaderFactory **
 | 
			
		||||
       The ReplicationHandler assumes a disk-resident index. Using a custom
 | 
			
		||||
       IndexReader implementation may cause incompatibility with ReplicationHandler and
 | 
			
		||||
       may cause replication to not work correctly. See SOLR-1366 for details.
 | 
			
		||||
 | 
			
		||||
  <indexReaderFactory name="IndexReaderFactory" class="package.class">
 | 
			
		||||
    Parameters as required by the implementation
 | 
			
		||||
  </indexReaderFactory >
 | 
			
		||||
  -->
 | 
			
		||||
  <!-- To set the termInfosIndexDivisor, do this: -->
 | 
			
		||||
  <!--<indexReaderFactory name="IndexReaderFactory" class="org.apache.solr.core.StandardIndexReaderFactory">
 | 
			
		||||
    <int name="termInfosIndexDivisor">12</int>
 | 
			
		||||
  </indexReaderFactory >-->
 | 
			
		||||
  <query>
 | 
			
		||||
    <!-- Maximum number of clauses in a boolean query... in the past, this affected
 | 
			
		||||
        range or prefix queries that expanded to big boolean queries - built in Solr 
 | 
			
		||||
        query parsers no longer create queries with this limitation. 
 | 
			
		||||
        An exception is thrown if exceeded.  -->
 | 
			
		||||
    <maxBooleanClauses>1024</maxBooleanClauses>
 | 
			
		||||
    <!-- There are two implementations of cache available for Solr,
 | 
			
		||||
         LRUCache, based on a synchronized LinkedHashMap, and
 | 
			
		||||
         FastLRUCache, based on a ConcurrentHashMap.  FastLRUCache has faster gets
 | 
			
		||||
         and slower puts in single threaded operation and thus is generally faster
 | 
			
		||||
         than LRUCache when the hit ratio of the cache is high (> 75%), and may be
 | 
			
		||||
         faster under other scenarios on multi-cpu systems. -->
 | 
			
		||||
    <!-- Cache used by SolrIndexSearcher for filters (DocSets),
 | 
			
		||||
         unordered sets of *all* documents that match a query.
 | 
			
		||||
         When a new searcher is opened, its caches may be prepopulated
 | 
			
		||||
         or "autowarmed" using data from caches in the old searcher.
 | 
			
		||||
         autowarmCount is the number of items to prepopulate.  For LRUCache,
 | 
			
		||||
         the autowarmed items will be the most recently accessed items.
 | 
			
		||||
       Parameters:
 | 
			
		||||
         class - the SolrCache implementation LRUCache or FastLRUCache
 | 
			
		||||
         size - the maximum number of entries in the cache
 | 
			
		||||
         initialSize - the initial capacity (number of entries) of
 | 
			
		||||
           the cache.  (seel java.util.HashMap)
 | 
			
		||||
         autowarmCount - the number of entries to prepopulate from
 | 
			
		||||
           and old cache.
 | 
			
		||||
         -->
 | 
			
		||||
    <filterCache class="solr.FastLRUCache" size="512" initialSize="512" autowarmCount="0"/>
 | 
			
		||||
    <!-- Cache used to hold field values that are quickly accessible
 | 
			
		||||
         by document id.  The fieldValueCache is created by default
 | 
			
		||||
         even if not configured here.
 | 
			
		||||
      <fieldValueCache
 | 
			
		||||
        class="solr.FastLRUCache"
 | 
			
		||||
        size="512"
 | 
			
		||||
        autowarmCount="128"
 | 
			
		||||
        showItems="32"
 | 
			
		||||
      />
 | 
			
		||||
    -->
 | 
			
		||||
    <!-- queryResultCache caches results of searches - ordered lists of
 | 
			
		||||
         document ids (DocList) based on a query, a sort, and the range
 | 
			
		||||
         of documents requested.  -->
 | 
			
		||||
    <queryResultCache class="solr.LRUCache" size="512" initialSize="512" autowarmCount="0"/>
 | 
			
		||||
    <!-- documentCache caches Lucene Document objects (the stored fields for each document).
 | 
			
		||||
       Since Lucene internal document ids are transient, this cache will not be autowarmed.  -->
 | 
			
		||||
    <documentCache class="solr.LRUCache" size="512" initialSize="512" autowarmCount="0"/>
 | 
			
		||||
    <!-- If true, stored fields that are not requested will be loaded lazily.
 | 
			
		||||
      This can result in a significant speed improvement if the usual case is to
 | 
			
		||||
      not load all stored fields, especially if the skipped fields are large
 | 
			
		||||
      compressed text fields.
 | 
			
		||||
    -->
 | 
			
		||||
    <enableLazyFieldLoading>true</enableLazyFieldLoading>
 | 
			
		||||
    <!-- Example of a generic cache.  These caches may be accessed by name
 | 
			
		||||
         through SolrIndexSearcher.getCache(),cacheLookup(), and cacheInsert().
 | 
			
		||||
         The purpose is to enable easy caching of user/application level data.
 | 
			
		||||
         The regenerator argument should be specified as an implementation
 | 
			
		||||
         of solr.search.CacheRegenerator if autowarming is desired.  -->
 | 
			
		||||
    <!--
 | 
			
		||||
    <cache name="myUserCache"
 | 
			
		||||
      class="solr.LRUCache"
 | 
			
		||||
      size="4096"
 | 
			
		||||
      initialSize="1024"
 | 
			
		||||
      autowarmCount="1024"
 | 
			
		||||
      regenerator="org.mycompany.mypackage.MyRegenerator"
 | 
			
		||||
      />
 | 
			
		||||
    -->
 | 
			
		||||
    <!-- An optimization that attempts to use a filter to satisfy a search.
 | 
			
		||||
         If the requested sort does not include score, then the filterCache
 | 
			
		||||
         will be checked for a filter matching the query. If found, the filter
 | 
			
		||||
         will be used as the source of document ids, and then the sort will be
 | 
			
		||||
         applied to that.
 | 
			
		||||
    <useFilterForSortedQuery>true</useFilterForSortedQuery>
 | 
			
		||||
   -->
 | 
			
		||||
    <!-- An optimization for use with the queryResultCache.  When a search
 | 
			
		||||
         is requested, a superset of the requested number of document ids
 | 
			
		||||
         are collected.  For example, if a search for a particular query
 | 
			
		||||
         requests matching documents 10 through 19, and queryWindowSize is 50,
 | 
			
		||||
         then documents 0 through 49 will be collected and cached.  Any further
 | 
			
		||||
         requests in that range can be satisfied via the cache.  -->
 | 
			
		||||
    <queryResultWindowSize>20</queryResultWindowSize>
 | 
			
		||||
    <!-- Maximum number of documents to cache for any entry in the
 | 
			
		||||
         queryResultCache. -->
 | 
			
		||||
    <queryResultMaxDocsCached>200</queryResultMaxDocsCached>
 | 
			
		||||
    <!-- a newSearcher event is fired whenever a new searcher is being prepared
 | 
			
		||||
      and there is a current searcher handling requests (aka registered).
 | 
			
		||||
      It can be used to prime certain caches to prevent long request times for
 | 
			
		||||
      certain requests.
 | 
			
		||||
    -->
 | 
			
		||||
    <!-- QuerySenderListener takes an array of NamedList and executes a
 | 
			
		||||
         local query request for each NamedList in sequence. -->
 | 
			
		||||
    <listener event="newSearcher" class="solr.QuerySenderListener">
 | 
			
		||||
      <arr name="queries">
 | 
			
		||||
        <!--
 | 
			
		||||
        <lst> <str name="q">solr</str> <str name="start">0</str> <str name="rows">10</str> </lst>
 | 
			
		||||
        <lst> <str name="q">rocks</str> <str name="start">0</str> <str name="rows">10</str> </lst>
 | 
			
		||||
        <lst><str name="q">static newSearcher warming query from solrconfig.xml</str></lst>
 | 
			
		||||
        -->
 | 
			
		||||
      </arr>
 | 
			
		||||
    </listener>
 | 
			
		||||
    <!-- a firstSearcher event is fired whenever a new searcher is being
 | 
			
		||||
         prepared but there is no current registered searcher to handle
 | 
			
		||||
         requests or to gain autowarming data from. -->
 | 
			
		||||
    <listener event="firstSearcher" class="solr.QuerySenderListener">
 | 
			
		||||
      <arr name="queries">
 | 
			
		||||
        <lst>
 | 
			
		||||
          <str name="q">solr rocks</str>
 | 
			
		||||
          <str name="start">0</str>
 | 
			
		||||
          <str name="rows">10</str>
 | 
			
		||||
        </lst>
 | 
			
		||||
        <lst>
 | 
			
		||||
          <str name="q">static firstSearcher warming query from solrconfig.xml</str>
 | 
			
		||||
        </lst>
 | 
			
		||||
      </arr>
 | 
			
		||||
    </listener>
 | 
			
		||||
    <!-- If a search request comes in and there is no current registered searcher,
 | 
			
		||||
         then immediately register the still warming searcher and use it.  If
 | 
			
		||||
         "false" then all requests will block until the first searcher is done
 | 
			
		||||
         warming. -->
 | 
			
		||||
    <useColdSearcher>false</useColdSearcher>
 | 
			
		||||
    <!-- Maximum number of searchers that may be warming in the background
 | 
			
		||||
      concurrently.  An error is returned if this limit is exceeded. Recommend
 | 
			
		||||
      1-2 for read-only slaves, higher for masters w/o cache warming. -->
 | 
			
		||||
    <maxWarmingSearchers>2</maxWarmingSearchers>
 | 
			
		||||
  </query>
 | 
			
		||||
  <!-- 
 | 
			
		||||
    Let the dispatch filter handler /select?qt=XXX
 | 
			
		||||
    handleSelect=true will use consistent error handling for /select and /update
 | 
			
		||||
    handleSelect=false will use solr1.1 style error formatting
 | 
			
		||||
    -->
 | 
			
		||||
  <requestDispatcher handleSelect="true">
 | 
			
		||||
    <!--Make sure your system has some authentication before enabling remote streaming!  -->
 | 
			
		||||
    <requestParsers enableRemoteStreaming="true" multipartUploadLimitInKB="2048000"/>
 | 
			
		||||
    <!-- Set HTTP caching related parameters (for proxy caches and clients).
 | 
			
		||||
          
 | 
			
		||||
         To get the behaviour of Solr 1.2 (ie: no caching related headers)
 | 
			
		||||
         use the never304="true" option and do not specify a value for
 | 
			
		||||
         <cacheControl>
 | 
			
		||||
    -->
 | 
			
		||||
    <!-- <httpCaching never304="true"> -->
 | 
			
		||||
    <httpCaching lastModifiedFrom="openTime" etagSeed="Solr">
 | 
			
		||||
      <!-- lastModFrom="openTime" is the default, the Last-Modified value
 | 
			
		||||
            (and validation against If-Modified-Since requests) will all be
 | 
			
		||||
            relative to when the current Searcher was opened.
 | 
			
		||||
            You can change it to lastModFrom="dirLastMod" if you want the
 | 
			
		||||
            value to exactly corrispond to when the physical index was last
 | 
			
		||||
            modified.
 | 
			
		||||
 | 
			
		||||
            etagSeed="..." is an option you can change to force the ETag
 | 
			
		||||
            header (and validation against If-None-Match requests) to be
 | 
			
		||||
            differnet even if the index has not changed (ie: when making
 | 
			
		||||
            significant changes to your config file)
 | 
			
		||||
 | 
			
		||||
            lastModifiedFrom and etagSeed are both ignored if you use the
 | 
			
		||||
            never304="true" option.
 | 
			
		||||
       -->
 | 
			
		||||
      <!-- If you include a <cacheControl> directive, it will be used to
 | 
			
		||||
            generate a Cache-Control header, as well as an Expires header
 | 
			
		||||
            if the value contains "max-age="
 | 
			
		||||
 | 
			
		||||
            By default, no Cache-Control header is generated.
 | 
			
		||||
 | 
			
		||||
            You can use the <cacheControl> option even if you have set
 | 
			
		||||
            never304="true"
 | 
			
		||||
       -->
 | 
			
		||||
      <!-- <cacheControl>max-age=30, public</cacheControl> -->
 | 
			
		||||
    </httpCaching>
 | 
			
		||||
  </requestDispatcher>
 | 
			
		||||
  <!-- requestHandler plugins... incoming queries will be dispatched to the
 | 
			
		||||
     correct handler based on the path or the qt (query type) param.
 | 
			
		||||
     Names starting with a '/' are accessed with the a path equal to the 
 | 
			
		||||
     registered name.  Names without a leading '/' are accessed with:
 | 
			
		||||
      http://host/app/select?qt=name
 | 
			
		||||
     If no qt is defined, the requestHandler that declares default="true"
 | 
			
		||||
     will be used.
 | 
			
		||||
  -->
 | 
			
		||||
  <requestHandler name="standard" class="solr.SearchHandler" default="true">
 | 
			
		||||
    <!-- default values for query parameters -->
 | 
			
		||||
    <lst name="defaults">
 | 
			
		||||
      <str name="echoParams">explicit</str>
 | 
			
		||||
      <!--
 | 
			
		||||
       <int name="rows">10</int>
 | 
			
		||||
       <str name="fl">*</str>
 | 
			
		||||
       <str name="version">2.1</str>
 | 
			
		||||
        -->
 | 
			
		||||
    </lst>
 | 
			
		||||
  </requestHandler>
 | 
			
		||||
  <!-- Please refer to http://wiki.apache.org/solr/SolrReplication for details on configuring replication -->
 | 
			
		||||
  <!-- remove the <lst name="master"> section if this is just a slave -->
 | 
			
		||||
  <!-- remove  the <lst name="slave"> section if this is just a master -->
 | 
			
		||||
  <!--
 | 
			
		||||
<requestHandler name="/replication" class="solr.ReplicationHandler" >
 | 
			
		||||
    <lst name="master">
 | 
			
		||||
      <str name="replicateAfter">commit</str>
 | 
			
		||||
      <str name="replicateAfter">startup</str>
 | 
			
		||||
      <str name="confFiles">schema.xml,stopwords.txt</str>
 | 
			
		||||
    </lst>
 | 
			
		||||
    <lst name="slave">
 | 
			
		||||
      <str name="masterUrl">http://localhost:8983/solr/replication</str>
 | 
			
		||||
      <str name="pollInterval">00:00:60</str>
 | 
			
		||||
    </lst>
 | 
			
		||||
</requestHandler>-->
 | 
			
		||||
  <!-- DisMaxRequestHandler allows easy searching across multiple fields
 | 
			
		||||
       for simple user-entered phrases.  It's implementation is now
 | 
			
		||||
       just the standard SearchHandler with a default query type
 | 
			
		||||
       of "dismax". 
 | 
			
		||||
       see http://wiki.apache.org/solr/DisMaxRequestHandler
 | 
			
		||||
   -->
 | 
			
		||||
  <requestHandler name="dismax" class="solr.SearchHandler">
 | 
			
		||||
    <lst name="defaults">
 | 
			
		||||
      <str name="defType">dismax</str>
 | 
			
		||||
      <str name="echoParams">explicit</str>
 | 
			
		||||
      <float name="tie">0.01</float>
 | 
			
		||||
      <str name="qf">
 | 
			
		||||
        text^0.5 features^1.0 name^1.2 sku^1.5 id^10.0 manu^1.1 cat^1.4
 | 
			
		||||
     </str>
 | 
			
		||||
      <str name="pf">
 | 
			
		||||
        text^0.2 features^1.1 name^1.5 manu^1.4 manu_exact^1.9
 | 
			
		||||
     </str>
 | 
			
		||||
      <str name="bf">
 | 
			
		||||
        popularity^0.5 recip(price,1,1000,1000)^0.3
 | 
			
		||||
     </str>
 | 
			
		||||
      <str name="fl">
 | 
			
		||||
        id,name,price,score
 | 
			
		||||
     </str>
 | 
			
		||||
      <str name="mm">
 | 
			
		||||
        2<-1 5<-2 6<90%
 | 
			
		||||
     </str>
 | 
			
		||||
      <int name="ps">100</int>
 | 
			
		||||
      <str name="q.alt">*:*</str>
 | 
			
		||||
      <!-- example highlighter config, enable per-query with hl=true -->
 | 
			
		||||
      <str name="hl.fl">text features name</str>
 | 
			
		||||
      <!-- for this field, we want no fragmenting, just highlighting -->
 | 
			
		||||
      <str name="f.name.hl.fragsize">0</str>
 | 
			
		||||
      <!-- instructs Solr to return the field itself if no query terms are
 | 
			
		||||
          found -->
 | 
			
		||||
      <str name="f.name.hl.alternateField">name</str>
 | 
			
		||||
      <str name="f.text.hl.fragmenter">regex</str>
 | 
			
		||||
      <!-- defined below -->
 | 
			
		||||
    </lst>
 | 
			
		||||
  </requestHandler>
 | 
			
		||||
  <!-- Note how you can register the same handler multiple times with
 | 
			
		||||
       different names (and different init parameters)
 | 
			
		||||
    -->
 | 
			
		||||
  <requestHandler name="partitioned" class="solr.SearchHandler">
 | 
			
		||||
    <lst name="defaults">
 | 
			
		||||
      <str name="defType">dismax</str>
 | 
			
		||||
      <str name="echoParams">explicit</str>
 | 
			
		||||
      <str name="qf">text^0.5 features^1.0 name^1.2 sku^1.5 id^10.0</str>
 | 
			
		||||
      <str name="mm">2<-1 5<-2 6<90%</str>
 | 
			
		||||
      <!-- This is an example of using Date Math to specify a constantly
 | 
			
		||||
          moving date range in a config...
 | 
			
		||||
       -->
 | 
			
		||||
      <str name="bq">incubationdate_dt:[* TO NOW/DAY-1MONTH]^2.2</str>
 | 
			
		||||
    </lst>
 | 
			
		||||
    <!-- In addition to defaults, "appends" params can be specified
 | 
			
		||||
         to identify values which should be appended to the list of
 | 
			
		||||
         multi-val params from the query (or the existing "defaults").
 | 
			
		||||
 | 
			
		||||
         In this example, the param "fq=instock:true" will be appended to
 | 
			
		||||
         any query time fq params the user may specify, as a mechanism for
 | 
			
		||||
         partitioning the index, independent of any user selected filtering
 | 
			
		||||
         that may also be desired (perhaps as a result of faceted searching).
 | 
			
		||||
 | 
			
		||||
         NOTE: there is *absolutely* nothing a client can do to prevent these
 | 
			
		||||
         "appends" values from being used, so don't use this mechanism
 | 
			
		||||
         unless you are sure you always want it.
 | 
			
		||||
      -->
 | 
			
		||||
    <lst name="appends">
 | 
			
		||||
      <str name="fq">inStock:true</str>
 | 
			
		||||
    </lst>
 | 
			
		||||
    <!-- "invariants" are a way of letting the Solr maintainer lock down
 | 
			
		||||
         the options available to Solr clients.  Any params values
 | 
			
		||||
         specified here are used regardless of what values may be specified
 | 
			
		||||
         in either the query, the "defaults", or the "appends" params.
 | 
			
		||||
 | 
			
		||||
         In this example, the facet.field and facet.query params are fixed,
 | 
			
		||||
         limiting the facets clients can use.  Faceting is not turned on by
 | 
			
		||||
         default - but if the client does specify facet=true in the request,
 | 
			
		||||
         these are the only facets they will be able to see counts for;
 | 
			
		||||
         regardless of what other facet.field or facet.query params they
 | 
			
		||||
         may specify.
 | 
			
		||||
 | 
			
		||||
         NOTE: there is *absolutely* nothing a client can do to prevent these
 | 
			
		||||
         "invariants" values from being used, so don't use this mechanism
 | 
			
		||||
         unless you are sure you always want it.
 | 
			
		||||
      -->
 | 
			
		||||
    <lst name="invariants">
 | 
			
		||||
      <str name="facet.field">cat</str>
 | 
			
		||||
      <str name="facet.field">manu_exact</str>
 | 
			
		||||
      <str name="facet.query">price:[* TO 500]</str>
 | 
			
		||||
      <str name="facet.query">price:[500 TO *]</str>
 | 
			
		||||
    </lst>
 | 
			
		||||
  </requestHandler>
 | 
			
		||||
  <!--
 | 
			
		||||
   Search components are registered to SolrCore and used by Search Handlers
 | 
			
		||||
   
 | 
			
		||||
   By default, the following components are avaliable:
 | 
			
		||||
    
 | 
			
		||||
   <searchComponent name="query"     class="org.apache.solr.handler.component.QueryComponent" />
 | 
			
		||||
   <searchComponent name="facet"     class="org.apache.solr.handler.component.FacetComponent" />
 | 
			
		||||
   <searchComponent name="mlt"       class="org.apache.solr.handler.component.MoreLikeThisComponent" />
 | 
			
		||||
   <searchComponent name="highlight" class="org.apache.solr.handler.component.HighlightComponent" />
 | 
			
		||||
   <searchComponent name="stats"     class="org.apache.solr.handler.component.StatsComponent" />
 | 
			
		||||
   <searchComponent name="debug"     class="org.apache.solr.handler.component.DebugComponent" />
 | 
			
		||||
   
 | 
			
		||||
   Default configuration in a requestHandler would look like:
 | 
			
		||||
    <arr name="components">
 | 
			
		||||
      <str>query</str>
 | 
			
		||||
      <str>facet</str>
 | 
			
		||||
      <str>mlt</str>
 | 
			
		||||
      <str>highlight</str>
 | 
			
		||||
      <str>stats</str>
 | 
			
		||||
      <str>debug</str>
 | 
			
		||||
    </arr>
 | 
			
		||||
 | 
			
		||||
    If you register a searchComponent to one of the standard names, that will be used instead.
 | 
			
		||||
    To insert components before or after the 'standard' components, use:
 | 
			
		||||
    
 | 
			
		||||
    <arr name="first-components">
 | 
			
		||||
      <str>myFirstComponentName</str>
 | 
			
		||||
    </arr>
 | 
			
		||||
    
 | 
			
		||||
    <arr name="last-components">
 | 
			
		||||
      <str>myLastComponentName</str>
 | 
			
		||||
    </arr>
 | 
			
		||||
  -->
 | 
			
		||||
  <!-- The spell check component can return a list of alternative spelling
 | 
			
		||||
  suggestions.  -->
 | 
			
		||||
  <searchComponent name="spellcheck" class="solr.SpellCheckComponent">
 | 
			
		||||
    <str name="queryAnalyzerFieldType">textSpell</str>
 | 
			
		||||
    <lst name="spellchecker">
 | 
			
		||||
      <str name="name">default</str>
 | 
			
		||||
      <str name="field">name</str>
 | 
			
		||||
      <str name="spellcheckIndexDir">./spellchecker</str>
 | 
			
		||||
    </lst>
 | 
			
		||||
    <!-- a spellchecker that uses a different distance measure
 | 
			
		||||
    <lst name="spellchecker">
 | 
			
		||||
      <str name="name">jarowinkler</str>
 | 
			
		||||
      <str name="field">spell</str>
 | 
			
		||||
      <str name="distanceMeasure">org.apache.lucene.search.spell.JaroWinklerDistance</str>
 | 
			
		||||
      <str name="spellcheckIndexDir">./spellchecker2</str>
 | 
			
		||||
    </lst>
 | 
			
		||||
     -->
 | 
			
		||||
    <!-- a file based spell checker
 | 
			
		||||
    <lst name="spellchecker">
 | 
			
		||||
      <str name="classname">solr.FileBasedSpellChecker</str>
 | 
			
		||||
      <str name="name">file</str>
 | 
			
		||||
      <str name="sourceLocation">spellings.txt</str>
 | 
			
		||||
      <str name="characterEncoding">UTF-8</str>
 | 
			
		||||
      <str name="spellcheckIndexDir">./spellcheckerFile</str>
 | 
			
		||||
    </lst>
 | 
			
		||||
    -->
 | 
			
		||||
  </searchComponent>
 | 
			
		||||
  <!-- A request handler utilizing the spellcheck component.  
 | 
			
		||||
  #############################################################################
 | 
			
		||||
  NOTE: This is purely as an example.  The whole purpose of the
 | 
			
		||||
  SpellCheckComponent is to hook it into the request handler that handles (i.e.
 | 
			
		||||
  the standard or dismax SearchHandler) queries such that a separate request is
 | 
			
		||||
  not needed to get suggestions.
 | 
			
		||||
 | 
			
		||||
  IN OTHER WORDS, THERE IS REALLY GOOD CHANCE THE SETUP BELOW IS NOT WHAT YOU
 | 
			
		||||
  WANT FOR YOUR PRODUCTION SYSTEM!
 | 
			
		||||
  #############################################################################
 | 
			
		||||
  -->
 | 
			
		||||
  <requestHandler name="/spell" class="solr.SearchHandler" lazy="true">
 | 
			
		||||
    <lst name="defaults">
 | 
			
		||||
      <!-- omp = Only More Popular -->
 | 
			
		||||
      <str name="spellcheck.onlyMorePopular">false</str>
 | 
			
		||||
      <!-- exr = Extended Results -->
 | 
			
		||||
      <str name="spellcheck.extendedResults">false</str>
 | 
			
		||||
      <!--  The number of suggestions to return -->
 | 
			
		||||
      <str name="spellcheck.count">1</str>
 | 
			
		||||
    </lst>
 | 
			
		||||
    <arr name="last-components">
 | 
			
		||||
      <str>spellcheck</str>
 | 
			
		||||
    </arr>
 | 
			
		||||
  </requestHandler>
 | 
			
		||||
  <searchComponent name="tvComponent" class="org.apache.solr.handler.component.TermVectorComponent"/>
 | 
			
		||||
  <!-- A Req Handler for working with the tvComponent.  This is purely as an example.
 | 
			
		||||
  You will likely want to add the component to your already specified request handlers. -->
 | 
			
		||||
  <requestHandler name="tvrh" class="org.apache.solr.handler.component.SearchHandler">
 | 
			
		||||
    <lst name="defaults">
 | 
			
		||||
      <bool name="tv">true</bool>
 | 
			
		||||
    </lst>
 | 
			
		||||
    <arr name="last-components">
 | 
			
		||||
      <str>tvComponent</str>
 | 
			
		||||
    </arr>
 | 
			
		||||
  </requestHandler>
 | 
			
		||||
  <!-- Clustering Component
 | 
			
		||||
       http://wiki.apache.org/solr/ClusteringComponent
 | 
			
		||||
       This relies on third party jars which are not included in the release.
 | 
			
		||||
       To use this component (and the "/clustering" handler)
 | 
			
		||||
       Those jars will need to be downloaded, and you'll need to set the
 | 
			
		||||
       solr.cluster.enabled system property when running solr...
 | 
			
		||||
          java -Dsolr.clustering.enabled=true -jar start.jar
 | 
			
		||||
    -->
 | 
			
		||||
  <searchComponent name="clusteringComponent" enable="${solr.clustering.enabled:false}" class="org.apache.solr.handler.clustering.ClusteringComponent">
 | 
			
		||||
    <!-- Declare an engine -->
 | 
			
		||||
    <lst name="engine">
 | 
			
		||||
      <!-- The name, only one can be named "default" -->
 | 
			
		||||
      <str name="name">default</str>
 | 
			
		||||
      <!-- 
 | 
			
		||||
           Class name of Carrot2 clustering algorithm. Currently available algorithms are:
 | 
			
		||||
           
 | 
			
		||||
           * org.carrot2.clustering.lingo.LingoClusteringAlgorithm
 | 
			
		||||
           * org.carrot2.clustering.stc.STCClusteringAlgorithm
 | 
			
		||||
           
 | 
			
		||||
           See http://project.carrot2.org/algorithms.html for the algorithm's characteristics.
 | 
			
		||||
        -->
 | 
			
		||||
      <str name="carrot.algorithm">org.carrot2.clustering.lingo.LingoClusteringAlgorithm</str>
 | 
			
		||||
      <!-- 
 | 
			
		||||
           Overriding values for Carrot2 default algorithm attributes. For a description
 | 
			
		||||
           of all available attributes, see: http://download.carrot2.org/stable/manual/#chapter.components.
 | 
			
		||||
           Use attribute key as name attribute of str elements below. These can be further
 | 
			
		||||
           overridden for individual requests by specifying attribute key as request
 | 
			
		||||
           parameter name and attribute value as parameter value.
 | 
			
		||||
        -->
 | 
			
		||||
      <str name="LingoClusteringAlgorithm.desiredClusterCountBase">20</str>
 | 
			
		||||
    </lst>
 | 
			
		||||
    <lst name="engine">
 | 
			
		||||
      <str name="name">stc</str>
 | 
			
		||||
      <str name="carrot.algorithm">org.carrot2.clustering.stc.STCClusteringAlgorithm</str>
 | 
			
		||||
    </lst>
 | 
			
		||||
  </searchComponent>
 | 
			
		||||
  <requestHandler name="/clustering" enable="${solr.clustering.enabled:false}" class="solr.SearchHandler">
 | 
			
		||||
    <lst name="defaults">
 | 
			
		||||
      <bool name="clustering">true</bool>
 | 
			
		||||
      <str name="clustering.engine">default</str>
 | 
			
		||||
      <bool name="clustering.results">true</bool>
 | 
			
		||||
      <!-- The title field -->
 | 
			
		||||
      <str name="carrot.title">name</str>
 | 
			
		||||
      <str name="carrot.url">id</str>
 | 
			
		||||
      <!-- The field to cluster on -->
 | 
			
		||||
      <str name="carrot.snippet">features</str>
 | 
			
		||||
      <!-- produce summaries -->
 | 
			
		||||
      <bool name="carrot.produceSummary">true</bool>
 | 
			
		||||
      <!-- the maximum number of labels per cluster -->
 | 
			
		||||
      <!--<int name="carrot.numDescriptions">5</int>-->
 | 
			
		||||
      <!-- produce sub clusters -->
 | 
			
		||||
      <bool name="carrot.outputSubClusters">false</bool>
 | 
			
		||||
    </lst>
 | 
			
		||||
    <arr name="last-components">
 | 
			
		||||
      <str>clusteringComponent</str>
 | 
			
		||||
    </arr>
 | 
			
		||||
  </requestHandler>
 | 
			
		||||
  <!-- Solr Cell: http://wiki.apache.org/solr/ExtractingRequestHandler -->
 | 
			
		||||
  <requestHandler name="/update/extract" class="org.apache.solr.handler.extraction.ExtractingRequestHandler" startup="lazy">
 | 
			
		||||
    <lst name="defaults">
 | 
			
		||||
      <!-- All the main content goes into "text"... if you need to return
 | 
			
		||||
           the extracted text or do highlighting, use a stored field. -->
 | 
			
		||||
      <str name="fmap.content">text</str>
 | 
			
		||||
      <str name="lowernames">true</str>
 | 
			
		||||
      <str name="uprefix">ignored_</str>
 | 
			
		||||
      <!-- capture link hrefs but ignore div attributes -->
 | 
			
		||||
      <str name="captureAttr">true</str>
 | 
			
		||||
      <str name="fmap.a">links</str>
 | 
			
		||||
      <str name="fmap.div">ignored_</str>
 | 
			
		||||
    </lst>
 | 
			
		||||
  </requestHandler>
 | 
			
		||||
  <!-- A component to return terms and document frequency of those terms.
 | 
			
		||||
       This component does not yet support distributed search. -->
 | 
			
		||||
  <searchComponent name="termsComponent" class="org.apache.solr.handler.component.TermsComponent"/>
 | 
			
		||||
  <requestHandler name="/terms" class="org.apache.solr.handler.component.SearchHandler">
 | 
			
		||||
    <lst name="defaults">
 | 
			
		||||
      <bool name="terms">true</bool>
 | 
			
		||||
    </lst>
 | 
			
		||||
    <arr name="components">
 | 
			
		||||
      <str>termsComponent</str>
 | 
			
		||||
    </arr>
 | 
			
		||||
  </requestHandler>
 | 
			
		||||
  <!-- a search component that enables you to configure the top results for
 | 
			
		||||
       a given query regardless of the normal lucene scoring.-->
 | 
			
		||||
  <searchComponent name="elevator" class="solr.QueryElevationComponent">
 | 
			
		||||
    <!-- pick a fieldType to analyze queries -->
 | 
			
		||||
    <str name="queryFieldType">string</str>
 | 
			
		||||
    <str name="config-file">elevate.xml</str>
 | 
			
		||||
  </searchComponent>
 | 
			
		||||
  <!-- a request handler utilizing the elevator component -->
 | 
			
		||||
  <requestHandler name="/elevate" class="solr.SearchHandler" startup="lazy">
 | 
			
		||||
    <lst name="defaults">
 | 
			
		||||
      <str name="echoParams">explicit</str>
 | 
			
		||||
    </lst>
 | 
			
		||||
    <arr name="last-components">
 | 
			
		||||
      <str>elevator</str>
 | 
			
		||||
    </arr>
 | 
			
		||||
  </requestHandler>
 | 
			
		||||
  <!-- Update request handler.  
 | 
			
		||||
 | 
			
		||||
       Note: Since solr1.1 requestHandlers requires a valid content type header if posted in
 | 
			
		||||
       the body. For example, curl now requires: -H 'Content-type:text/xml; charset=utf-8'
 | 
			
		||||
       The response format differs from solr1.1 formatting and returns a standard error code.
 | 
			
		||||
       To enable solr1.1 behavior, remove the /update handler or change its path
 | 
			
		||||
    -->
 | 
			
		||||
  <requestHandler name="/update" class="solr.XmlUpdateRequestHandler"/>
 | 
			
		||||
  <requestHandler name="/update/javabin" class="solr.BinaryUpdateRequestHandler"/>
 | 
			
		||||
  <!--
 | 
			
		||||
   Analysis request handler.  Since Solr 1.3.  Use to return how a document is analyzed.  Useful
 | 
			
		||||
   for debugging and as a token server for other types of applications.
 | 
			
		||||
 | 
			
		||||
   This is deprecated in favor of the improved DocumentAnalysisRequestHandler and FieldAnalysisRequestHandler
 | 
			
		||||
 | 
			
		||||
   <requestHandler name="/analysis" class="solr.AnalysisRequestHandler" />
 | 
			
		||||
   -->
 | 
			
		||||
  <!--
 | 
			
		||||
    An analysis handler that provides a breakdown of the analysis process of provided docuemnts. This handler expects a
 | 
			
		||||
    (single) content stream with the following format:
 | 
			
		||||
 | 
			
		||||
    <docs>
 | 
			
		||||
      <doc>
 | 
			
		||||
        <field name="id">1</field>
 | 
			
		||||
        <field name="name">The Name</field>
 | 
			
		||||
        <field name="text">The Text Value</field>
 | 
			
		||||
      <doc>
 | 
			
		||||
      <doc>...</doc>
 | 
			
		||||
      <doc>...</doc>
 | 
			
		||||
      ...
 | 
			
		||||
    </docs>
 | 
			
		||||
 | 
			
		||||
    Note: Each document must contain a field which serves as the unique key. This key is used in the returned
 | 
			
		||||
    response to assoicate an analysis breakdown to the analyzed document.
 | 
			
		||||
 | 
			
		||||
    Like the FieldAnalysisRequestHandler, this handler also supports query analysis by
 | 
			
		||||
    sending either an "analysis.query" or "q" request paraemter that holds the query text to be analyized. It also
 | 
			
		||||
    supports the "analysis.showmatch" parameter which when set to true, all field tokens that match the query
 | 
			
		||||
    tokens will be marked as a "match".
 | 
			
		||||
  -->
 | 
			
		||||
  <requestHandler name="/analysis/document" class="solr.DocumentAnalysisRequestHandler"/>
 | 
			
		||||
  <!--
 | 
			
		||||
    RequestHandler that provides much the same functionality as analysis.jsp. Provides the ability
 | 
			
		||||
    to specify multiple field types and field names in the same request and outputs index-time and
 | 
			
		||||
    query-time analysis for each of them.
 | 
			
		||||
 | 
			
		||||
    Request parameters are:
 | 
			
		||||
    analysis.fieldname - The field name whose analyzers are to be used
 | 
			
		||||
    analysis.fieldtype - The field type whose analyzers are to be used
 | 
			
		||||
    analysis.fieldvalue - The text for index-time analysis
 | 
			
		||||
    q (or analysis.q) - The text for query time analysis
 | 
			
		||||
    analysis.showmatch (true|false) - When set to true and when query analysis is performed, the produced
 | 
			
		||||
                                      tokens of the field value analysis will be marked as "matched" for every
 | 
			
		||||
                                      token that is produces by the query analysis
 | 
			
		||||
   -->
 | 
			
		||||
  <requestHandler name="/analysis/field" class="solr.FieldAnalysisRequestHandler"/>
 | 
			
		||||
  <!-- CSV update handler, loaded on demand -->
 | 
			
		||||
  <requestHandler name="/update/csv" class="solr.CSVRequestHandler" startup="lazy"/>
 | 
			
		||||
  <!-- 
 | 
			
		||||
   Admin Handlers - This will register all the standard admin RequestHandlers.  Adding 
 | 
			
		||||
   this single handler is equivalent to registering:
 | 
			
		||||
   
 | 
			
		||||
  <requestHandler name="/admin/luke"       class="org.apache.solr.handler.admin.LukeRequestHandler" />
 | 
			
		||||
  <requestHandler name="/admin/system"     class="org.apache.solr.handler.admin.SystemInfoHandler" />
 | 
			
		||||
  <requestHandler name="/admin/plugins"    class="org.apache.solr.handler.admin.PluginInfoHandler" />
 | 
			
		||||
  <requestHandler name="/admin/threads"    class="org.apache.solr.handler.admin.ThreadDumpHandler" />
 | 
			
		||||
  <requestHandler name="/admin/properties" class="org.apache.solr.handler.admin.PropertiesRequestHandler" />
 | 
			
		||||
  <requestHandler name="/admin/file"       class="org.apache.solr.handler.admin.ShowFileRequestHandler" >
 | 
			
		||||
  
 | 
			
		||||
  If you wish to hide files under ${solr.home}/conf, explicitly register the ShowFileRequestHandler using:
 | 
			
		||||
  <requestHandler name="/admin/file" class="org.apache.solr.handler.admin.ShowFileRequestHandler" >
 | 
			
		||||
    <lst name="invariants">
 | 
			
		||||
     <str name="hidden">synonyms.txt</str> 
 | 
			
		||||
     <str name="hidden">anotherfile.txt</str> 
 | 
			
		||||
    </lst>
 | 
			
		||||
  </requestHandler>
 | 
			
		||||
  -->
 | 
			
		||||
  <requestHandler name="/admin/" class="org.apache.solr.handler.admin.AdminHandlers"/>
 | 
			
		||||
  <!-- ping/healthcheck -->
 | 
			
		||||
  <requestHandler name="/admin/ping" class="PingRequestHandler">
 | 
			
		||||
    <lst name="defaults">
 | 
			
		||||
      <str name="qt">standard</str>
 | 
			
		||||
      <str name="q">solrpingquery</str>
 | 
			
		||||
      <str name="echoParams">all</str>
 | 
			
		||||
    </lst>
 | 
			
		||||
  </requestHandler>
 | 
			
		||||
  <!-- Echo the request contents back to the client -->
 | 
			
		||||
  <requestHandler name="/debug/dump" class="solr.DumpRequestHandler">
 | 
			
		||||
    <lst name="defaults">
 | 
			
		||||
      <str name="echoParams">explicit</str>
 | 
			
		||||
      <!-- for all params (including the default etc) use: 'all' -->
 | 
			
		||||
      <str name="echoHandler">true</str>
 | 
			
		||||
    </lst>
 | 
			
		||||
  </requestHandler>
 | 
			
		||||
  <highlighting>
 | 
			
		||||
    <!-- Configure the standard fragmenter -->
 | 
			
		||||
    <!-- This could most likely be commented out in the "default" case -->
 | 
			
		||||
    <fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
 | 
			
		||||
      <lst name="defaults">
 | 
			
		||||
        <int name="hl.fragsize">100</int>
 | 
			
		||||
      </lst>
 | 
			
		||||
    </fragmenter>
 | 
			
		||||
    <!-- A regular-expression-based fragmenter (f.i., for sentence extraction) -->
 | 
			
		||||
    <fragmenter name="regex" class="org.apache.solr.highlight.RegexFragmenter">
 | 
			
		||||
      <lst name="defaults">
 | 
			
		||||
        <!-- slightly smaller fragsizes work better because of slop -->
 | 
			
		||||
        <int name="hl.fragsize">70</int>
 | 
			
		||||
        <!-- allow 50% slop on fragment sizes -->
 | 
			
		||||
        <float name="hl.regex.slop">0.5</float>
 | 
			
		||||
        <!-- a basic sentence pattern -->
 | 
			
		||||
        <str name="hl.regex.pattern">[-\w ,/\n\"']{20,200}</str>
 | 
			
		||||
      </lst>
 | 
			
		||||
    </fragmenter>
 | 
			
		||||
    <!-- Configure the standard formatter -->
 | 
			
		||||
    <formatter name="html" class="org.apache.solr.highlight.HtmlFormatter" default="true">
 | 
			
		||||
      <lst name="defaults">
 | 
			
		||||
        <str name="hl.simple.pre"><![CDATA[<em>]]></str>
 | 
			
		||||
        <str name="hl.simple.post"><![CDATA[</em>]]></str>
 | 
			
		||||
      </lst>
 | 
			
		||||
    </formatter>
 | 
			
		||||
  </highlighting>
 | 
			
		||||
  <!-- An example dedup update processor that creates the "id" field on the fly
 | 
			
		||||
       based on the hash code of some other fields.  This example has overwriteDupes
 | 
			
		||||
       set to false since we are using the id field as the signatureField and Solr
 | 
			
		||||
       will maintain uniqueness based on that anyway. 
 | 
			
		||||
       
 | 
			
		||||
       You have to link the chain to an update handler above to use it ie:
 | 
			
		||||
         <requestHandler name="/update "class="solr.XmlUpdateRequestHandler">
 | 
			
		||||
           <lst name="defaults">
 | 
			
		||||
             <str name="update.processor">dedupe</str>
 | 
			
		||||
           </lst>
 | 
			
		||||
         </requestHandler>  
 | 
			
		||||
  -->
 | 
			
		||||
  <!--
 | 
			
		||||
  <updateRequestProcessorChain name="dedupe">
 | 
			
		||||
    <processor class="org.apache.solr.update.processor.SignatureUpdateProcessorFactory">
 | 
			
		||||
      <bool name="enabled">true</bool>
 | 
			
		||||
      <str name="signatureField">id</str>
 | 
			
		||||
      <bool name="overwriteDupes">false</bool>
 | 
			
		||||
      <str name="fields">name,features,cat</str>
 | 
			
		||||
      <str name="signatureClass">org.apache.solr.update.processor.Lookup3Signature</str>
 | 
			
		||||
    </processor>
 | 
			
		||||
    <processor class="solr.LogUpdateProcessorFactory" />
 | 
			
		||||
    <processor class="solr.RunUpdateProcessorFactory" />
 | 
			
		||||
  </updateRequestProcessorChain>
 | 
			
		||||
  -->
 | 
			
		||||
  <!-- queryResponseWriter plugins... query responses will be written using the
 | 
			
		||||
    writer specified by the 'wt' request parameter matching the name of a registered
 | 
			
		||||
    writer.
 | 
			
		||||
    The "default" writer is the default and will be used if 'wt' is not specified 
 | 
			
		||||
    in the request. XMLResponseWriter will be used if nothing is specified here.
 | 
			
		||||
    The json, python, and ruby writers are also available by default.
 | 
			
		||||
 | 
			
		||||
    <queryResponseWriter name="xml" class="org.apache.solr.request.XMLResponseWriter" default="true"/>
 | 
			
		||||
    <queryResponseWriter name="json" class="org.apache.solr.request.JSONResponseWriter"/>
 | 
			
		||||
    <queryResponseWriter name="python" class="org.apache.solr.request.PythonResponseWriter"/>
 | 
			
		||||
    <queryResponseWriter name="ruby" class="org.apache.solr.request.RubyResponseWriter"/>
 | 
			
		||||
    <queryResponseWriter name="php" class="org.apache.solr.request.PHPResponseWriter"/>
 | 
			
		||||
    <queryResponseWriter name="phps" class="org.apache.solr.request.PHPSerializedResponseWriter"/>
 | 
			
		||||
 | 
			
		||||
    <queryResponseWriter name="custom" class="com.example.MyResponseWriter"/>
 | 
			
		||||
  -->
 | 
			
		||||
  <!-- XSLT response writer transforms the XML output by any xslt file found
 | 
			
		||||
       in Solr's conf/xslt directory.  Changes to xslt files are checked for
 | 
			
		||||
       every xsltCacheLifetimeSeconds.  
 | 
			
		||||
   -->
 | 
			
		||||
  <queryResponseWriter name="xslt" class="org.apache.solr.request.XSLTResponseWriter">
 | 
			
		||||
    <int name="xsltCacheLifetimeSeconds">5</int>
 | 
			
		||||
  </queryResponseWriter>
 | 
			
		||||
  <!-- example of registering a query parser
 | 
			
		||||
  <queryParser name="lucene" class="org.apache.solr.search.LuceneQParserPlugin"/>
 | 
			
		||||
  -->
 | 
			
		||||
  <!-- example of registering a custom function parser 
 | 
			
		||||
  <valueSourceParser name="myfunc" class="com.mycompany.MyValueSourceParser" />
 | 
			
		||||
  -->
 | 
			
		||||
  <!-- config for the admin interface -->
 | 
			
		||||
  <admin>
 | 
			
		||||
    <defaultQuery>solr</defaultQuery>
 | 
			
		||||
    <!-- configure a healthcheck file for servers behind a loadbalancer
 | 
			
		||||
    <healthcheck type="file">server-enabled</healthcheck>
 | 
			
		||||
    -->
 | 
			
		||||
  </admin>
 | 
			
		||||
  <requestHandler class="solr.MoreLikeThisHandler" name="/mlt">
 | 
			
		||||
    <lst name="defaults">
 | 
			
		||||
      <str name="mlt.mintf">1</str>
 | 
			
		||||
      <str name="mlt.mindf">2</str>
 | 
			
		||||
    </lst>
 | 
			
		||||
  </requestHandler>
 | 
			
		||||
</config>
 | 
			
		||||
| 
						 | 
				
			
			@ -1,2 +0,0 @@
 | 
			
		|||
pizza
 | 
			
		||||
history
 | 
			
		||||
| 
						 | 
				
			
			@ -1,58 +0,0 @@
 | 
			
		|||
# Licensed to the Apache Software Foundation (ASF) under one or more
 | 
			
		||||
# contributor license agreements.  See the NOTICE file distributed with
 | 
			
		||||
# this work for additional information regarding copyright ownership.
 | 
			
		||||
# The ASF licenses this file to You under the Apache License, Version 2.0
 | 
			
		||||
# (the "License"); you may not use this file except in compliance with
 | 
			
		||||
# the License.  You may obtain a copy of the License at
 | 
			
		||||
#
 | 
			
		||||
#     http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
#
 | 
			
		||||
# Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
# distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
# See the License for the specific language governing permissions and
 | 
			
		||||
# limitations under the License.
 | 
			
		||||
 | 
			
		||||
#-----------------------------------------------------------------------
 | 
			
		||||
# a couple of test stopwords to test that the words are really being
 | 
			
		||||
# configured from this file:
 | 
			
		||||
stopworda
 | 
			
		||||
stopwordb
 | 
			
		||||
 | 
			
		||||
#Standard english stop words taken from Lucene's StopAnalyzer
 | 
			
		||||
a
 | 
			
		||||
an
 | 
			
		||||
and
 | 
			
		||||
are
 | 
			
		||||
as
 | 
			
		||||
at
 | 
			
		||||
be
 | 
			
		||||
but
 | 
			
		||||
by
 | 
			
		||||
for
 | 
			
		||||
if
 | 
			
		||||
in
 | 
			
		||||
into
 | 
			
		||||
is
 | 
			
		||||
it
 | 
			
		||||
no
 | 
			
		||||
not
 | 
			
		||||
of
 | 
			
		||||
on
 | 
			
		||||
or
 | 
			
		||||
s
 | 
			
		||||
such
 | 
			
		||||
t
 | 
			
		||||
that
 | 
			
		||||
the
 | 
			
		||||
their
 | 
			
		||||
then
 | 
			
		||||
there
 | 
			
		||||
these
 | 
			
		||||
they
 | 
			
		||||
this
 | 
			
		||||
to
 | 
			
		||||
was
 | 
			
		||||
will
 | 
			
		||||
with
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -1,31 +0,0 @@
 | 
			
		|||
# The ASF licenses this file to You under the Apache License, Version 2.0
 | 
			
		||||
# (the "License"); you may not use this file except in compliance with
 | 
			
		||||
# the License.  You may obtain a copy of the License at
 | 
			
		||||
#
 | 
			
		||||
#     http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
#
 | 
			
		||||
# Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
# distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
# See the License for the specific language governing permissions and
 | 
			
		||||
# limitations under the License.
 | 
			
		||||
 | 
			
		||||
#-----------------------------------------------------------------------
 | 
			
		||||
#some test synonym mappings unlikely to appear in real input text
 | 
			
		||||
aaa => aaaa
 | 
			
		||||
bbb => bbbb1 bbbb2
 | 
			
		||||
ccc => cccc1,cccc2
 | 
			
		||||
a\=>a => b\=>b
 | 
			
		||||
a\,a => b\,b
 | 
			
		||||
fooaaa,baraaa,bazaaa
 | 
			
		||||
 | 
			
		||||
# Some synonym groups specific to this example
 | 
			
		||||
GB,gib,gigabyte,gigabytes
 | 
			
		||||
MB,mib,megabyte,megabytes
 | 
			
		||||
Television, Televisions, TV, TVs
 | 
			
		||||
#notice we use "gib" instead of "GiB" so any WordDelimiterFilter coming
 | 
			
		||||
#after us won't split it into two words.
 | 
			
		||||
 | 
			
		||||
# Synonym mappings can be used for spelling correction too
 | 
			
		||||
pixima => pixma
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -1,99 +0,0 @@
 | 
			
		|||
PATH
 | 
			
		||||
  remote: .
 | 
			
		||||
  specs:
 | 
			
		||||
    personal_journal (0.0.1)
 | 
			
		||||
      rails (~> 3.1.4)
 | 
			
		||||
 | 
			
		||||
GEM
 | 
			
		||||
  remote: http://rubygems.org/
 | 
			
		||||
  specs:
 | 
			
		||||
    actionmailer (3.1.9)
 | 
			
		||||
      actionpack (= 3.1.9)
 | 
			
		||||
      mail (~> 2.3.3)
 | 
			
		||||
    actionpack (3.1.9)
 | 
			
		||||
      activemodel (= 3.1.9)
 | 
			
		||||
      activesupport (= 3.1.9)
 | 
			
		||||
      builder (~> 3.0.0)
 | 
			
		||||
      erubis (~> 2.7.0)
 | 
			
		||||
      i18n (~> 0.6)
 | 
			
		||||
      rack (~> 1.3.6)
 | 
			
		||||
      rack-cache (~> 1.2)
 | 
			
		||||
      rack-mount (~> 0.8.2)
 | 
			
		||||
      rack-test (~> 0.6.1)
 | 
			
		||||
      sprockets (~> 2.0.4)
 | 
			
		||||
    activemodel (3.1.9)
 | 
			
		||||
      activesupport (= 3.1.9)
 | 
			
		||||
      builder (~> 3.0.0)
 | 
			
		||||
      i18n (~> 0.6)
 | 
			
		||||
    activerecord (3.1.9)
 | 
			
		||||
      activemodel (= 3.1.9)
 | 
			
		||||
      activesupport (= 3.1.9)
 | 
			
		||||
      arel (~> 2.2.3)
 | 
			
		||||
      tzinfo (~> 0.3.29)
 | 
			
		||||
    activeresource (3.1.9)
 | 
			
		||||
      activemodel (= 3.1.9)
 | 
			
		||||
      activesupport (= 3.1.9)
 | 
			
		||||
    activesupport (3.1.9)
 | 
			
		||||
      multi_json (>= 1.0, < 1.3)
 | 
			
		||||
    arel (2.2.3)
 | 
			
		||||
    builder (3.0.4)
 | 
			
		||||
    erubis (2.7.0)
 | 
			
		||||
    hike (1.2.1)
 | 
			
		||||
    i18n (0.6.1)
 | 
			
		||||
    jquery-rails (2.1.4)
 | 
			
		||||
      railties (>= 3.0, < 5.0)
 | 
			
		||||
      thor (>= 0.14, < 2.0)
 | 
			
		||||
    json (1.7.6)
 | 
			
		||||
    mail (2.3.3)
 | 
			
		||||
      i18n (>= 0.4.0)
 | 
			
		||||
      mime-types (~> 1.16)
 | 
			
		||||
      treetop (~> 1.4.8)
 | 
			
		||||
    mime-types (1.19)
 | 
			
		||||
    multi_json (1.2.0)
 | 
			
		||||
    polyglot (0.3.3)
 | 
			
		||||
    rack (1.3.6)
 | 
			
		||||
    rack-cache (1.2)
 | 
			
		||||
      rack (>= 0.4)
 | 
			
		||||
    rack-mount (0.8.3)
 | 
			
		||||
      rack (>= 1.0.0)
 | 
			
		||||
    rack-ssl (1.3.2)
 | 
			
		||||
      rack
 | 
			
		||||
    rack-test (0.6.2)
 | 
			
		||||
      rack (>= 1.0)
 | 
			
		||||
    rails (3.1.9)
 | 
			
		||||
      actionmailer (= 3.1.9)
 | 
			
		||||
      actionpack (= 3.1.9)
 | 
			
		||||
      activerecord (= 3.1.9)
 | 
			
		||||
      activeresource (= 3.1.9)
 | 
			
		||||
      activesupport (= 3.1.9)
 | 
			
		||||
      bundler (~> 1.0)
 | 
			
		||||
      railties (= 3.1.9)
 | 
			
		||||
    railties (3.1.9)
 | 
			
		||||
      actionpack (= 3.1.9)
 | 
			
		||||
      activesupport (= 3.1.9)
 | 
			
		||||
      rack-ssl (~> 1.3.2)
 | 
			
		||||
      rake (>= 0.8.7)
 | 
			
		||||
      rdoc (~> 3.4)
 | 
			
		||||
      thor (~> 0.14.6)
 | 
			
		||||
    rake (10.0.3)
 | 
			
		||||
    rdoc (3.12)
 | 
			
		||||
      json (~> 1.4)
 | 
			
		||||
    sprockets (2.0.4)
 | 
			
		||||
      hike (~> 1.2)
 | 
			
		||||
      rack (~> 1.0)
 | 
			
		||||
      tilt (~> 1.1, != 1.3.0)
 | 
			
		||||
    sqlite3 (1.3.6)
 | 
			
		||||
    thor (0.14.6)
 | 
			
		||||
    tilt (1.3.3)
 | 
			
		||||
    treetop (1.4.12)
 | 
			
		||||
      polyglot
 | 
			
		||||
      polyglot (>= 0.3.1)
 | 
			
		||||
    tzinfo (0.3.35)
 | 
			
		||||
 | 
			
		||||
PLATFORMS
 | 
			
		||||
  ruby
 | 
			
		||||
 | 
			
		||||
DEPENDENCIES
 | 
			
		||||
  jquery-rails
 | 
			
		||||
  personal_journal!
 | 
			
		||||
  sqlite3
 | 
			
		||||
| 
						 | 
				
			
			@ -1,3 +1,5 @@
 | 
			
		|||
require 'csv'
 | 
			
		||||
 | 
			
		||||
class Panel::Survey::BackEnd::SurveysController < OrbitBackendController
 | 
			
		||||
 | 
			
		||||
  include AdminHelper
 | 
			
		||||
| 
						 | 
				
			
			@ -83,4 +85,83 @@ class Panel::Survey::BackEnd::SurveysController < OrbitBackendController
 | 
			
		|||
    redirect_to panel_survey_back_end_surveys_url(:direction => params[:direction], :sort => params[:sort], :sort_options => params[:sort_options])
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def export
 | 
			
		||||
    @survey = ::Survey.find(params[:id])
 | 
			
		||||
    @survey_questions = @survey.survey_questions.all
 | 
			
		||||
 | 
			
		||||
    respond_to do |format|
 | 
			
		||||
      format.csv do
 | 
			
		||||
 | 
			
		||||
        csv = CSV.generate do |csv|
 | 
			
		||||
          csv << @survey_questions.map(&:title)
 | 
			
		||||
          @survey.survey_answers.each do |answer|
 | 
			
		||||
            row = []
 | 
			
		||||
            @survey_questions.each do |question|
 | 
			
		||||
              row << answer[question.id.to_s]
 | 
			
		||||
            end
 | 
			
		||||
            csv << row
 | 
			
		||||
          end
 | 
			
		||||
 | 
			
		||||
        end
 | 
			
		||||
 | 
			
		||||
        render :text => csv
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def chart
 | 
			
		||||
    @survey = ::Survey.find(params[:id])
 | 
			
		||||
    @chart_data, @survey_questions, @survey_answers = @survey.generate_chart_data
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def set_answers
 | 
			
		||||
    @survey = ::Survey.find(params[:id])
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def jump
 | 
			
		||||
    @survey = ::Survey.find(params[:id])
 | 
			
		||||
    @questions = @survey.survey_questions.all
 | 
			
		||||
 | 
			
		||||
    @jump_to_options = [[ t('survey.not_jump'), 0 ], [t('survey.jump_to_end'), 1]]
 | 
			
		||||
    @jump_to_options += @questions.collect {|q| [ q.title, q.id.to_s ] }
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def duplicate_it
 | 
			
		||||
    @survey = ::Survey.find(params[:id])
 | 
			
		||||
 | 
			
		||||
    @new_survey = ::Survey.new
 | 
			
		||||
 | 
			
		||||
    @survey.attributes.each do |key, value|
 | 
			
		||||
      unless ['_id', 'created_at', 'updated_at', 'update_user_id'].include? key
 | 
			
		||||
        if @survey.respond_to?(key + '_translations')
 | 
			
		||||
          @new_survey.send(key + '_translations=', value)
 | 
			
		||||
        else
 | 
			
		||||
          @new_survey.write_attribute(key, value)
 | 
			
		||||
        end
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
    @survey.survey_questions.all.each do |question|
 | 
			
		||||
      new_question = @new_survey.survey_questions.new
 | 
			
		||||
      question.attributes.each do |key, value|
 | 
			
		||||
        unless ['_id', 'created_at', 'updated_at'].include? key
 | 
			
		||||
          if @survey.respond_to?(key + '_translations')
 | 
			
		||||
            new_question.send(key + '_translations=', value)
 | 
			
		||||
          else
 | 
			
		||||
            new_question.write_attribute(key, value)
 | 
			
		||||
          end
 | 
			
		||||
        end
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    @new_survey.create_user_id = current_user.id
 | 
			
		||||
    @new_survey.update_user_id = current_user.id
 | 
			
		||||
 | 
			
		||||
    @new_survey.save!
 | 
			
		||||
 | 
			
		||||
    respond_to do |format|
 | 
			
		||||
      format.html { redirect_to(panel_survey_back_end_surveys_url) }
 | 
			
		||||
      format.xml  { render :xml => @survey, :status => :created, :location => @new_survey }
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
  
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			@ -1,4 +1,5 @@
 | 
			
		|||
class Panel::Survey::FrontEnd::SurveysController < OrbitWidgetController
 | 
			
		||||
  helper ApplicationHelper
 | 
			
		||||
  
 | 
			
		||||
  def initialize
 | 
			
		||||
    super
 | 
			
		||||
| 
						 | 
				
			
			@ -6,11 +7,18 @@ class Panel::Survey::FrontEnd::SurveysController < OrbitWidgetController
 | 
			
		|||
  end
 | 
			
		||||
 | 
			
		||||
  def index
 | 
			
		||||
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def show
 | 
			
		||||
    @survey = ::Survey.find params[:id]
 | 
			
		||||
    redirect_standalone panel_survey_front_end_survey_path(params[:id], :standalone => 'true') do
 | 
			
		||||
      @survey = ::Survey.find params[:id]
 | 
			
		||||
      @questions = @survey.survey_questions.all
 | 
			
		||||
      if @survey.jump_mode
 | 
			
		||||
        @jumpable_questions = @questions.all.select{ |q| q.jumpable? && q.can_set_jump? }
 | 
			
		||||
 | 
			
		||||
        @jump_tos_map = @jumpable_questions.map(&:get_jump_tos).inject(:merge)
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def update
 | 
			
		||||
| 
						 | 
				
			
			@ -20,7 +28,7 @@ class Panel::Survey::FrontEnd::SurveysController < OrbitWidgetController
 | 
			
		|||
    @answer_model = @survey.survey_answers.new
 | 
			
		||||
    @survey.survey_questions.each do |question|
 | 
			
		||||
      qid = question.id.to_s
 | 
			
		||||
      if question.is_required && answer[qid].blank?
 | 
			
		||||
      if question.is_required && answer[qid].blank? && !@survey.jump_mode #&& (! @survey.jump_mode || ( @survey.jump_mode && question.jumpable? ) )
 | 
			
		||||
        @answer_model.errors.add question.title, t('survey_question.required_error')
 | 
			
		||||
      else
 | 
			
		||||
        case question.type
 | 
			
		||||
| 
						 | 
				
			
			@ -65,7 +73,6 @@ class Panel::Survey::FrontEnd::SurveysController < OrbitWidgetController
 | 
			
		|||
        end
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
    p @answer_model
 | 
			
		||||
    if @answer_model.errors.empty?
 | 
			
		||||
      @answer_model.save!
 | 
			
		||||
      render :answer_success
 | 
			
		||||
| 
						 | 
				
			
			@ -75,4 +82,26 @@ class Panel::Survey::FrontEnd::SurveysController < OrbitWidgetController
 | 
			
		|||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def result
 | 
			
		||||
    redirect_standalone result_panel_survey_front_end_survey_path(params[:id], :standalone => 'true') do
 | 
			
		||||
      @survey = ::Survey.find params[:id]
 | 
			
		||||
      case @survey.result_type
 | 
			
		||||
      when ::Survey::ResultChart
 | 
			
		||||
        @chart_data, @survey_questions, @survey_answers = @survey.generate_chart_data
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def redirect_standalone url
 | 
			
		||||
    unless params[:standalone] == 'true'
 | 
			
		||||
      @redirect_url = url
 | 
			
		||||
      render :redirect_standalone
 | 
			
		||||
    else
 | 
			
		||||
      module_app = ModuleApp.first(:conditions => {:key => 'survey'})
 | 
			
		||||
      @item = Item.where(module_app_id: module_app.id, app_frontend_url: 'default_widget').first
 | 
			
		||||
      yield
 | 
			
		||||
      render :layout => 'standalone'
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			@ -5,6 +5,10 @@ class Survey
 | 
			
		|||
  include Mongoid::Document
 | 
			
		||||
  include Mongoid::Timestamps
 | 
			
		||||
 | 
			
		||||
  ResultChart = 0
 | 
			
		||||
  ResultExtern = 1
 | 
			
		||||
  ResultFile = 2
 | 
			
		||||
 | 
			
		||||
  scope :available_for_lang, ->(locale){ where("available_for_#{locale}".to_sym => true) }
 | 
			
		||||
  scope :can_display, where(is_hidden: false)
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -19,6 +23,12 @@ class Survey
 | 
			
		|||
 | 
			
		||||
  field :is_hidden, :type => Boolean, :default => false
 | 
			
		||||
 | 
			
		||||
  field :result_type, :type => Integer, :default => 0
 | 
			
		||||
  field :extern_link
 | 
			
		||||
  mount_uploader :upload_file, AssetUploader
 | 
			
		||||
 | 
			
		||||
  field :jump_mode, :type => Boolean, :default => false
 | 
			
		||||
  
 | 
			
		||||
  validates :title, :at_least_one => true
 | 
			
		||||
 | 
			
		||||
  has_many :survey_questions, :autosave => true, :dependent => :destroy
 | 
			
		||||
| 
						 | 
				
			
			@ -34,6 +44,43 @@ class Survey
 | 
			
		|||
    r
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def result
 | 
			
		||||
    I18n.t 'survey.view_result'
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def generate_chart_data
 | 
			
		||||
    survey_questions = self.survey_questions.all
 | 
			
		||||
    survey_answers = self.survey_answers.all
 | 
			
		||||
 | 
			
		||||
    chart_data = {}
 | 
			
		||||
 | 
			
		||||
    survey_questions.each do |question|
 | 
			
		||||
      qid = question.id.to_s
 | 
			
		||||
      case question.type
 | 
			
		||||
      when ::SurveyQuestion::Radio, ::SurveyQuestion::Select
 | 
			
		||||
        chart_data[qid] = {}
 | 
			
		||||
        answers = survey_answers.each do |answer|
 | 
			
		||||
          if answer[qid]
 | 
			
		||||
            chart_data[qid][answer[qid]] ||= 0
 | 
			
		||||
            chart_data[qid][answer[qid]] += 1
 | 
			
		||||
          end
 | 
			
		||||
        end
 | 
			
		||||
      when ::SurveyQuestion::Check
 | 
			
		||||
        chart_data[qid] = {}
 | 
			
		||||
        answers = survey_answers.each do |answer|
 | 
			
		||||
          if answer[qid]
 | 
			
		||||
            answer[qid].each do |option|
 | 
			
		||||
              chart_data[qid][option] ||= 0
 | 
			
		||||
              chart_data[qid][option] += 1
 | 
			
		||||
            end
 | 
			
		||||
          end
 | 
			
		||||
        end
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    [chart_data, survey_questions, survey_answers]
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  protected
 | 
			
		||||
  
 | 
			
		||||
  def check_deadline
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -24,4 +24,22 @@ class SurveyQuestion
 | 
			
		|||
 | 
			
		||||
  accepts_nested_attributes_for :survey_question_options, :allow_destroy => true
 | 
			
		||||
  accepts_nested_attributes_for :survey_question_radiogroups, :allow_destroy => true
 | 
			
		||||
 | 
			
		||||
  def jumpable?
 | 
			
		||||
    case type
 | 
			
		||||
    when SurveyQuestion::Radio, SurveyQuestion::Select
 | 
			
		||||
      true
 | 
			
		||||
    else
 | 
			
		||||
      false
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def can_set_jump?
 | 
			
		||||
    ( !custom_option )
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def get_jump_tos
 | 
			
		||||
    Hash[survey_question_options.select{ |o| !o.jump_to.blank? }.collect{ |o| [o.id.to_s, o.jump_to] }]
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -0,0 +1,3 @@
 | 
			
		|||
class SurveyQuestionOneline < SurveyQuestion
 | 
			
		||||
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			@ -2,6 +2,7 @@ class SurveyQuestionOption
 | 
			
		|||
  include Mongoid::Document
 | 
			
		||||
 | 
			
		||||
  field :name, :localize => true
 | 
			
		||||
  field :jump_to, :default => 0
 | 
			
		||||
 | 
			
		||||
  embedded_in :survey_question
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			@ -111,7 +111,7 @@
 | 
			
		|||
              </tr>
 | 
			
		||||
            </tfoot>
 | 
			
		||||
          </table>
 | 
			
		||||
          <div class="type-specify hide-type-<%= SurveyQuestion::Radiogroup%>">
 | 
			
		||||
          <div class="type-specify type-<%= SurveyQuestion::Radio%> type-<%= SurveyQuestion::Check%> type-<%= SurveyQuestion::Select%> hide-type-<%= SurveyQuestion::Radiogroup%>">
 | 
			
		||||
            <%= f.label :custom_option, t('survey_question.custom_option')%> 
 | 
			
		||||
            <%= f.check_box :custom_option %>
 | 
			
		||||
          </div>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -10,7 +10,12 @@
 | 
			
		|||
      <ul class="nav nav-pills hide">
 | 
			
		||||
        <%if at_least_module_manager %>
 | 
			
		||||
          <li><%= link_to t('edit'), edit_panel_survey_back_end_survey_path(survey, :page => params[:page]) %></li>
 | 
			
		||||
          <li><%= link_to t('survey.answers'), panel_survey_back_end_survey_answers_path(survey, :page => params[:page]) %></li>
 | 
			
		||||
          <li><%= link_to t('survey.duplicate_it'), duplicate_it_panel_survey_back_end_survey_path(survey, :page => params[:page]) %></li>
 | 
			
		||||
          <li><%= link_to t('survey.jump'), jump_panel_survey_back_end_survey_path(survey, :page => params[:page]) %></li>
 | 
			
		||||
          <li><%= link_to t('survey.set_answers'), set_answers_panel_survey_back_end_survey_path(survey, :page => params[:page]) %></li>
 | 
			
		||||
          <li><%= link_to t('survey.answers_list'), panel_survey_back_end_survey_answers_path(survey, :page => params[:page]) %></li>
 | 
			
		||||
          <li><%= link_to t('survey.export_csv'), export_panel_survey_back_end_survey_path(survey, :format => :csv), :target => '_blank' %></li>
 | 
			
		||||
          <li><%= link_to t('survey.chart'), chart_panel_survey_back_end_survey_path(survey, :page => params[:page]) %></li>
 | 
			
		||||
          <li><%= link_to t(:delete_), panel_survey_back_end_survey_path(survey), :confirm => t('sure?'), :method => :delete, :remote => true %></li>
 | 
			
		||||
        <% end -%>
 | 
			
		||||
      </ul>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										40
									
								
								vendor/built_in_modules/survey/app/views/panel/survey/back_end/surveys/chart.html.erb
								
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										40
									
								
								vendor/built_in_modules/survey/app/views/panel/survey/back_end/surveys/chart.html.erb
								
								
								
									vendored
								
								
									Normal file
								
							| 
						 | 
				
			
			@ -0,0 +1,40 @@
 | 
			
		|||
<h1><%= @survey.title %> <%= t('survey.chart') %></h1>
 | 
			
		||||
 | 
			
		||||
<% @survey_questions.each do |question| %>
 | 
			
		||||
 | 
			
		||||
  <h3><%= question.title %></h3>
 | 
			
		||||
  <% case question.type %>
 | 
			
		||||
  <% when ::SurveyQuestion::Radio, ::SurveyQuestion::Check, ::SurveyQuestion::Select %>
 | 
			
		||||
    <div id="question_chart_<%= question.id.to_s %>" style="width: 600px; height: 300px;"></div>
 | 
			
		||||
  <% else %>
 | 
			
		||||
    <p><%= t('survey_question.have_not_chart') %></p>
 | 
			
		||||
  <% end %>
 | 
			
		||||
 | 
			
		||||
<% end %>
 | 
			
		||||
 | 
			
		||||
<div class="form-actions form-fixed">
 | 
			
		||||
  <%= link_to t('back'), get_go_back, :class=>"btn" %> 
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<% content_for :page_specific_javascript do %>
 | 
			
		||||
  <script type="text/javascript" src="https://www.google.com/jsapi"></script>
 | 
			
		||||
  <script type="text/javascript">
 | 
			
		||||
    google.load("visualization", "1", {packages:["corechart"]});
 | 
			
		||||
    google.setOnLoadCallback(function(){
 | 
			
		||||
    <% @survey_questions.each do |question| %>
 | 
			
		||||
      <% qid = question.id.to_s %>
 | 
			
		||||
      <% case question.type %>
 | 
			
		||||
      <% when ::SurveyQuestion::Radio, ::SurveyQuestion::Check, ::SurveyQuestion::Select %>
 | 
			
		||||
        var data_<%= qid %> = google.visualization.arrayToDataTable([
 | 
			
		||||
          ['<%= t("survey_question.option") %>', ''],
 | 
			
		||||
          <% @chart_data[qid].each do |option, count| %>
 | 
			
		||||
            ['<%= option %>', <%= count %>],
 | 
			
		||||
          <% end %>
 | 
			
		||||
        ]);
 | 
			
		||||
        var chart_<%= qid %> = new google.visualization.PieChart(document.getElementById('question_chart_<%= qid %>'));
 | 
			
		||||
        chart_<%= qid %>.draw(data_<%= qid %>, {title: '<%= question.title %>'});
 | 
			
		||||
      <% end %>
 | 
			
		||||
    <% end %>
 | 
			
		||||
    });
 | 
			
		||||
  </script>
 | 
			
		||||
<% end %>
 | 
			
		||||
							
								
								
									
										56
									
								
								vendor/built_in_modules/survey/app/views/panel/survey/back_end/surveys/jump.html.erb
								
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										56
									
								
								vendor/built_in_modules/survey/app/views/panel/survey/back_end/surveys/jump.html.erb
								
								
								
									vendored
								
								
									Normal file
								
							| 
						 | 
				
			
			@ -0,0 +1,56 @@
 | 
			
		|||
<h1><%= @survey.title %> <%= t('survey.jump') %></h1>
 | 
			
		||||
 | 
			
		||||
<%= form_for @survey, :url => panel_survey_back_end_survey_path(@survey), :html => {:class => 'clear'} do |f| %>
 | 
			
		||||
  <div id="post-body">
 | 
			
		||||
    <div id="post-body-content" class="clear">
 | 
			
		||||
      <div class="jump_mode">
 | 
			
		||||
        <%= f.label :jump_mode, t('survey.jump_mode')%> 
 | 
			
		||||
        <%= f.check_box :jump_mode %>
 | 
			
		||||
      </div>
 | 
			
		||||
 | 
			
		||||
      <% @questions.each_with_index do |question, i| %>
 | 
			
		||||
 | 
			
		||||
        <%= f.fields_for :survey_questions, question do |f| %>
 | 
			
		||||
 | 
			
		||||
          <div id="<%= "survey_question_#{question.id}"%>" class="survey_question_item clear">
 | 
			
		||||
            <div id="widget-question" class="widget-box">
 | 
			
		||||
              <h3 class="widget-title"><i class="icons-help"></i><%= question.title %></h3>
 | 
			
		||||
              <div class="widget-content">
 | 
			
		||||
                <% if question.jumpable? %>
 | 
			
		||||
                  <% if question.can_set_jump? %>
 | 
			
		||||
                    <ol>
 | 
			
		||||
                      <% question.survey_question_options.each_with_index do |option, i| %>
 | 
			
		||||
 | 
			
		||||
                        <%= f.fields_for :survey_question_options, option do |f| %>
 | 
			
		||||
 | 
			
		||||
                          <li>
 | 
			
		||||
                            <%= f.label :survey_question_options, option.name %>
 | 
			
		||||
                            <%= f.select :jump_to, @jump_to_options %>
 | 
			
		||||
                          </li>
 | 
			
		||||
                          
 | 
			
		||||
                        <% end %>
 | 
			
		||||
 | 
			
		||||
                      <% end %>
 | 
			
		||||
                    </ol>
 | 
			
		||||
                  <% else %>
 | 
			
		||||
                    <%= t('survey.right_type_cant_jump') %>
 | 
			
		||||
                  <% end %>
 | 
			
		||||
                <% else %>
 | 
			
		||||
                  <%= t('survey.wrong_type_cant_jump') %>
 | 
			
		||||
                <% end %>
 | 
			
		||||
              </div>
 | 
			
		||||
            </div>
 | 
			
		||||
          </div>
 | 
			
		||||
 | 
			
		||||
        <% end %>
 | 
			
		||||
 | 
			
		||||
      <% end %>
 | 
			
		||||
 | 
			
		||||
      <div class="form-actions">
 | 
			
		||||
        <%= hidden_field_tag 'page', params[:page] if !params[:page].blank? %>
 | 
			
		||||
        <%= f.submit t('submit'), :class=>'btn btn-primary' %>
 | 
			
		||||
        <%= link_to t('cancel'), get_go_back, :class=>"btn" %> 
 | 
			
		||||
      </div>
 | 
			
		||||
    </div>
 | 
			
		||||
  </div>
 | 
			
		||||
<% end %>
 | 
			
		||||
							
								
								
									
										34
									
								
								vendor/built_in_modules/survey/app/views/panel/survey/back_end/surveys/set_answers.html.erb
								
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										34
									
								
								vendor/built_in_modules/survey/app/views/panel/survey/back_end/surveys/set_answers.html.erb
								
								
								
									vendored
								
								
									Normal file
								
							| 
						 | 
				
			
			@ -0,0 +1,34 @@
 | 
			
		|||
<h1><%= @survey.title %> <%= t('survey.set_answers') %></h1>
 | 
			
		||||
 | 
			
		||||
<%= form_for @survey, :url => panel_survey_back_end_survey_path(@survey), :html => {:class => 'clear'} do |f| %>
 | 
			
		||||
  <div id="post-body">
 | 
			
		||||
    <div id="post-body-content" class="clear">
 | 
			
		||||
      <div class="type">
 | 
			
		||||
        <%= f.label :result_type, t('survey.result_type')%> 
 | 
			
		||||
        <%= f.select :result_type, {
 | 
			
		||||
          t('survey.chart') => Survey::ResultChart, 
 | 
			
		||||
          t('survey.extern_link') => Survey::ResultExtern,
 | 
			
		||||
          t('survey.upload_file') => Survey::ResultFile
 | 
			
		||||
        }, {}, :class => "tinput-medium" %>      
 | 
			
		||||
      </div>
 | 
			
		||||
      <div class="extern_link">
 | 
			
		||||
        <%= f.label :extern_link, t('survey.extern_link') %>
 | 
			
		||||
        <%= f.text_field :extern_link, :style=>"width:98%;", :class=>'post-extern_link' %>
 | 
			
		||||
      </div>
 | 
			
		||||
      <div class="upload_file">
 | 
			
		||||
        <%= f.label :upload_file, t('survey.upload_file') %>
 | 
			
		||||
        <%= f.file_field :upload_file %>
 | 
			
		||||
        <% if @survey.upload_file? %>
 | 
			
		||||
          <%= link_to t(:view), @survey.upload_file.url, {:class => 'for_preview btn', :target => '_blank', :title => t(:view), "data-trigger" => :hover} %>
 | 
			
		||||
          <%= f.label :remove_upload_file, t('survey.remove_upload_file')%> 
 | 
			
		||||
          <%= f.check_box :remove_upload_file %>
 | 
			
		||||
        <% end %>
 | 
			
		||||
      </div>
 | 
			
		||||
      <div class="form-actions">
 | 
			
		||||
        <%= hidden_field_tag 'page', params[:page] if !params[:page].blank? %>
 | 
			
		||||
        <%= f.submit t('submit'), :class=>'btn btn-primary' %>
 | 
			
		||||
        <%= link_to t('cancel'), get_go_back, :class=>"btn" %> 
 | 
			
		||||
      </div>
 | 
			
		||||
    </div>
 | 
			
		||||
  </div>
 | 
			
		||||
<% end %>
 | 
			
		||||
| 
						 | 
				
			
			@ -1,4 +1,4 @@
 | 
			
		|||
<script type="text/javascript">
 | 
			
		||||
  alert("<%= t('survey.answer_error')%>: <%= @survey_answer_error %>");
 | 
			
		||||
  window.location.href = "<%= panel_survey_front_end_survey_path(@survey, :clicked_field_name => 'title') %>";
 | 
			
		||||
  window.history.back();
 | 
			
		||||
</script>
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,3 @@
 | 
			
		|||
<script type="text/javascript">
 | 
			
		||||
  window.location.href = "<%= @redirect_url %>";
 | 
			
		||||
</script>
 | 
			
		||||
							
								
								
									
										49
									
								
								vendor/built_in_modules/survey/app/views/panel/survey/front_end/surveys/result.html.erb
								
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										49
									
								
								vendor/built_in_modules/survey/app/views/panel/survey/front_end/surveys/result.html.erb
								
								
								
									vendored
								
								
									Normal file
								
							| 
						 | 
				
			
			@ -0,0 +1,49 @@
 | 
			
		|||
<% case @survey.result_type %>
 | 
			
		||||
<% when ::Survey::ResultChart %>
 | 
			
		||||
 | 
			
		||||
  <h1><%= @survey.title %> <%= t('survey.chart') %></h1>
 | 
			
		||||
  <section>
 | 
			
		||||
    <% @survey_questions.each do |question| %>
 | 
			
		||||
 | 
			
		||||
      <% case question.type %>
 | 
			
		||||
      <% when ::SurveyQuestion::Radio, ::SurveyQuestion::Check, ::SurveyQuestion::Select %>
 | 
			
		||||
        <div id="question_chart_<%= question.id.to_s %>" style="width: 600px; height: 300px;"></div>
 | 
			
		||||
      <% end %>
 | 
			
		||||
 | 
			
		||||
    <% end %>
 | 
			
		||||
  </section>
 | 
			
		||||
 | 
			
		||||
  <script type="text/javascript" src="https://www.google.com/jsapi"></script>
 | 
			
		||||
  <script type="text/javascript">
 | 
			
		||||
    if (window.google) {
 | 
			
		||||
      window.google.load("visualization", "1", {packages:["corechart"]});
 | 
			
		||||
      window.google.setOnLoadCallback(function(){
 | 
			
		||||
      <% @survey_questions.each do |question| %>
 | 
			
		||||
        <% qid = question.id.to_s %>
 | 
			
		||||
        <% case question.type %>
 | 
			
		||||
        <% when ::SurveyQuestion::Radio, ::SurveyQuestion::Check, ::SurveyQuestion::Select %>
 | 
			
		||||
          var data_<%= qid %> = google.visualization.arrayToDataTable([
 | 
			
		||||
            ['<%= t("survey_question.option") %>', ''],
 | 
			
		||||
            <% @chart_data[qid].each do |option, count| %>
 | 
			
		||||
              ['<%= option %>', <%= count %>],
 | 
			
		||||
            <% end %>
 | 
			
		||||
          ]);
 | 
			
		||||
          var chart_<%= qid %> = new google.visualization.PieChart(document.getElementById('question_chart_<%= qid %>'));
 | 
			
		||||
          chart_<%= qid %>.draw(data_<%= qid %>, {title: '<%= question.title %>'});
 | 
			
		||||
        <% end %>
 | 
			
		||||
      <% end %>
 | 
			
		||||
      });
 | 
			
		||||
    } else {
 | 
			
		||||
      window.location.href = "<%= result_panel_survey_front_end_survey_path(@survey, :inner => 'true') %>";
 | 
			
		||||
    }
 | 
			
		||||
  </script>
 | 
			
		||||
<% when ::Survey::ResultExtern %>
 | 
			
		||||
  <script type="text/javascript">
 | 
			
		||||
    window.location.href = "<%= @survey.extern_link %>";
 | 
			
		||||
  </script>
 | 
			
		||||
<% when ::Survey::ResultFile %>
 | 
			
		||||
  <h1><%= @survey.title %> <%= t('survey.upload_file') %></h1>
 | 
			
		||||
  <section>
 | 
			
		||||
    <%= link_to t(:view), @survey.upload_file.url, {:class => 'for_preview btn', :target => '_blank', :title => t(:view), "data-trigger" => :hover} %>
 | 
			
		||||
  </section>
 | 
			
		||||
<% end %>
 | 
			
		||||
| 
						 | 
				
			
			@ -1,87 +1,157 @@
 | 
			
		|||
<% # encoding: utf-8 %>
 | 
			
		||||
<h1 class="h1"><%= @survey.title %></h1>
 | 
			
		||||
<%= form_for :answer, :method => :put, :url => panel_survey_front_end_survey_path(@survey, :inner => true), :html => {:class => 'clear'} do |f| %>
 | 
			
		||||
  <% @survey.survey_questions.each do |question| %>
 | 
			
		||||
    <% label = question.title %>
 | 
			
		||||
    <% label += ' (' + t('survey_question.required') + ')' if question.is_required %>
 | 
			
		||||
    <%= f.label question.id, label %>
 | 
			
		||||
    <p><%= question.description %></p>
 | 
			
		||||
    <% case question.type %>
 | 
			
		||||
    <% when ::SurveyQuestion::Oneline %>
 | 
			
		||||
      <%= f.text_field question.id, :required => question.is_required %>
 | 
			
		||||
    <% when ::SurveyQuestion::Multiline %>
 | 
			
		||||
      <%= f.text_area question.id, :rows => 5, :required => question.is_required %>
 | 
			
		||||
    <% when ::SurveyQuestion::Radio %>
 | 
			
		||||
      <% question.survey_question_options.each do |option| %>
 | 
			
		||||
        <p>
 | 
			
		||||
          <%= f.radio_button question.id, option.id %>
 | 
			
		||||
          <%= f.label "#{question.id}_#{option.id}", option.name, :style => "display:inline" %>
 | 
			
		||||
        </p>
 | 
			
		||||
      <% end %>
 | 
			
		||||
      <% if question.custom_option %>
 | 
			
		||||
        <p>
 | 
			
		||||
          <%= f.radio_button question.id, 'custom_option' %>
 | 
			
		||||
          <%= f.label "#{question.id}_custom_option", t('survey_question.use_custom_option') + ': ', :style => "display:inline" %>
 | 
			
		||||
          <%= f.text_field "#{question.id}_custom_option" %>
 | 
			
		||||
        </p>
 | 
			
		||||
      <% end %>
 | 
			
		||||
    <% when ::SurveyQuestion::Check %>
 | 
			
		||||
      <%= f.fields_for "#{question.id}" do |cf| %>
 | 
			
		||||
        <% question.survey_question_options.each do |option| %>
 | 
			
		||||
          <p>
 | 
			
		||||
            <%= cf.check_box option.id %>
 | 
			
		||||
            <%= cf.label option.id, option.name, :style => "display:inline" %>
 | 
			
		||||
          </p>
 | 
			
		||||
        <% end %>
 | 
			
		||||
        <% if question.custom_option %>
 | 
			
		||||
          <p>
 | 
			
		||||
            <%= cf.check_box 'custom_option' %>
 | 
			
		||||
            <%= f.label "#{question.id}_custom_option", t('survey_question.use_custom_option') + ': ', :style => "display:inline" %>
 | 
			
		||||
            <%= f.text_field "#{question.id}_custom_option" %>
 | 
			
		||||
          </p>
 | 
			
		||||
        <% end %>
 | 
			
		||||
      <% end %>
 | 
			
		||||
    <% when ::SurveyQuestion::Select %>
 | 
			
		||||
      <% options = question.survey_question_options.collect {|o| [ o.name, o.id ] } %>
 | 
			
		||||
      <% if question.custom_option %>
 | 
			
		||||
        <% options.push [t('survey_question.use_custom_option'), 'custom_option'] %>
 | 
			
		||||
      <% end %>
 | 
			
		||||
      <%= f.select question.id, options %>
 | 
			
		||||
      <% if question.custom_option %>
 | 
			
		||||
        <%= f.text_field "#{question.id}_custom_option" %>
 | 
			
		||||
      <% end %>
 | 
			
		||||
    <% when ::SurveyQuestion::Radiogroup %>
 | 
			
		||||
      <%= f.fields_for "#{question.id}" do |rgf| %>
 | 
			
		||||
        <table>
 | 
			
		||||
          <thead>
 | 
			
		||||
            <tr>
 | 
			
		||||
              <td></td>
 | 
			
		||||
              <% question.survey_question_radiogroups.each do |radiogroup| %>
 | 
			
		||||
                <td>
 | 
			
		||||
                  <%= rgf.label radiogroup.id, radiogroup.name %>
 | 
			
		||||
                </td>
 | 
			
		||||
              <% end %>
 | 
			
		||||
            </tr>
 | 
			
		||||
          </thead>
 | 
			
		||||
          <tbody>
 | 
			
		||||
            <% question.survey_question_options.each do |option| %>
 | 
			
		||||
              <tr>
 | 
			
		||||
                <td>
 | 
			
		||||
                  <%= rgf.label option.id, option.name %>
 | 
			
		||||
                </td>
 | 
			
		||||
                <% question.survey_question_radiogroups.each do |radiogroup| %>
 | 
			
		||||
                  <td>
 | 
			
		||||
                    <%= rgf.radio_button option.id, radiogroup.id %>
 | 
			
		||||
                  </td>
 | 
			
		||||
<h1><%= @survey.title %></h1>
 | 
			
		||||
<div>
 | 
			
		||||
  <section>
 | 
			
		||||
    <div class="o-question">
 | 
			
		||||
      <%= form_for :answer, :method => :put, :url => panel_survey_front_end_survey_path(@survey, :inner => true), :html => {:class => 'clear'} do |f| %>
 | 
			
		||||
        <div class="o-question-description">
 | 
			
		||||
          <%= @survey.description %>
 | 
			
		||||
        </div>
 | 
			
		||||
        <ol class="o-question-list">
 | 
			
		||||
          <% @questions.each_with_index do |question, i| %>
 | 
			
		||||
            <li class="question-item question-<%= question.id.to_s %> hide" data-index="<%= i %>" data-type="<%= question.type%>" data-custom="<%= question.custom_option.to_s %>">
 | 
			
		||||
              <% label = question.title %>
 | 
			
		||||
              <% label += ' (' + t('survey_question.required') + ')' if question.is_required %>
 | 
			
		||||
              <%= f.label question.id, label, :class => "o-question-title" %>
 | 
			
		||||
              <div class="o-question-description">
 | 
			
		||||
                <%= question.description %>
 | 
			
		||||
              </div>
 | 
			
		||||
              <% case question.type %>
 | 
			
		||||
              <% when ::SurveyQuestion::Oneline %>
 | 
			
		||||
                <%= f.text_field question.id, :required => question.is_required %>
 | 
			
		||||
              <% when ::SurveyQuestion::Multiline %>
 | 
			
		||||
                <%= f.text_area question.id, :rows => 5, :required => question.is_required %>
 | 
			
		||||
              <% when ::SurveyQuestion::Radio %>
 | 
			
		||||
                <% question.survey_question_options.each do |option| %>
 | 
			
		||||
                  <p>
 | 
			
		||||
                    <%= f.radio_button question.id, option.id %>
 | 
			
		||||
                    <%= f.label "#{question.id}_#{option.id}", option.name, :style => "display:inline" %>
 | 
			
		||||
                  </p>
 | 
			
		||||
                <% end %>
 | 
			
		||||
              </tr>
 | 
			
		||||
            <% end %>
 | 
			
		||||
          </tbody>
 | 
			
		||||
        </table>
 | 
			
		||||
                <% if question.custom_option %>
 | 
			
		||||
                  <p>
 | 
			
		||||
                    <%= f.radio_button question.id, 'custom_option' %>
 | 
			
		||||
                    <%= f.label "#{question.id}_custom_option", t('survey_question.use_custom_option') + ': ', :style => "display:inline" %>
 | 
			
		||||
                    <%= f.text_field "#{question.id}_custom_option" %>
 | 
			
		||||
                  </p>
 | 
			
		||||
                <% end %>
 | 
			
		||||
              <% when ::SurveyQuestion::Check %>
 | 
			
		||||
                <%= f.fields_for "#{question.id}" do |cf| %>
 | 
			
		||||
                  <% question.survey_question_options.each do |option| %>
 | 
			
		||||
                    <p>
 | 
			
		||||
                      <%= cf.check_box option.id %>
 | 
			
		||||
                      <%= cf.label option.id, option.name, :style => "display:inline" %>
 | 
			
		||||
                    </p>
 | 
			
		||||
                  <% end %>
 | 
			
		||||
                  <% if question.custom_option %>
 | 
			
		||||
                    <p>
 | 
			
		||||
                      <%= cf.check_box 'custom_option' %>
 | 
			
		||||
                      <%= f.label "#{question.id}_custom_option", t('survey_question.use_custom_option') + ': ', :style => "display:inline" %>
 | 
			
		||||
                      <%= f.text_field "#{question.id}_custom_option" %>
 | 
			
		||||
                    </p>
 | 
			
		||||
                  <% end %>
 | 
			
		||||
                <% end %>
 | 
			
		||||
              <% when ::SurveyQuestion::Select %>
 | 
			
		||||
                <% options = question.survey_question_options.collect {|o| [ o.name, o.id ] } %>
 | 
			
		||||
                <% if question.custom_option %>
 | 
			
		||||
                  <% options.push [t('survey_question.use_custom_option'), 'custom_option'] %>
 | 
			
		||||
                <% end %>
 | 
			
		||||
                <%= f.select question.id, options %>
 | 
			
		||||
                <% if question.custom_option %>
 | 
			
		||||
                  <%= f.text_field "#{question.id}_custom_option", :class => 'custom_option' %>
 | 
			
		||||
                <% end %>
 | 
			
		||||
              <% when ::SurveyQuestion::Radiogroup %>
 | 
			
		||||
                <%= f.fields_for "#{question.id}" do |rgf| %>
 | 
			
		||||
                  <table class="o-question-group view-grid">
 | 
			
		||||
                    <thead>
 | 
			
		||||
                      <tr>
 | 
			
		||||
                        <th></th>
 | 
			
		||||
                        <% question.survey_question_radiogroups.each do |radiogroup| %>
 | 
			
		||||
                          <th>
 | 
			
		||||
                            <%= radiogroup.name %>
 | 
			
		||||
                          </th>
 | 
			
		||||
                        <% end %>
 | 
			
		||||
                      </tr>
 | 
			
		||||
                    </thead>
 | 
			
		||||
                    <tbody>
 | 
			
		||||
                      <% question.survey_question_options.each_with_index do |option, j| %>
 | 
			
		||||
                        <tr<%= (' class="odd"').html_safe if (j % 2 == 0) %>>
 | 
			
		||||
                          <th class="o-question-title">
 | 
			
		||||
                            <%= option.name %>
 | 
			
		||||
                          </th>
 | 
			
		||||
                          <% question.survey_question_radiogroups.each do |radiogroup| %>
 | 
			
		||||
                            <td>
 | 
			
		||||
                              <%= rgf.radio_button option.id, radiogroup.id %>
 | 
			
		||||
                            </td>
 | 
			
		||||
                          <% end %>
 | 
			
		||||
                        </tr>
 | 
			
		||||
                      <% end %>
 | 
			
		||||
                    </tbody>
 | 
			
		||||
                  </table>
 | 
			
		||||
                <% end %>
 | 
			
		||||
              <% end %>
 | 
			
		||||
            </li>
 | 
			
		||||
          <% end %>
 | 
			
		||||
        </ol>
 | 
			
		||||
        <div class="o-question-action">
 | 
			
		||||
          <%= f.submit t('submit'), :class => 'survey-submit' %>
 | 
			
		||||
        </div>
 | 
			
		||||
      <% end %>
 | 
			
		||||
    <% end %>
 | 
			
		||||
  <% end %>
 | 
			
		||||
  <p>
 | 
			
		||||
    <%= f.submit t('submit') %>
 | 
			
		||||
  </p>
 | 
			
		||||
    </div>
 | 
			
		||||
  </section>
 | 
			
		||||
</div>
 | 
			
		||||
<% content_for :page_stylesheets do %>
 | 
			
		||||
  <link href='/assets/questionnaire.css' rel='stylesheet' type='text/css' />
 | 
			
		||||
<% end %>
 | 
			
		||||
<script type="text/javascript">
 | 
			
		||||
<% if @survey.jump_mode %>
 | 
			
		||||
  var jump_tos_map = <%== @jump_tos_map.to_json %>;
 | 
			
		||||
  var $current_question = $('.question-item').eq(0);
 | 
			
		||||
  var current_index = parseInt($current_question.attr('data-index'));
 | 
			
		||||
  $current_question.show();
 | 
			
		||||
  $('.survey-submit').click(function(){
 | 
			
		||||
    $current_question.hide();
 | 
			
		||||
    if ( $current_question.attr('data-type') == '<%= SurveyQuestion::Radio %>' || $current_question.attr('data-type') == '<%= SurveyQuestion::Select %>' ) {
 | 
			
		||||
      if ( $current_question.attr('data-type') == '<%= SurveyQuestion::Radio %>' ) {
 | 
			
		||||
        value = $current_question.find('input[type=radio]:checked').val();
 | 
			
		||||
      } else if ( $current_question.attr('data-type') == '<%= SurveyQuestion::Select %>') {
 | 
			
		||||
        value = $current_question.find('select option:selected').val();
 | 
			
		||||
      }
 | 
			
		||||
      if ( value == undefined ) {
 | 
			
		||||
        alert("<%= t('survey.must_answer') %>");
 | 
			
		||||
      } else {
 | 
			
		||||
        jump_to = jump_tos_map[value];
 | 
			
		||||
        if (jump_to == '1') {
 | 
			
		||||
          return true;
 | 
			
		||||
        } else if ( jump_to != '0' && jump_to != undefined ) {
 | 
			
		||||
          $current_question = $('.question-item.question-' + jump_to);
 | 
			
		||||
        } else {
 | 
			
		||||
          $current_question = $('.question-item[data-index=' + (current_index + 1) + ']');
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
    } else {
 | 
			
		||||
      $current_question = $('.question-item[data-index=' + (current_index + 1) + ']');
 | 
			
		||||
    }
 | 
			
		||||
    if ( $current_question[0] ) {
 | 
			
		||||
      $current_question.show();
 | 
			
		||||
      current_index = parseInt($current_question.attr('data-index'));
 | 
			
		||||
      return false;
 | 
			
		||||
    } else {
 | 
			
		||||
      return true;
 | 
			
		||||
    }
 | 
			
		||||
    return false;
 | 
			
		||||
  });
 | 
			
		||||
<% else %>
 | 
			
		||||
  $('.question-item').show();
 | 
			
		||||
<% end %>
 | 
			
		||||
  $('.question-item[data-type=<%= SurveyQuestion::Select %>][data-custom=true]').each(function(){
 | 
			
		||||
    $(this).change(function(){
 | 
			
		||||
      if ( $(this).find('option:selected').val() == 'custom_option' ) {
 | 
			
		||||
        $(this).find('input.custom_option').show();
 | 
			
		||||
      } else {
 | 
			
		||||
        $(this).find('input.custom_option').hide();
 | 
			
		||||
      }
 | 
			
		||||
    });
 | 
			
		||||
    $(this).trigger('change');
 | 
			
		||||
  });
 | 
			
		||||
</script>
 | 
			
		||||
| 
						 | 
				
			
			@ -7,11 +7,63 @@ en:
 | 
			
		|||
    postdate: Start Date
 | 
			
		||||
    deadline: End Date
 | 
			
		||||
    no_postdate: No Start Date
 | 
			
		||||
    no_deadline: No Start Date
 | 
			
		||||
    no_deadline: No End Date
 | 
			
		||||
    results_count: Results Count
 | 
			
		||||
    update_user: Update User
 | 
			
		||||
    question: Question
 | 
			
		||||
 | 
			
		||||
    result_type: Result Type (Frontend)
 | 
			
		||||
    extern_link: Extern Link
 | 
			
		||||
    upload_file: Uploaded File
 | 
			
		||||
 | 
			
		||||
    remove_upload_file: Remove Uploaded File
 | 
			
		||||
 | 
			
		||||
    answer_success: Successfully answered,jump back now
 | 
			
		||||
    answer_error: Unsuccessful answer
 | 
			
		||||
 | 
			
		||||
    answers_list: Answers List
 | 
			
		||||
    export_csv: Export CSV
 | 
			
		||||
    chart: Chart
 | 
			
		||||
    set_answers: Set Answers
 | 
			
		||||
    duplicate_it: Duplicate It
 | 
			
		||||
 | 
			
		||||
    view_result: View Result
 | 
			
		||||
 | 
			
		||||
    jump: Jump-To
 | 
			
		||||
    jump_mode: Jump-To Mode
 | 
			
		||||
    wrong_type_cant_jump: Only radio or select can set jump-to
 | 
			
		||||
    right_type_cant_jump: Custom option allowed can't set jump-to
 | 
			
		||||
    not_jump: Not Jump
 | 
			
		||||
    jump_to_end: End of Survey
 | 
			
		||||
 | 
			
		||||
    must_answer: Must be Answered
 | 
			
		||||
 | 
			
		||||
    default_widget:
 | 
			
		||||
      title: Title
 | 
			
		||||
      time_range: Date Range
 | 
			
		||||
      result: Result
 | 
			
		||||
 | 
			
		||||
    frontend:
 | 
			
		||||
        survey: Survey Frontend
 | 
			
		||||
 | 
			
		||||
  survey_question:
 | 
			
		||||
    title: Question
 | 
			
		||||
    description: Description
 | 
			
		||||
    type: Type
 | 
			
		||||
    is_required: Is Required
 | 
			
		||||
    required: Required
 | 
			
		||||
    required_error: Can't not be empty
 | 
			
		||||
    oneline: Oneline
 | 
			
		||||
    multiline: Multi-line
 | 
			
		||||
    radio: Radio
 | 
			
		||||
    check: Check
 | 
			
		||||
    select: Select
 | 
			
		||||
    radiogroup: Radio Group
 | 
			
		||||
    options_lists: Options List
 | 
			
		||||
    radiogroup_label: Radio Group Label
 | 
			
		||||
    radiogroups_lists: Radio Groups List
 | 
			
		||||
    option: Option
 | 
			
		||||
    custom_option: Allow Custom Option
 | 
			
		||||
    use_custom_option: Other
 | 
			
		||||
 | 
			
		||||
    have_not_chart: This type of question havn't chart
 | 
			
		||||
| 
						 | 
				
			
			@ -13,14 +13,36 @@ zh_tw:
 | 
			
		|||
    update_user: 最後更新者
 | 
			
		||||
    question: 問題
 | 
			
		||||
 | 
			
		||||
    result_type: 前端結果表示方式
 | 
			
		||||
    extern_link: 外部連結
 | 
			
		||||
    upload_file: 結果文件
 | 
			
		||||
 | 
			
		||||
    remove_upload_file: 移除存在的結果文件
 | 
			
		||||
 | 
			
		||||
    answer_success: 問卷填寫成功,現在跳回
 | 
			
		||||
    answer_error: 問卷填寫錯誤
 | 
			
		||||
 | 
			
		||||
    answers: 結果
 | 
			
		||||
    answers_list: 結果清單
 | 
			
		||||
    export_csv: 匯出CSV
 | 
			
		||||
    chart: 結果圖表
 | 
			
		||||
    set_answers: 設定結果
 | 
			
		||||
    duplicate_it: 複製問卷
 | 
			
		||||
 | 
			
		||||
    view_result: 查看結果
 | 
			
		||||
 | 
			
		||||
    jump: 跳題
 | 
			
		||||
    jump_mode: 設爲跳題方式回答
 | 
			
		||||
    wrong_type_cant_jump: 不是單選或下拉無法使用跳題
 | 
			
		||||
    right_type_cant_jump: 允許自定回答的問題無法使用跳題
 | 
			
		||||
    not_jump: 依據試卷列出所有問題數
 | 
			
		||||
    jump_to_end: 結束問題
 | 
			
		||||
 | 
			
		||||
    must_answer: 必須回答這個問題
 | 
			
		||||
 | 
			
		||||
    default_widget:
 | 
			
		||||
      title: 問卷標題
 | 
			
		||||
      time_range: 問卷期間
 | 
			
		||||
      result: 結果
 | 
			
		||||
 | 
			
		||||
    frontend:
 | 
			
		||||
        survey: 問卷調查前台
 | 
			
		||||
| 
						 | 
				
			
			@ -44,3 +66,5 @@ zh_tw:
 | 
			
		|||
    option: 選項
 | 
			
		||||
    custom_option: 允許自定回答選項
 | 
			
		||||
    use_custom_option: 其他
 | 
			
		||||
 | 
			
		||||
    have_not_chart: 此種類型問題不含結果圖表
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -7,6 +7,13 @@ Rails.application.routes.draw do
 | 
			
		|||
          collection do
 | 
			
		||||
            get 'delete'
 | 
			
		||||
          end
 | 
			
		||||
          member do
 | 
			
		||||
            get 'export'
 | 
			
		||||
            get 'chart'
 | 
			
		||||
            get 'set_answers'
 | 
			
		||||
            get 'jump'
 | 
			
		||||
            get 'duplicate_it'
 | 
			
		||||
          end
 | 
			
		||||
          resources :answers, :controller => :surveys_answers do
 | 
			
		||||
            collection do
 | 
			
		||||
              get 'delete'
 | 
			
		||||
| 
						 | 
				
			
			@ -15,7 +22,11 @@ Rails.application.routes.draw do
 | 
			
		|||
        end
 | 
			
		||||
      end
 | 
			
		||||
      namespace :front_end do
 | 
			
		||||
        resources :surveys
 | 
			
		||||
        resources :surveys do
 | 
			
		||||
          member do
 | 
			
		||||
            get 'result'
 | 
			
		||||
          end
 | 
			
		||||
        end
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -22,9 +22,10 @@ module Faq
 | 
			
		|||
      default_widget do
 | 
			
		||||
        enable ["typeA"]
 | 
			
		||||
        query 'Survey.any_of( {deadline: nil,:postdate.lte => Time.now} , {:deadline.gte => Time.now, :postdate.lte => Time.now} )'
 | 
			
		||||
        link_field :title,{:method => 'panel_survey_front_end_survey_path',:args=>:self}
 | 
			
		||||
        link_field :title, {:method => 'panel_survey_front_end_survey_path',:args=>:self}
 | 
			
		||||
        link_field :result, {:method => 'result_panel_survey_front_end_survey_path', :args=>:self}
 | 
			
		||||
        field :time_range
 | 
			
		||||
        link_to_more 'panel_survey_front_end_survey_path',:title_i18n=> 'faq.default_widget.to_more'
 | 
			
		||||
        link_to_more 'panel_survey_front_end_survey_path', :title_i18n=> 'faq.default_widget.to_more'
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Reference in New Issue