ULL-ETSII-Alu3177-Quiz 0.1.2
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +5 -0
- data/Gemfile +4 -0
- data/README.md +58 -0
- data/Rakefile +1 -0
- data/ULL-ETSII-Alu3177-Quiz.gemspec +26 -0
- data/bin/quiz_main.rb +53 -0
- data/lib/ULL-ETSII-Alu3177-Quiz/ULL-ETSII-Alu3177-Quiz.rb +175 -0
- data/lib/ULL-ETSII-Alu3177-Quiz/templates.rb +77 -0
- data/lib/ULL-ETSII-Alu3177-Quiz/version.rb +9 -0
- data/lib/html/css/base.css +28 -0
- data/lib/html/css/blitzer/images/ui-bg_diagonals-thick_75_f3d8d8_40x40.png +0 -0
- data/lib/html/css/blitzer/images/ui-bg_dots-small_65_a6a6a6_2x2.png +0 -0
- data/lib/html/css/blitzer/images/ui-bg_flat_0_333333_40x100.png +0 -0
- data/lib/html/css/blitzer/images/ui-bg_flat_65_ffffff_40x100.png +0 -0
- data/lib/html/css/blitzer/images/ui-bg_flat_75_ffffff_40x100.png +0 -0
- data/lib/html/css/blitzer/images/ui-bg_glass_55_fbf8ee_1x400.png +0 -0
- data/lib/html/css/blitzer/images/ui-bg_highlight-hard_100_eeeeee_1x100.png +0 -0
- data/lib/html/css/blitzer/images/ui-bg_highlight-hard_100_f6f6f6_1x100.png +0 -0
- data/lib/html/css/blitzer/images/ui-bg_highlight-soft_15_cc0000_1x100.png +0 -0
- data/lib/html/css/blitzer/images/ui-icons_004276_256x240.png +0 -0
- data/lib/html/css/blitzer/images/ui-icons_cc0000_256x240.png +0 -0
- data/lib/html/css/blitzer/images/ui-icons_ffffff_256x240.png +0 -0
- data/lib/html/css/blitzer/jquery-ui-1.9.2.custom.min.css +5 -0
- data/lib/html/js/jquery-1.8.3.js +9472 -0
- data/lib/html/js/jquery-ui-1.9.2.custom.min.js +6 -0
- data/spec/ULL-ETSII-Alu3177-Quiz_spec.rb +35 -0
- metadata +154 -0
data/Gemfile
ADDED
data/README.md
ADDED
@@ -0,0 +1,58 @@
|
|
1
|
+
# ULL::ETSII::Alu3177::Quiz
|
2
|
+
|
3
|
+
# Práctica 13: DSL: Redacción de Cuestionarios II (Usando Contexto)
|
4
|
+
# `W.I.P: Work In Progress`
|
5
|
+
## Enunciado
|
6
|
+
Se trata de escribir un programa que redacte cuestionarios. En principio, sólo soportaremos preguntas del tipo selección múltiple:
|
7
|
+
|
8
|
+
1 - ¿En que año Cristóbal Colón descubrió América?
|
9
|
+
1. 1942
|
10
|
+
2. 1492
|
11
|
+
3. 1808
|
12
|
+
4. 1914
|
13
|
+
Su respuesta:
|
14
|
+
|
15
|
+
Debe definir una clase __Quiz__ que soporte un pequeño lenguaje en el que las preguntas puedan ser especificadas. El constructor de __Quiz__ va seguido de un bloque, en el que mediante el DSL se especifican las preguntas y respuestas.
|
16
|
+
|
17
|
+
quiz = Quiz.new("Cuestionario de PFS 10/12/2011"){
|
18
|
+
question ’¿En que añoo Cristóbal Colón descubrió América?’,
|
19
|
+
wrong =>’1942’,
|
20
|
+
right =>’1492’,
|
21
|
+
wrong =>’1808’,
|
22
|
+
wrong =>’1914’
|
23
|
+
|
24
|
+
a = rand(10)
|
25
|
+
b = rand(10)
|
26
|
+
|
27
|
+
question "#{a}+#{b} = ",
|
28
|
+
wrong =>"44",
|
29
|
+
wrong =>"#{a + b + 2}",
|
30
|
+
right =>"#{a + b}",
|
31
|
+
wrong =>"#{a + b - 2}"
|
32
|
+
}
|
33
|
+
quiz.run
|
34
|
+
|
35
|
+
## Exportación HTML
|
36
|
+
Mediante el método `to_html` de la clase _Quiz_ crea un directorio llamado 'html' y en su interior se construye un fichero con el test. Se incluyen además los ficheros de estilo e implementación JavaScript.
|
37
|
+
|
38
|
+
La página construída representa cada pregunta y sus posibles respuestas y además permite evaluar si son correctas o no (mostrando individualmente el resultado de cada respuesta) mediante el uso de javascript.
|
39
|
+
|
40
|
+
## Objetivos
|
41
|
+
- Escriba un método `to_html` que genere una página describiendo el examen. `Use ERB`
|
42
|
+
- Opcionalmente puede incluir hojas de estilo, javascript, etc. en el HTML generado
|
43
|
+
- Use TDD con RSpec
|
44
|
+
- Use Unit Testing
|
45
|
+
- Use Continuous Integration (Travis)
|
46
|
+
- Use Continuous Testing (Guard)
|
47
|
+
- Documente su gema véase `RDOC::Markup o RDOC o YARD`
|
48
|
+
- Cree una gema `ull-etsii-aluXX-quiz`
|
49
|
+
- Publique la gema en RubyGems.org
|
50
|
+
- Indique la URL de su repositorio en GitHub y la URL en RubyGems.org
|
51
|
+
|
52
|
+
## Contributing
|
53
|
+
|
54
|
+
1. Fork it
|
55
|
+
2. Create your feature branch (`git checkout -b my-new-feature`)
|
56
|
+
3. Commit your changes (`git commit -am 'Add some feature'`)
|
57
|
+
4. Push to the branch (`git push origin my-new-feature`)
|
58
|
+
5. Create new Pull Request
|
data/Rakefile
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
require "bundler/gem_tasks"
|
@@ -0,0 +1,26 @@
|
|
1
|
+
# -*- encoding: utf-8 -*-
|
2
|
+
$:.push File.expand_path("../lib", __FILE__)
|
3
|
+
require "ULL-ETSII-Alu3177-Quiz/version"
|
4
|
+
|
5
|
+
Gem::Specification.new do |s|
|
6
|
+
s.name = "ULL-ETSII-Alu3177-Quiz"
|
7
|
+
s.version = ULL::ETSII::Alu3177::Quiz::VERSION
|
8
|
+
s.authors = ["Fernando González López-Peñalver"]
|
9
|
+
s.email = ["alu0100256543@ull.edu.es"]
|
10
|
+
s.homepage = ""
|
11
|
+
s.summary = %q{Práctica: DSL: Redacción de Cuestionarios II (Usando Contexto)}
|
12
|
+
s.description = %q{Generador de custionarios. Permite crear custionarios mediante un DSL simple. Además se podrán ejecutar estos cuestionarios via consola o generar un documento html encargado de mostrar y corregir los tests.}
|
13
|
+
|
14
|
+
s.rubyforge_project = "ULL-ETSII-Alu3177-Quiz"
|
15
|
+
|
16
|
+
s.files = `git ls-files`.split("\n")
|
17
|
+
s.test_files = `git ls-files -- {test,spec,features}/*`.split("\n")
|
18
|
+
s.executables = `git ls-files -- bin/*`.split("\n").map{ |f| File.basename(f) }
|
19
|
+
s.require_paths = ["lib"]
|
20
|
+
|
21
|
+
s.add_development_dependency "rspec"
|
22
|
+
s.add_development_dependency "guard"
|
23
|
+
s.add_development_dependency "guard-rspec"
|
24
|
+
s.add_development_dependency "rdoc"
|
25
|
+
s.add_runtime_dependency "colorize"
|
26
|
+
end
|
data/bin/quiz_main.rb
ADDED
@@ -0,0 +1,53 @@
|
|
1
|
+
#encoding: UTF-8
|
2
|
+
require 'ULL-ETSII-Alu3177-Quiz'
|
3
|
+
include ULL::ETSII::Alu3177::Quiz
|
4
|
+
|
5
|
+
quiz = Quiz.new("Lenguajes y Paradigmas de Programación: Temas 1 y 2") {
|
6
|
+
question "¿Cómo se pueden ver los valores de una configuración git?",
|
7
|
+
right => "git config -l",
|
8
|
+
wrong => "git list config",
|
9
|
+
wrong => "git config -a",
|
10
|
+
wrong => "git config ls"
|
11
|
+
question "¿Cómo se crea un repositorio git?",
|
12
|
+
wrong => "git initialize",
|
13
|
+
wrong => "git start",
|
14
|
+
right => "git init",
|
15
|
+
wrong => "git new"
|
16
|
+
question "¿Cómo se añaden cambios para que estén bajo el control de git?",
|
17
|
+
wrong => "git update filename",
|
18
|
+
wrong => "git include filename",
|
19
|
+
right => "git add filename",
|
20
|
+
wrong => "git require filename"
|
21
|
+
question "¿Cómo se ve el estado de mis ficheros con respecto al repositorio?",
|
22
|
+
wrong => "git list",
|
23
|
+
wrong => "git file status",
|
24
|
+
wrong => "git diff",
|
25
|
+
right => "git status"
|
26
|
+
question "¿Es correcto escribir subguiones en un número (por ejemplo: 1_000_000)?",
|
27
|
+
right => "Sí",
|
28
|
+
wrong => "No"
|
29
|
+
question "¿Qué opción hay que pasarle a git commit para especificar el mensaje de log y evitar que abra el editor?",
|
30
|
+
wrong => "-n",
|
31
|
+
wrong => "-n \"Texto\"",
|
32
|
+
wrong => "-m",
|
33
|
+
right => "-m \"Texto\""
|
34
|
+
question "¿Qué opción hay que pasarle a git commit para que añada todos los cambios efectuados en ficheros rastreados (tracked)?",
|
35
|
+
right => "-a",
|
36
|
+
wrong => "-c",
|
37
|
+
wrong => "-h",
|
38
|
+
wrong => "-p"
|
39
|
+
question "Qué indica el prefijo/sufijo? $",
|
40
|
+
right => "Variable global",
|
41
|
+
wrong => "Variable de clase",
|
42
|
+
wrong => "Variable de instancia"
|
43
|
+
question "Qué indica el prefijo/sufijo? @",
|
44
|
+
wrong => "Variable global",
|
45
|
+
wrong => "Variable de clase",
|
46
|
+
right => "Variable de instancia"
|
47
|
+
question "Qué indica el prefijo/sufijo? @@",
|
48
|
+
wrong => "Variable global",
|
49
|
+
right => "Variable de clase",
|
50
|
+
wrong => "Variable de instancia"
|
51
|
+
}
|
52
|
+
|
53
|
+
quiz.to_html
|
@@ -0,0 +1,175 @@
|
|
1
|
+
#encoding: UTF-8
|
2
|
+
require "ULL-ETSII-Alu3177-Quiz/version"
|
3
|
+
require 'colorize'
|
4
|
+
require 'erb'
|
5
|
+
|
6
|
+
module ULL
|
7
|
+
module ETSII
|
8
|
+
module Alu3177
|
9
|
+
module Quiz
|
10
|
+
|
11
|
+
WRONG = false
|
12
|
+
RIGHT = true
|
13
|
+
|
14
|
+
# Clase que permite la construcción de cuestionarios tipo test mediante un DSL
|
15
|
+
class Quiz
|
16
|
+
attr_accessor :name, :questions
|
17
|
+
|
18
|
+
# Recibe el nombre del test y un bloque con las preguntas y sus respuestas
|
19
|
+
#
|
20
|
+
# Ejemplo de uso:
|
21
|
+
# quiz = Quiz.new("Test 1"){
|
22
|
+
# question "Pregunta 1",
|
23
|
+
# wrong => "Respuesta incorrecta 1",
|
24
|
+
# wrong => "Respuesta incorrecta 2",
|
25
|
+
# wrong => "Respuesta incorrecta 3",
|
26
|
+
# right => "Respuesta correcta"
|
27
|
+
# }
|
28
|
+
def initialize(name, &block)
|
29
|
+
@counter = 0
|
30
|
+
@aciertos = 0
|
31
|
+
@name = name
|
32
|
+
@questions = []
|
33
|
+
|
34
|
+
instance_eval &block
|
35
|
+
end
|
36
|
+
|
37
|
+
# Pregunta incorrecta
|
38
|
+
#
|
39
|
+
# Avoid collisions
|
40
|
+
def wrong
|
41
|
+
@counter += 1
|
42
|
+
[@counter, WRONG]
|
43
|
+
end
|
44
|
+
|
45
|
+
# Pregunta correcta
|
46
|
+
def right
|
47
|
+
:right
|
48
|
+
end
|
49
|
+
|
50
|
+
# Método que recibe el título <em>title</em> de la pregunta y una serie de
|
51
|
+
# parámetros como respuestas
|
52
|
+
def question(title, anss)
|
53
|
+
answers = []
|
54
|
+
|
55
|
+
anss.each do |ans|
|
56
|
+
a = Answer.new(ans)
|
57
|
+
answers << a
|
58
|
+
end
|
59
|
+
|
60
|
+
q = Question.new(title, answers)
|
61
|
+
questions << q
|
62
|
+
end
|
63
|
+
|
64
|
+
# Ejecuta el test por consola. Presenta cada pregunta y las posibles respuestas.
|
65
|
+
# Al final muestra los resultados.
|
66
|
+
def run
|
67
|
+
aciertos = 0
|
68
|
+
puts name
|
69
|
+
questions.each do |q|
|
70
|
+
puts q
|
71
|
+
print "Su respuesta: "
|
72
|
+
resp = gets.chomp.to_i
|
73
|
+
raise IndexError, "Answer must be between 1 and #{q.answers.size}." unless resp <= q.answers.size and resp > 0
|
74
|
+
if q.answers[resp-1].state
|
75
|
+
puts "Correcto!".colorize(:light_green)
|
76
|
+
@aciertos += 1
|
77
|
+
else
|
78
|
+
correcta = q.answers.select { |ans| ans.state }.first
|
79
|
+
puts "Fallo, la respuesta correcta era #{correcta}".colorize(:red)
|
80
|
+
end
|
81
|
+
puts
|
82
|
+
end
|
83
|
+
puts "Has acertado el #{(@aciertos/questions.size.to_f)*100}% de las preguntas [#{@aciertos} de #{questions.size}]."
|
84
|
+
end
|
85
|
+
|
86
|
+
# Representación visual de un Test en forma de String.
|
87
|
+
def to_s
|
88
|
+
out = name + "\n"
|
89
|
+
questions.each do |q|
|
90
|
+
out << "#{q}\n"
|
91
|
+
end
|
92
|
+
out
|
93
|
+
end
|
94
|
+
|
95
|
+
# Genera el test en formato html.
|
96
|
+
# Dicho test es totalmente funcional, permitiendo la selección de respuestas y
|
97
|
+
# la corrección de las mismas
|
98
|
+
def to_html
|
99
|
+
# SetUp del fichero de salida
|
100
|
+
if not Dir.exist? "html"
|
101
|
+
# Copiamos el directorio html con los ficheros básicos
|
102
|
+
require 'fileutils'
|
103
|
+
FileUtils.cp_r File.expand_path(File.dirname(__FILE__)) + '/html', 'html'
|
104
|
+
end
|
105
|
+
# Generamos HTML
|
106
|
+
htmlFile = File.new("html/#{name.gsub(/[\ \\\/:]/, '_')}.html", "w")
|
107
|
+
raise IOError, 'Can\'t access to html output file' unless htmlFile
|
108
|
+
# Generamos JavaScript
|
109
|
+
jsFile = File.new("html/js/quiz.js", "w")
|
110
|
+
raise IOError, 'Can\'t access to javascript output file' unless jsFile
|
111
|
+
|
112
|
+
# Construimos los ERB y los escribimos en los ficheros
|
113
|
+
require 'templates'
|
114
|
+
rhtml = ERB.new(HTML_TEMPLATE)
|
115
|
+
htmlFile.syswrite(rhtml.result(binding))
|
116
|
+
htmlFile.close
|
117
|
+
|
118
|
+
rjs = ERB.new(JAVASCRIPT_TEMPLATE)
|
119
|
+
jsFile.syswrite(rjs.result(binding))
|
120
|
+
jsFile.close
|
121
|
+
|
122
|
+
|
123
|
+
end
|
124
|
+
|
125
|
+
end
|
126
|
+
|
127
|
+
# Clase que representa una de pregunta a un test.
|
128
|
+
class Question
|
129
|
+
attr_accessor :answers, :title
|
130
|
+
# Recibe un título <em>title</em> de la pregunta y el resto de parámetros son las
|
131
|
+
# posibles respuestas.
|
132
|
+
def initialize(title, anss)
|
133
|
+
raise ArgumentError, "Title has to be a String, got #{title.class}" unless title.is_a? String
|
134
|
+
@title = title
|
135
|
+
@answers = anss
|
136
|
+
end
|
137
|
+
|
138
|
+
# Representación visual de una pregunta en forma de String.
|
139
|
+
def to_s
|
140
|
+
out = "# #{@title}".colorize(:light_blue) + "\n"
|
141
|
+
i = 1
|
142
|
+
answers.each do |a|
|
143
|
+
out << " [#{i}] #{a}\n"
|
144
|
+
i += 1
|
145
|
+
end
|
146
|
+
out
|
147
|
+
end
|
148
|
+
end
|
149
|
+
|
150
|
+
# Clase que representa las respuestas a preguntas de un test.
|
151
|
+
class Answer
|
152
|
+
attr_reader :state, :value
|
153
|
+
|
154
|
+
# Recibe como parámetro una lista de dos elementos que contiene
|
155
|
+
# el <em>state</em> o estado de la respuesta (si es verdadera o falsa)
|
156
|
+
# y el <em>value</em> con el texto que la representa.
|
157
|
+
def initialize(ans)
|
158
|
+
raise ArgumentError, "Array spected, got #{ans.class}" unless ans.is_a? Array
|
159
|
+
raise IndexError, 'Must have two (2) elements; state and value' unless ans.size == 2
|
160
|
+
state = ans[0]
|
161
|
+
value = ans[1]
|
162
|
+
state == :right ? @state = RIGHT : @state = WRONG
|
163
|
+
@value = value
|
164
|
+
end
|
165
|
+
|
166
|
+
# Devuelve <em>value</em>, es decir, el texto que describe a la respuesta
|
167
|
+
def to_s
|
168
|
+
"#{@value}"
|
169
|
+
end
|
170
|
+
end
|
171
|
+
|
172
|
+
end
|
173
|
+
end
|
174
|
+
end
|
175
|
+
end
|
@@ -0,0 +1,77 @@
|
|
1
|
+
#encoding: UTF-8
|
2
|
+
module ULL
|
3
|
+
module ETSII
|
4
|
+
module Alu3177
|
5
|
+
module Quiz
|
6
|
+
|
7
|
+
JAVASCRIPT_TEMPLATE = %{
|
8
|
+
$(function() {
|
9
|
+
$( "#button" ).button();
|
10
|
+
<% for i in 1..questions.size %>
|
11
|
+
$( "#question<%=i%>" ).buttonset();
|
12
|
+
<%end%>
|
13
|
+
});
|
14
|
+
function run(){
|
15
|
+
<% for i in 1..questions.size %>
|
16
|
+
for (i=0;i<document.forms[0].preg<%=i%>.length;i++) {
|
17
|
+
if (document.forms[0].preg<%=i%>[i].checked) {
|
18
|
+
user_input = document.forms[0].preg<%=i%>[i].value;
|
19
|
+
if (user_input == "true") {
|
20
|
+
$( "#correccion<%=i%>" ).show("blind", 65);
|
21
|
+
text = document.getElementById("correccion<%=i%>_text");
|
22
|
+
text.innerHTML = "<span style='color: green;'><b>¡Respuesta Correcta!</b></span>";
|
23
|
+
}else{
|
24
|
+
$( "#correccion<%=i%>" ).show("blind", 65);
|
25
|
+
text = document.getElementById("correccion<%=i%>_text");
|
26
|
+
text.innerHTML = "<span style='color: red;'>Respuesta incorrecta ...</span>";
|
27
|
+
}
|
28
|
+
}
|
29
|
+
}
|
30
|
+
<%end%>
|
31
|
+
}
|
32
|
+
}
|
33
|
+
|
34
|
+
HTML_TEMPLATE = %{
|
35
|
+
<html>
|
36
|
+
<head>
|
37
|
+
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
|
38
|
+
<title><%= name %></title>
|
39
|
+
<link href="css/blitzer/jquery-ui-1.9.2.custom.min.css" rel="stylesheet">
|
40
|
+
<link href="css/base.css" rel="stylesheet">
|
41
|
+
<script src="js/jquery-1.8.3.js"></script>
|
42
|
+
<script src="js/jquery-ui-1.9.2.custom.min.js"></script>
|
43
|
+
<script src="js/quiz.js"></script>
|
44
|
+
</head>
|
45
|
+
<body>
|
46
|
+
<div class="contenedor">
|
47
|
+
<h1><%= name %></h1>
|
48
|
+
<form action="">
|
49
|
+
<% i=0; questions.each do |q| %>
|
50
|
+
<div id="question_<%=i%>" class="question">
|
51
|
+
<h3><%= q.title %></h3>
|
52
|
+
<div id="question<%=i+1%>">
|
53
|
+
<% j=0; q.answers.each do |a| %>
|
54
|
+
<input type="radio" id="preg<%=i%>.<%=j+1%>" name="preg<%=i+1%>" value="<%= a.state %>"><label for="preg<%=i%>.<%=j+1%>"><%= a.value %></label>
|
55
|
+
<% j+=1;end %>
|
56
|
+
</div>
|
57
|
+
|
58
|
+
<div id="correccion<%=i+1%>" class="ui-state-highlight ui-corner-all" style="display: none;margin-top: 20px;">
|
59
|
+
<p><span class="ui-icon ui-icon-info" style="float: left; margin-left: .3em;"></span>
|
60
|
+
<p id="correccion<%=i+1%>_text"></p>
|
61
|
+
</p>
|
62
|
+
</div>
|
63
|
+
</div>
|
64
|
+
<% i += 1 %>
|
65
|
+
<% end %>
|
66
|
+
<input id="button" value="Corregir" onclick="run()" />
|
67
|
+
</form>
|
68
|
+
</div>
|
69
|
+
</body>
|
70
|
+
</html>
|
71
|
+
}
|
72
|
+
|
73
|
+
|
74
|
+
end
|
75
|
+
end
|
76
|
+
end
|
77
|
+
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
body{
|
2
|
+
font: 78.5% "Trebuchet MS", sans-serif;
|
3
|
+
margin: 50px;
|
4
|
+
}
|
5
|
+
|
6
|
+
h1{
|
7
|
+
font-size: 350%;
|
8
|
+
color: #E0E0E0;
|
9
|
+
}
|
10
|
+
|
11
|
+
h3{
|
12
|
+
color: #C40F45;
|
13
|
+
}
|
14
|
+
|
15
|
+
.contenedor{
|
16
|
+
background-color: #666;
|
17
|
+
margin-left: 5em;
|
18
|
+
padding: 1em 1em 1em 10em;
|
19
|
+
width: 65%;
|
20
|
+
}
|
21
|
+
|
22
|
+
.question{
|
23
|
+
background-color: #AAA;
|
24
|
+
padding: 1em 1em 2em 1em;
|
25
|
+
margin-bottom: 2em;
|
26
|
+
width: 80%;
|
27
|
+
}
|
28
|
+
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
@@ -0,0 +1,5 @@
|
|
1
|
+
/*! jQuery UI - v1.9.2 - 2012-12-05
|
2
|
+
* http://jqueryui.com
|
3
|
+
* Includes: jquery.ui.core.css, jquery.ui.resizable.css, jquery.ui.button.css, jquery.ui.dialog.css, jquery.ui.progressbar.css
|
4
|
+
* To view and modify this theme, visit http://jqueryui.com/themeroller/?ffDefault=Arial%2Csans-serif&fwDefault=bold&fsDefault=1.1em&cornerRadius=6px&bgColorHeader=cc0000&bgTextureHeader=03_highlight_soft.png&bgImgOpacityHeader=15&borderColorHeader=e3a1a1&fcHeader=ffffff&iconColorHeader=ffffff&bgColorContent=ffffff&bgTextureContent=01_flat.png&bgImgOpacityContent=75&borderColorContent=eeeeee&fcContent=333333&iconColorContent=cc0000&bgColorDefault=eeeeee&bgTextureDefault=04_highlight_hard.png&bgImgOpacityDefault=100&borderColorDefault=d8dcdf&fcDefault=004276&iconColorDefault=cc0000&bgColorHover=f6f6f6&bgTextureHover=04_highlight_hard.png&bgImgOpacityHover=100&borderColorHover=cdd5da&fcHover=111111&iconColorHover=cc0000&bgColorActive=ffffff&bgTextureActive=01_flat.png&bgImgOpacityActive=65&borderColorActive=eeeeee&fcActive=cc0000&iconColorActive=cc0000&bgColorHighlight=fbf8ee&bgTextureHighlight=02_glass.png&bgImgOpacityHighlight=55&borderColorHighlight=fcd3a1&fcHighlight=444444&iconColorHighlight=004276&bgColorError=f3d8d8&bgTextureError=08_diagonals_thick.png&bgImgOpacityError=75&borderColorError=cc0000&fcError=2e2e2e&iconColorError=cc0000&bgColorOverlay=a6a6a6&bgTextureOverlay=09_dots_small.png&bgImgOpacityOverlay=65&opacityOverlay=40&bgColorShadow=333333&bgTextureShadow=01_flat.png&bgImgOpacityShadow=0&opacityShadow=10&thicknessShadow=8px&offsetTopShadow=-8px&offsetLeftShadow=-8px&cornerRadiusShadow=8px
|
5
|
+
* Copyright (c) 2012 jQuery Foundation and other contributors Licensed MIT */.ui-helper-hidden{display:none}.ui-helper-hidden-accessible{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.ui-helper-reset{margin:0;padding:0;border:0;outline:0;line-height:1.3;text-decoration:none;font-size:100%;list-style:none}.ui-helper-clearfix:before,.ui-helper-clearfix:after{content:"";display:table}.ui-helper-clearfix:after{clear:both}.ui-helper-clearfix{zoom:1}.ui-helper-zfix{width:100%;height:100%;top:0;left:0;position:absolute;opacity:0;filter:Alpha(Opacity=0)}.ui-state-disabled{cursor:default!important}.ui-icon{display:block;text-indent:-99999px;overflow:hidden;background-repeat:no-repeat}.ui-widget-overlay{position:absolute;top:0;left:0;width:100%;height:100%}.ui-resizable{position:relative}.ui-resizable-handle{position:absolute;font-size:0.1px;display:block}.ui-resizable-disabled .ui-resizable-handle,.ui-resizable-autohide .ui-resizable-handle{display:none}.ui-resizable-n{cursor:n-resize;height:7px;width:100%;top:-5px;left:0}.ui-resizable-s{cursor:s-resize;height:7px;width:100%;bottom:-5px;left:0}.ui-resizable-e{cursor:e-resize;width:7px;right:-5px;top:0;height:100%}.ui-resizable-w{cursor:w-resize;width:7px;left:-5px;top:0;height:100%}.ui-resizable-se{cursor:se-resize;width:12px;height:12px;right:1px;bottom:1px}.ui-resizable-sw{cursor:sw-resize;width:9px;height:9px;left:-5px;bottom:-5px}.ui-resizable-nw{cursor:nw-resize;width:9px;height:9px;left:-5px;top:-5px}.ui-resizable-ne{cursor:ne-resize;width:9px;height:9px;right:-5px;top:-5px}.ui-button{display:inline-block;position:relative;padding:0;margin-right:.1em;cursor:pointer;text-align:center;zoom:1;overflow:visible}.ui-button,.ui-button:link,.ui-button:visited,.ui-button:hover,.ui-button:active{text-decoration:none}.ui-button-icon-only{width:2.2em}button.ui-button-icon-only{width:2.4em}.ui-button-icons-only{width:3.4em}button.ui-button-icons-only{width:3.7em}.ui-button .ui-button-text{display:block;line-height:1.4}.ui-button-text-only .ui-button-text{padding:.4em 1em}.ui-button-icon-only .ui-button-text,.ui-button-icons-only .ui-button-text{padding:.4em;text-indent:-9999999px}.ui-button-text-icon-primary .ui-button-text,.ui-button-text-icons .ui-button-text{padding:.4em 1em .4em 2.1em}.ui-button-text-icon-secondary .ui-button-text,.ui-button-text-icons .ui-button-text{padding:.4em 2.1em .4em 1em}.ui-button-text-icons .ui-button-text{padding-left:2.1em;padding-right:2.1em}input.ui-button{padding:.4em 1em}.ui-button-icon-only .ui-icon,.ui-button-text-icon-primary .ui-icon,.ui-button-text-icon-secondary .ui-icon,.ui-button-text-icons .ui-icon,.ui-button-icons-only .ui-icon{position:absolute;top:50%;margin-top:-8px}.ui-button-icon-only .ui-icon{left:50%;margin-left:-8px}.ui-button-text-icon-primary .ui-button-icon-primary,.ui-button-text-icons .ui-button-icon-primary,.ui-button-icons-only .ui-button-icon-primary{left:.5em}.ui-button-text-icon-secondary .ui-button-icon-secondary,.ui-button-text-icons .ui-button-icon-secondary,.ui-button-icons-only .ui-button-icon-secondary{right:.5em}.ui-button-text-icons .ui-button-icon-secondary,.ui-button-icons-only .ui-button-icon-secondary{right:.5em}.ui-buttonset{margin-right:7px}.ui-buttonset .ui-button{margin-left:0;margin-right:-.3em}button.ui-button::-moz-focus-inner{border:0;padding:0}.ui-dialog{position:absolute;top:0;left:0;padding:.2em;width:300px;overflow:hidden}.ui-dialog .ui-dialog-titlebar{padding:.4em 1em;position:relative}.ui-dialog .ui-dialog-title{float:left;margin:.1em 16px .1em 0}.ui-dialog .ui-dialog-titlebar-close{position:absolute;right:.3em;top:50%;width:19px;margin:-10px 0 0 0;padding:1px;height:18px}.ui-dialog .ui-dialog-titlebar-close span{display:block;margin:1px}.ui-dialog .ui-dialog-titlebar-close:hover,.ui-dialog .ui-dialog-titlebar-close:focus{padding:0}.ui-dialog .ui-dialog-content{position:relative;border:0;padding:.5em 1em;background:none;overflow:auto;zoom:1}.ui-dialog .ui-dialog-buttonpane{text-align:left;border-width:1px 0 0 0;background-image:none;margin:.5em 0 0 0;padding:.3em 1em .5em .4em}.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset{float:right}.ui-dialog .ui-dialog-buttonpane button{margin:.5em .4em .5em 0;cursor:pointer}.ui-dialog .ui-resizable-se{width:14px;height:14px;right:3px;bottom:3px}.ui-draggable .ui-dialog-titlebar{cursor:move}.ui-progressbar{height:2em;text-align:left;overflow:hidden}.ui-progressbar .ui-progressbar-value{margin:-1px;height:100%}.ui-widget{font-family:Arial,sans-serif;font-size:1.1em}.ui-widget .ui-widget{font-size:1em}.ui-widget input,.ui-widget select,.ui-widget textarea,.ui-widget button{font-family:Arial,sans-serif;font-size:1em}.ui-widget-content{border:1px solid #eee;background:#fff url(images/ui-bg_flat_75_ffffff_40x100.png) 50% 50% repeat-x;color:#333}.ui-widget-content a{color:#333}.ui-widget-header{border:1px solid #e3a1a1;background:#c00 url(images/ui-bg_highlight-soft_15_cc0000_1x100.png) 50% 50% repeat-x;color:#fff;font-weight:bold}.ui-widget-header a{color:#fff}.ui-state-default,.ui-widget-content .ui-state-default,.ui-widget-header .ui-state-default{border:1px solid #d8dcdf;background:#eee url(images/ui-bg_highlight-hard_100_eeeeee_1x100.png) 50% 50% repeat-x;font-weight:bold;color:#004276}.ui-state-default a,.ui-state-default a:link,.ui-state-default a:visited{color:#004276;text-decoration:none}.ui-state-hover,.ui-widget-content .ui-state-hover,.ui-widget-header .ui-state-hover,.ui-state-focus,.ui-widget-content .ui-state-focus,.ui-widget-header .ui-state-focus{border:1px solid #cdd5da;background:#f6f6f6 url(images/ui-bg_highlight-hard_100_f6f6f6_1x100.png) 50% 50% repeat-x;font-weight:bold;color:#111}.ui-state-hover a,.ui-state-hover a:hover,.ui-state-hover a:link,.ui-state-hover a:visited{color:#111;text-decoration:none}.ui-state-active,.ui-widget-content .ui-state-active,.ui-widget-header .ui-state-active{border:1px solid #eee;background:#fff url(images/ui-bg_flat_65_ffffff_40x100.png) 50% 50% repeat-x;font-weight:bold;color:#c00}.ui-state-active a,.ui-state-active a:link,.ui-state-active a:visited{color:#c00;text-decoration:none}.ui-state-highlight,.ui-widget-content .ui-state-highlight,.ui-widget-header .ui-state-highlight{border:1px solid #fcd3a1;background:#fbf8ee url(images/ui-bg_glass_55_fbf8ee_1x400.png) 50% 50% repeat-x;color:#444}.ui-state-highlight a,.ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a{color:#444}.ui-state-error,.ui-widget-content .ui-state-error,.ui-widget-header .ui-state-error{border:1px solid #c00;background:#f3d8d8 url(images/ui-bg_diagonals-thick_75_f3d8d8_40x40.png) 50% 50% repeat;color:#2e2e2e}.ui-state-error a,.ui-widget-content .ui-state-error a,.ui-widget-header .ui-state-error a{color:#2e2e2e}.ui-state-error-text,.ui-widget-content .ui-state-error-text,.ui-widget-header .ui-state-error-text{color:#2e2e2e}.ui-priority-primary,.ui-widget-content .ui-priority-primary,.ui-widget-header .ui-priority-primary{font-weight:bold}.ui-priority-secondary,.ui-widget-content .ui-priority-secondary,.ui-widget-header .ui-priority-secondary{opacity:.7;filter:Alpha(Opacity=70);font-weight:normal}.ui-state-disabled,.ui-widget-content .ui-state-disabled,.ui-widget-header .ui-state-disabled{opacity:.35;filter:Alpha(Opacity=35);background-image:none}.ui-state-disabled .ui-icon{filter:Alpha(Opacity=35)}.ui-icon{width:16px;height:16px;background-image:url(images/ui-icons_cc0000_256x240.png)}.ui-widget-content .ui-icon{background-image:url(images/ui-icons_cc0000_256x240.png)}.ui-widget-header .ui-icon{background-image:url(images/ui-icons_ffffff_256x240.png)}.ui-state-default .ui-icon{background-image:url(images/ui-icons_cc0000_256x240.png)}.ui-state-hover .ui-icon,.ui-state-focus .ui-icon{background-image:url(images/ui-icons_cc0000_256x240.png)}.ui-state-active .ui-icon{background-image:url(images/ui-icons_cc0000_256x240.png)}.ui-state-highlight .ui-icon{background-image:url(images/ui-icons_004276_256x240.png)}.ui-state-error .ui-icon,.ui-state-error-text .ui-icon{background-image:url(images/ui-icons_cc0000_256x240.png)}.ui-icon-carat-1-n{background-position:0 0}.ui-icon-carat-1-ne{background-position:-16px 0}.ui-icon-carat-1-e{background-position:-32px 0}.ui-icon-carat-1-se{background-position:-48px 0}.ui-icon-carat-1-s{background-position:-64px 0}.ui-icon-carat-1-sw{background-position:-80px 0}.ui-icon-carat-1-w{background-position:-96px 0}.ui-icon-carat-1-nw{background-position:-112px 0}.ui-icon-carat-2-n-s{background-position:-128px 0}.ui-icon-carat-2-e-w{background-position:-144px 0}.ui-icon-triangle-1-n{background-position:0 -16px}.ui-icon-triangle-1-ne{background-position:-16px -16px}.ui-icon-triangle-1-e{background-position:-32px -16px}.ui-icon-triangle-1-se{background-position:-48px -16px}.ui-icon-triangle-1-s{background-position:-64px -16px}.ui-icon-triangle-1-sw{background-position:-80px -16px}.ui-icon-triangle-1-w{background-position:-96px -16px}.ui-icon-triangle-1-nw{background-position:-112px -16px}.ui-icon-triangle-2-n-s{background-position:-128px -16px}.ui-icon-triangle-2-e-w{background-position:-144px -16px}.ui-icon-arrow-1-n{background-position:0 -32px}.ui-icon-arrow-1-ne{background-position:-16px -32px}.ui-icon-arrow-1-e{background-position:-32px -32px}.ui-icon-arrow-1-se{background-position:-48px -32px}.ui-icon-arrow-1-s{background-position:-64px -32px}.ui-icon-arrow-1-sw{background-position:-80px -32px}.ui-icon-arrow-1-w{background-position:-96px -32px}.ui-icon-arrow-1-nw{background-position:-112px -32px}.ui-icon-arrow-2-n-s{background-position:-128px -32px}.ui-icon-arrow-2-ne-sw{background-position:-144px -32px}.ui-icon-arrow-2-e-w{background-position:-160px -32px}.ui-icon-arrow-2-se-nw{background-position:-176px -32px}.ui-icon-arrowstop-1-n{background-position:-192px -32px}.ui-icon-arrowstop-1-e{background-position:-208px -32px}.ui-icon-arrowstop-1-s{background-position:-224px -32px}.ui-icon-arrowstop-1-w{background-position:-240px -32px}.ui-icon-arrowthick-1-n{background-position:0 -48px}.ui-icon-arrowthick-1-ne{background-position:-16px -48px}.ui-icon-arrowthick-1-e{background-position:-32px -48px}.ui-icon-arrowthick-1-se{background-position:-48px -48px}.ui-icon-arrowthick-1-s{background-position:-64px -48px}.ui-icon-arrowthick-1-sw{background-position:-80px -48px}.ui-icon-arrowthick-1-w{background-position:-96px -48px}.ui-icon-arrowthick-1-nw{background-position:-112px -48px}.ui-icon-arrowthick-2-n-s{background-position:-128px -48px}.ui-icon-arrowthick-2-ne-sw{background-position:-144px -48px}.ui-icon-arrowthick-2-e-w{background-position:-160px -48px}.ui-icon-arrowthick-2-se-nw{background-position:-176px -48px}.ui-icon-arrowthickstop-1-n{background-position:-192px -48px}.ui-icon-arrowthickstop-1-e{background-position:-208px -48px}.ui-icon-arrowthickstop-1-s{background-position:-224px -48px}.ui-icon-arrowthickstop-1-w{background-position:-240px -48px}.ui-icon-arrowreturnthick-1-w{background-position:0 -64px}.ui-icon-arrowreturnthick-1-n{background-position:-16px -64px}.ui-icon-arrowreturnthick-1-e{background-position:-32px -64px}.ui-icon-arrowreturnthick-1-s{background-position:-48px -64px}.ui-icon-arrowreturn-1-w{background-position:-64px -64px}.ui-icon-arrowreturn-1-n{background-position:-80px -64px}.ui-icon-arrowreturn-1-e{background-position:-96px -64px}.ui-icon-arrowreturn-1-s{background-position:-112px -64px}.ui-icon-arrowrefresh-1-w{background-position:-128px -64px}.ui-icon-arrowrefresh-1-n{background-position:-144px -64px}.ui-icon-arrowrefresh-1-e{background-position:-160px -64px}.ui-icon-arrowrefresh-1-s{background-position:-176px -64px}.ui-icon-arrow-4{background-position:0 -80px}.ui-icon-arrow-4-diag{background-position:-16px -80px}.ui-icon-extlink{background-position:-32px -80px}.ui-icon-newwin{background-position:-48px -80px}.ui-icon-refresh{background-position:-64px -80px}.ui-icon-shuffle{background-position:-80px -80px}.ui-icon-transfer-e-w{background-position:-96px -80px}.ui-icon-transferthick-e-w{background-position:-112px -80px}.ui-icon-folder-collapsed{background-position:0 -96px}.ui-icon-folder-open{background-position:-16px -96px}.ui-icon-document{background-position:-32px -96px}.ui-icon-document-b{background-position:-48px -96px}.ui-icon-note{background-position:-64px -96px}.ui-icon-mail-closed{background-position:-80px -96px}.ui-icon-mail-open{background-position:-96px -96px}.ui-icon-suitcase{background-position:-112px -96px}.ui-icon-comment{background-position:-128px -96px}.ui-icon-person{background-position:-144px -96px}.ui-icon-print{background-position:-160px -96px}.ui-icon-trash{background-position:-176px -96px}.ui-icon-locked{background-position:-192px -96px}.ui-icon-unlocked{background-position:-208px -96px}.ui-icon-bookmark{background-position:-224px -96px}.ui-icon-tag{background-position:-240px -96px}.ui-icon-home{background-position:0 -112px}.ui-icon-flag{background-position:-16px -112px}.ui-icon-calendar{background-position:-32px -112px}.ui-icon-cart{background-position:-48px -112px}.ui-icon-pencil{background-position:-64px -112px}.ui-icon-clock{background-position:-80px -112px}.ui-icon-disk{background-position:-96px -112px}.ui-icon-calculator{background-position:-112px -112px}.ui-icon-zoomin{background-position:-128px -112px}.ui-icon-zoomout{background-position:-144px -112px}.ui-icon-search{background-position:-160px -112px}.ui-icon-wrench{background-position:-176px -112px}.ui-icon-gear{background-position:-192px -112px}.ui-icon-heart{background-position:-208px -112px}.ui-icon-star{background-position:-224px -112px}.ui-icon-link{background-position:-240px -112px}.ui-icon-cancel{background-position:0 -128px}.ui-icon-plus{background-position:-16px -128px}.ui-icon-plusthick{background-position:-32px -128px}.ui-icon-minus{background-position:-48px -128px}.ui-icon-minusthick{background-position:-64px -128px}.ui-icon-close{background-position:-80px -128px}.ui-icon-closethick{background-position:-96px -128px}.ui-icon-key{background-position:-112px -128px}.ui-icon-lightbulb{background-position:-128px -128px}.ui-icon-scissors{background-position:-144px -128px}.ui-icon-clipboard{background-position:-160px -128px}.ui-icon-copy{background-position:-176px -128px}.ui-icon-contact{background-position:-192px -128px}.ui-icon-image{background-position:-208px -128px}.ui-icon-video{background-position:-224px -128px}.ui-icon-script{background-position:-240px -128px}.ui-icon-alert{background-position:0 -144px}.ui-icon-info{background-position:-16px -144px}.ui-icon-notice{background-position:-32px -144px}.ui-icon-help{background-position:-48px -144px}.ui-icon-check{background-position:-64px -144px}.ui-icon-bullet{background-position:-80px -144px}.ui-icon-radio-on{background-position:-96px -144px}.ui-icon-radio-off{background-position:-112px -144px}.ui-icon-pin-w{background-position:-128px -144px}.ui-icon-pin-s{background-position:-144px -144px}.ui-icon-play{background-position:0 -160px}.ui-icon-pause{background-position:-16px -160px}.ui-icon-seek-next{background-position:-32px -160px}.ui-icon-seek-prev{background-position:-48px -160px}.ui-icon-seek-end{background-position:-64px -160px}.ui-icon-seek-start{background-position:-80px -160px}.ui-icon-seek-first{background-position:-80px -160px}.ui-icon-stop{background-position:-96px -160px}.ui-icon-eject{background-position:-112px -160px}.ui-icon-volume-off{background-position:-128px -160px}.ui-icon-volume-on{background-position:-144px -160px}.ui-icon-power{background-position:0 -176px}.ui-icon-signal-diag{background-position:-16px -176px}.ui-icon-signal{background-position:-32px -176px}.ui-icon-battery-0{background-position:-48px -176px}.ui-icon-battery-1{background-position:-64px -176px}.ui-icon-battery-2{background-position:-80px -176px}.ui-icon-battery-3{background-position:-96px -176px}.ui-icon-circle-plus{background-position:0 -192px}.ui-icon-circle-minus{background-position:-16px -192px}.ui-icon-circle-close{background-position:-32px -192px}.ui-icon-circle-triangle-e{background-position:-48px -192px}.ui-icon-circle-triangle-s{background-position:-64px -192px}.ui-icon-circle-triangle-w{background-position:-80px -192px}.ui-icon-circle-triangle-n{background-position:-96px -192px}.ui-icon-circle-arrow-e{background-position:-112px -192px}.ui-icon-circle-arrow-s{background-position:-128px -192px}.ui-icon-circle-arrow-w{background-position:-144px -192px}.ui-icon-circle-arrow-n{background-position:-160px -192px}.ui-icon-circle-zoomin{background-position:-176px -192px}.ui-icon-circle-zoomout{background-position:-192px -192px}.ui-icon-circle-check{background-position:-208px -192px}.ui-icon-circlesmall-plus{background-position:0 -208px}.ui-icon-circlesmall-minus{background-position:-16px -208px}.ui-icon-circlesmall-close{background-position:-32px -208px}.ui-icon-squaresmall-plus{background-position:-48px -208px}.ui-icon-squaresmall-minus{background-position:-64px -208px}.ui-icon-squaresmall-close{background-position:-80px -208px}.ui-icon-grip-dotted-vertical{background-position:0 -224px}.ui-icon-grip-dotted-horizontal{background-position:-16px -224px}.ui-icon-grip-solid-vertical{background-position:-32px -224px}.ui-icon-grip-solid-horizontal{background-position:-48px -224px}.ui-icon-gripsmall-diagonal-se{background-position:-64px -224px}.ui-icon-grip-diagonal-se{background-position:-80px -224px}.ui-corner-all,.ui-corner-top,.ui-corner-left,.ui-corner-tl{-moz-border-radius-topleft:6px;-webkit-border-top-left-radius:6px;-khtml-border-top-left-radius:6px;border-top-left-radius:6px}.ui-corner-all,.ui-corner-top,.ui-corner-right,.ui-corner-tr{-moz-border-radius-topright:6px;-webkit-border-top-right-radius:6px;-khtml-border-top-right-radius:6px;border-top-right-radius:6px}.ui-corner-all,.ui-corner-bottom,.ui-corner-left,.ui-corner-bl{-moz-border-radius-bottomleft:6px;-webkit-border-bottom-left-radius:6px;-khtml-border-bottom-left-radius:6px;border-bottom-left-radius:6px}.ui-corner-all,.ui-corner-bottom,.ui-corner-right,.ui-corner-br{-moz-border-radius-bottomright:6px;-webkit-border-bottom-right-radius:6px;-khtml-border-bottom-right-radius:6px;border-bottom-right-radius:6px}.ui-widget-overlay{background:#a6a6a6 url(images/ui-bg_dots-small_65_a6a6a6_2x2.png) 50% 50% repeat;opacity:.4;filter:Alpha(Opacity=40)}.ui-widget-shadow{margin:-8px 0 0 -8px;padding:8px;background:#333 url(images/ui-bg_flat_0_333333_40x100.png) 50% 50% repeat-x;opacity:.1;filter:Alpha(Opacity=10);-moz-border-radius:8px;-khtml-border-radius:8px;-webkit-border-radius:8px;border-radius:8px}
|