Remove legacy framework support: clean up for Bootstrap 5 only
- Remove all Bootstrap 2/3 source files and containers - Remove jQuery UI datepicker dependencies and files - Remove legacy input extensions (select2, typeahead, wysihtml5) - Remove old test framework libraries - Clean up dist files to match source removal - Prepare codebase for Bootstrap 5 only distribution
							
								
								
									
										2
									
								
								dist/app.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
							
								
								
									
										1848
									
								
								dist/bootstrap-editable/js/bootstrap-editable.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
							
								
								
									
										1421
									
								
								dist/bootstrap3-editable/js/bootstrap-editable.js
									
									
									
									
										vendored
									
									
								
							
							
						
						| Before Width: | Height: | Size: 1.7 KiB | 
| Before Width: | Height: | Size: 212 B | 
| Before Width: | Height: | Size: 206 B | 
| Before Width: | Height: | Size: 336 B | 
| Before Width: | Height: | Size: 341 B | 
| Before Width: | Height: | Size: 332 B | 
| Before Width: | Height: | Size: 5.7 KiB | 
| Before Width: | Height: | Size: 333 B | 
| Before Width: | Height: | Size: 292 B | 
| Before Width: | Height: | Size: 4.4 KiB | 
| Before Width: | Height: | Size: 4.4 KiB | 
| Before Width: | Height: | Size: 4.4 KiB | 
| Before Width: | Height: | Size: 4.4 KiB | 
| Before Width: | Height: | Size: 4.4 KiB | 
| Before Width: | Height: | Size: 4.4 KiB | 
| Before Width: | Height: | Size: 4.4 KiB | 
| @@ -1,649 +0,0 @@ | ||||
| /*! jQuery UI - v1.10.3 - 2013-08-05 | ||||
| * http://jqueryui.com | ||||
| * Includes: jquery.ui.core.css, jquery.ui.datepicker.css | ||||
| * To view and modify this theme, visit http://jqueryui.com/themeroller/?ffDefault=Lucida%20Grande%2CLucida%20Sans%2CArial%2Csans-serif&fwDefault=bold&fsDefault=1.1em&cornerRadius=5px&bgColorHeader=5c9ccc&bgTextureHeader=gloss_wave&bgImgOpacityHeader=55&borderColorHeader=4297d7&fcHeader=ffffff&iconColorHeader=d8e7f3&bgColorContent=fcfdfd&bgTextureContent=inset_hard&bgImgOpacityContent=100&borderColorContent=a6c9e2&fcContent=222222&iconColorContent=469bdd&bgColorDefault=dfeffc&bgTextureDefault=glass&bgImgOpacityDefault=85&borderColorDefault=c5dbec&fcDefault=2e6e9e&iconColorDefault=6da8d5&bgColorHover=d0e5f5&bgTextureHover=glass&bgImgOpacityHover=75&borderColorHover=79b7e7&fcHover=1d5987&iconColorHover=217bc0&bgColorActive=f5f8f9&bgTextureActive=inset_hard&bgImgOpacityActive=100&borderColorActive=79b7e7&fcActive=e17009&iconColorActive=f9bd01&bgColorHighlight=fbec88&bgTextureHighlight=flat&bgImgOpacityHighlight=55&borderColorHighlight=fad42e&fcHighlight=363636&iconColorHighlight=2e83ff&bgColorError=fef1ec&bgTextureError=glass&bgImgOpacityError=95&borderColorError=cd0a0a&fcError=cd0a0a&iconColorError=cd0a0a&bgColorOverlay=aaaaaa&bgTextureOverlay=flat&bgImgOpacityOverlay=0&opacityOverlay=30&bgColorShadow=aaaaaa&bgTextureShadow=flat&bgImgOpacityShadow=0&opacityShadow=30&thicknessShadow=8px&offsetTopShadow=-8px&offsetLeftShadow=-8px&cornerRadiusShadow=8px | ||||
| * Copyright 2013 jQuery Foundation and other contributors Licensed MIT */ | ||||
|  | ||||
| /* Layout helpers | ||||
| ----------------------------------*/ | ||||
| .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; | ||||
| 	border-collapse: collapse; | ||||
| } | ||||
| .ui-helper-clearfix:after { | ||||
| 	clear: both; | ||||
| } | ||||
| .ui-helper-clearfix { | ||||
| 	min-height: 0; /* support: IE7 */ | ||||
| } | ||||
| .ui-helper-zfix { | ||||
| 	width: 100%; | ||||
| 	height: 100%; | ||||
| 	top: 0; | ||||
| 	left: 0; | ||||
| 	position: absolute; | ||||
| 	opacity: 0; | ||||
| 	filter:Alpha(Opacity=0); | ||||
| } | ||||
|  | ||||
| .ui-front { | ||||
| 	z-index: 100; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Interaction Cues | ||||
| ----------------------------------*/ | ||||
| .ui-state-disabled { | ||||
| 	cursor: default !important; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Icons | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* states and images */ | ||||
| .ui-icon { | ||||
| 	display: block; | ||||
| 	text-indent: -99999px; | ||||
| 	overflow: hidden; | ||||
| 	background-repeat: no-repeat; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Misc visuals | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* Overlays */ | ||||
| .ui-widget-overlay { | ||||
| 	position: fixed; | ||||
| 	top: 0; | ||||
| 	left: 0; | ||||
| 	width: 100%; | ||||
| 	height: 100%; | ||||
| } | ||||
| .ui-datepicker { | ||||
| 	width: 17em; | ||||
| 	padding: .2em .2em 0; | ||||
| 	display: none; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-header { | ||||
| 	position: relative; | ||||
| 	padding: .2em 0; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev, | ||||
| .ui-datepicker .ui-datepicker-next { | ||||
| 	position: absolute; | ||||
| 	top: 2px; | ||||
| 	width: 1.8em; | ||||
| 	height: 1.8em; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev-hover, | ||||
| .ui-datepicker .ui-datepicker-next-hover { | ||||
| 	top: 1px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev { | ||||
| 	left: 2px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-next { | ||||
| 	right: 2px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev-hover { | ||||
| 	left: 1px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-next-hover { | ||||
| 	right: 1px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev span, | ||||
| .ui-datepicker .ui-datepicker-next span { | ||||
| 	display: block; | ||||
| 	position: absolute; | ||||
| 	left: 50%; | ||||
| 	margin-left: -8px; | ||||
| 	top: 50%; | ||||
| 	margin-top: -8px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-title { | ||||
| 	margin: 0 2.3em; | ||||
| 	line-height: 1.8em; | ||||
| 	text-align: center; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-title select { | ||||
| 	font-size: 1em; | ||||
| 	margin: 1px 0; | ||||
| } | ||||
| .ui-datepicker select.ui-datepicker-month-year { | ||||
| 	width: 100%; | ||||
| } | ||||
| .ui-datepicker select.ui-datepicker-month, | ||||
| .ui-datepicker select.ui-datepicker-year { | ||||
| 	width: 49%; | ||||
| } | ||||
| .ui-datepicker table { | ||||
| 	width: 100%; | ||||
| 	font-size: .9em; | ||||
| 	border-collapse: collapse; | ||||
| 	margin: 0 0 .4em; | ||||
| } | ||||
| .ui-datepicker th { | ||||
| 	padding: .7em .3em; | ||||
| 	text-align: center; | ||||
| 	font-weight: bold; | ||||
| 	border: 0; | ||||
| } | ||||
| .ui-datepicker td { | ||||
| 	border: 0; | ||||
| 	padding: 1px; | ||||
| } | ||||
| .ui-datepicker td span, | ||||
| .ui-datepicker td a { | ||||
| 	display: block; | ||||
| 	padding: .2em; | ||||
| 	text-align: right; | ||||
| 	text-decoration: none; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-buttonpane { | ||||
| 	background-image: none; | ||||
| 	margin: .7em 0 0 0; | ||||
| 	padding: 0 .2em; | ||||
| 	border-left: 0; | ||||
| 	border-right: 0; | ||||
| 	border-bottom: 0; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-buttonpane button { | ||||
| 	float: right; | ||||
| 	margin: .5em .2em .4em; | ||||
| 	cursor: pointer; | ||||
| 	padding: .2em .6em .3em .6em; | ||||
| 	width: auto; | ||||
| 	overflow: visible; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { | ||||
| 	float: left; | ||||
| } | ||||
|  | ||||
| /* with multiple calendars */ | ||||
| .ui-datepicker.ui-datepicker-multi { | ||||
| 	width: auto; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-group { | ||||
| 	float: left; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-group table { | ||||
| 	width: 95%; | ||||
| 	margin: 0 auto .4em; | ||||
| } | ||||
| .ui-datepicker-multi-2 .ui-datepicker-group { | ||||
| 	width: 50%; | ||||
| } | ||||
| .ui-datepicker-multi-3 .ui-datepicker-group { | ||||
| 	width: 33.3%; | ||||
| } | ||||
| .ui-datepicker-multi-4 .ui-datepicker-group { | ||||
| 	width: 25%; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header, | ||||
| .ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { | ||||
| 	border-left-width: 0; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-buttonpane { | ||||
| 	clear: left; | ||||
| } | ||||
| .ui-datepicker-row-break { | ||||
| 	clear: both; | ||||
| 	width: 100%; | ||||
| 	font-size: 0; | ||||
| } | ||||
|  | ||||
| /* RTL support */ | ||||
| .ui-datepicker-rtl { | ||||
| 	direction: rtl; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-prev { | ||||
| 	right: 2px; | ||||
| 	left: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-next { | ||||
| 	left: 2px; | ||||
| 	right: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-prev:hover { | ||||
| 	right: 1px; | ||||
| 	left: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-next:hover { | ||||
| 	left: 1px; | ||||
| 	right: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-buttonpane { | ||||
| 	clear: right; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-buttonpane button { | ||||
| 	float: left; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current, | ||||
| .ui-datepicker-rtl .ui-datepicker-group { | ||||
| 	float: right; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header, | ||||
| .ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { | ||||
| 	border-right-width: 0; | ||||
| 	border-left-width: 1px; | ||||
| } | ||||
|  | ||||
| /* Component containers | ||||
| ----------------------------------*/ | ||||
| .ui-widget { | ||||
| 	font-family: Lucida Grande,Lucida Sans,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: Lucida Grande,Lucida Sans,Arial,sans-serif; | ||||
| 	font-size: 1em; | ||||
| } | ||||
| .ui-widget-content { | ||||
| 	border: 1px solid #a6c9e2; | ||||
| 	background: #fcfdfd url(images/ui-bg_inset-hard_100_fcfdfd_1x100.png) 50% bottom repeat-x; | ||||
| 	color: #222222; | ||||
| } | ||||
| .ui-widget-content a { | ||||
| 	color: #222222; | ||||
| } | ||||
| .ui-widget-header { | ||||
| 	border: 1px solid #4297d7; | ||||
| 	background: #5c9ccc url(images/ui-bg_gloss-wave_55_5c9ccc_500x100.png) 50% 50% repeat-x; | ||||
| 	color: #ffffff; | ||||
| 	font-weight: bold; | ||||
| } | ||||
| .ui-widget-header a { | ||||
| 	color: #ffffff; | ||||
| } | ||||
|  | ||||
| /* Interaction states | ||||
| ----------------------------------*/ | ||||
| .ui-state-default, | ||||
| .ui-widget-content .ui-state-default, | ||||
| .ui-widget-header .ui-state-default { | ||||
| 	border: 1px solid #c5dbec; | ||||
| 	background: #dfeffc url(images/ui-bg_glass_85_dfeffc_1x400.png) 50% 50% repeat-x; | ||||
| 	font-weight: bold; | ||||
| 	color: #2e6e9e; | ||||
| } | ||||
| .ui-state-default a, | ||||
| .ui-state-default a:link, | ||||
| .ui-state-default a:visited { | ||||
| 	color: #2e6e9e; | ||||
| 	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 #79b7e7; | ||||
| 	background: #d0e5f5 url(images/ui-bg_glass_75_d0e5f5_1x400.png) 50% 50% repeat-x; | ||||
| 	font-weight: bold; | ||||
| 	color: #1d5987; | ||||
| } | ||||
| .ui-state-hover a, | ||||
| .ui-state-hover a:hover, | ||||
| .ui-state-hover a:link, | ||||
| .ui-state-hover a:visited { | ||||
| 	color: #1d5987; | ||||
| 	text-decoration: none; | ||||
| } | ||||
| .ui-state-active, | ||||
| .ui-widget-content .ui-state-active, | ||||
| .ui-widget-header .ui-state-active { | ||||
| 	border: 1px solid #79b7e7; | ||||
| 	background: #f5f8f9 url(images/ui-bg_inset-hard_100_f5f8f9_1x100.png) 50% 50% repeat-x; | ||||
| 	font-weight: bold; | ||||
| 	color: #e17009; | ||||
| } | ||||
| .ui-state-active a, | ||||
| .ui-state-active a:link, | ||||
| .ui-state-active a:visited { | ||||
| 	color: #e17009; | ||||
| 	text-decoration: none; | ||||
| } | ||||
|  | ||||
| /* Interaction Cues | ||||
| ----------------------------------*/ | ||||
| .ui-state-highlight, | ||||
| .ui-widget-content .ui-state-highlight, | ||||
| .ui-widget-header .ui-state-highlight { | ||||
| 	border: 1px solid #fad42e; | ||||
| 	background: #fbec88 url(images/ui-bg_flat_55_fbec88_40x100.png) 50% 50% repeat-x; | ||||
| 	color: #363636; | ||||
| } | ||||
| .ui-state-highlight a, | ||||
| .ui-widget-content .ui-state-highlight a, | ||||
| .ui-widget-header .ui-state-highlight a { | ||||
| 	color: #363636; | ||||
| } | ||||
| .ui-state-error, | ||||
| .ui-widget-content .ui-state-error, | ||||
| .ui-widget-header .ui-state-error { | ||||
| 	border: 1px solid #cd0a0a; | ||||
| 	background: #fef1ec url(images/ui-bg_glass_95_fef1ec_1x400.png) 50% 50% repeat-x; | ||||
| 	color: #cd0a0a; | ||||
| } | ||||
| .ui-state-error a, | ||||
| .ui-widget-content .ui-state-error a, | ||||
| .ui-widget-header .ui-state-error a { | ||||
| 	color: #cd0a0a; | ||||
| } | ||||
| .ui-state-error-text, | ||||
| .ui-widget-content .ui-state-error-text, | ||||
| .ui-widget-header .ui-state-error-text { | ||||
| 	color: #cd0a0a; | ||||
| } | ||||
| .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); /* For IE8 - See #6059 */ | ||||
| } | ||||
|  | ||||
| /* Icons | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* states and images */ | ||||
| .ui-icon { | ||||
| 	width: 16px; | ||||
| 	height: 16px; | ||||
| } | ||||
| .ui-icon, | ||||
| .ui-widget-content .ui-icon { | ||||
| 	background-image: url(images/ui-icons_469bdd_256x240.png); | ||||
| } | ||||
| .ui-widget-header .ui-icon { | ||||
| 	background-image: url(images/ui-icons_d8e7f3_256x240.png); | ||||
| } | ||||
| .ui-state-default .ui-icon { | ||||
| 	background-image: url(images/ui-icons_6da8d5_256x240.png); | ||||
| } | ||||
| .ui-state-hover .ui-icon, | ||||
| .ui-state-focus .ui-icon { | ||||
| 	background-image: url(images/ui-icons_217bc0_256x240.png); | ||||
| } | ||||
| .ui-state-active .ui-icon { | ||||
| 	background-image: url(images/ui-icons_f9bd01_256x240.png); | ||||
| } | ||||
| .ui-state-highlight .ui-icon { | ||||
| 	background-image: url(images/ui-icons_2e83ff_256x240.png); | ||||
| } | ||||
| .ui-state-error .ui-icon, | ||||
| .ui-state-error-text .ui-icon { | ||||
| 	background-image: url(images/ui-icons_cd0a0a_256x240.png); | ||||
| } | ||||
|  | ||||
| /* positioning */ | ||||
| .ui-icon-blank { background-position: 16px 16px; } | ||||
| .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 is deprecated, use ui-icon-seek-start instead */ | ||||
| .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; } | ||||
|  | ||||
|  | ||||
| /* Misc visuals | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* Corner radius */ | ||||
| .ui-corner-all, | ||||
| .ui-corner-top, | ||||
| .ui-corner-left, | ||||
| .ui-corner-tl { | ||||
| 	border-top-left-radius: 5px; | ||||
| } | ||||
| .ui-corner-all, | ||||
| .ui-corner-top, | ||||
| .ui-corner-right, | ||||
| .ui-corner-tr { | ||||
| 	border-top-right-radius: 5px; | ||||
| } | ||||
| .ui-corner-all, | ||||
| .ui-corner-bottom, | ||||
| .ui-corner-left, | ||||
| .ui-corner-bl { | ||||
| 	border-bottom-left-radius: 5px; | ||||
| } | ||||
| .ui-corner-all, | ||||
| .ui-corner-bottom, | ||||
| .ui-corner-right, | ||||
| .ui-corner-br { | ||||
| 	border-bottom-right-radius: 5px; | ||||
| } | ||||
|  | ||||
| /* Overlays */ | ||||
| .ui-widget-overlay { | ||||
| 	background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; | ||||
| 	opacity: .3; | ||||
| 	filter: Alpha(Opacity=30); | ||||
| } | ||||
| .ui-widget-shadow { | ||||
| 	margin: -8px 0 0 -8px; | ||||
| 	padding: 8px; | ||||
| 	background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; | ||||
| 	opacity: .3; | ||||
| 	filter: Alpha(Opacity=30); | ||||
| 	border-radius: 8px; | ||||
| } | ||||
							
								
								
									
										1526
									
								
								dist/jquery-editable/js/jquery-editable-poshytip.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
							
								
								
									
										1473
									
								
								dist/jqueryui-editable/js/jqueryui-editable.js
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,180 +0,0 @@ | ||||
| /** | ||||
| * Editable Popover  | ||||
| * --------------------- | ||||
| * requires bootstrap-popover.js | ||||
| */ | ||||
| (function ($) { | ||||
|     "use strict"; | ||||
|  | ||||
|     //extend methods | ||||
|     $.extend($.fn.editableContainer.Popup.prototype, { | ||||
|         containerName: 'popover', | ||||
|         //for compatibility with bootstrap <= 2.2.1 (content inserted into <p> instead of directly .popover-content)  | ||||
|         innerCss: $.fn.popover && $($.fn.popover.defaults.template).find('p').length ? '.popover-content p' : '.popover-content', | ||||
|         defaults: $.fn.popover.defaults, | ||||
|          | ||||
|         initContainer: function(){ | ||||
|             $.extend(this.containerOptions, { | ||||
|                 trigger: 'manual', | ||||
|                 selector: false, | ||||
|                 content: ' ', | ||||
|                 template: this.defaults.template | ||||
|             }); | ||||
|              | ||||
|             //as template property is used in inputs, hide it from popover | ||||
|             var t; | ||||
|             if(this.$element.data('template')) { | ||||
|                t = this.$element.data('template'); | ||||
|                this.$element.removeData('template');   | ||||
|             }  | ||||
|              | ||||
|             this.call(this.containerOptions); | ||||
|              | ||||
|             if(t) { | ||||
|                //restore data('template') | ||||
|                this.$element.data('template', t);  | ||||
|             } | ||||
|         },  | ||||
|          | ||||
|         /* show */ | ||||
|         innerShow: function () { | ||||
|             this.call('show');                 | ||||
|         },   | ||||
|          | ||||
|         /* hide */ | ||||
|         innerHide: function () { | ||||
|             this.call('hide');        | ||||
|         },  | ||||
|          | ||||
|         /* destroy */ | ||||
|         innerDestroy: function() { | ||||
|             this.call('destroy'); | ||||
|         },                                | ||||
|          | ||||
|         setContainerOption: function(key, value) { | ||||
|             this.container().options[key] = value;  | ||||
|         },                | ||||
|  | ||||
|         /** | ||||
|         * move popover to new position. This function mainly copied from bootstrap-popover. | ||||
|         */ | ||||
|         /*jshint laxcomma: true*/ | ||||
|         setPosition: function () {  | ||||
|  | ||||
|             (function() {     | ||||
|                 var $tip = this.tip() | ||||
|                 , inside | ||||
|                 , pos | ||||
|                 , actualWidth | ||||
|                 , actualHeight | ||||
|                 , placement | ||||
|                 , tp | ||||
|                 , tpt | ||||
|                 , tpb | ||||
|                 , tpl | ||||
|                 , tpr; | ||||
|  | ||||
|                 placement = typeof this.options.placement === 'function' ? | ||||
|                 this.options.placement.call(this, $tip[0], this.$element[0]) : | ||||
|                 this.options.placement; | ||||
|  | ||||
|                 inside = /in/.test(placement); | ||||
|                 | ||||
|                 $tip | ||||
|               //  .detach() | ||||
|               //vitalets: remove any placement class because otherwise they dont influence on re-positioning of visible popover | ||||
|                 .removeClass('top right bottom left') | ||||
|                 .css({ top: 0, left: 0, display: 'block' }); | ||||
|               //  .insertAfter(this.$element); | ||||
|                 | ||||
|                 pos = this.getPosition(inside); | ||||
|  | ||||
|                 actualWidth = $tip[0].offsetWidth; | ||||
|                 actualHeight = $tip[0].offsetHeight; | ||||
|  | ||||
|                 placement = inside ? placement.split(' ')[1] : placement; | ||||
|  | ||||
|                 tpb = {top: pos.top + pos.height, left: pos.left + pos.width / 2 - actualWidth / 2}; | ||||
|                 tpt = {top: pos.top - actualHeight, left: pos.left + pos.width / 2 - actualWidth / 2}; | ||||
|                 tpl = {top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left - actualWidth}; | ||||
|                 tpr = {top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left + pos.width}; | ||||
|  | ||||
|                 switch (placement) { | ||||
|                     case 'bottom': | ||||
|                         if ((tpb.top + actualHeight) > ($(window).scrollTop() + $(window).height())) { | ||||
|                             if (tpt.top > $(window).scrollTop()) { | ||||
|                                 placement = 'top'; | ||||
|                             } else if ((tpr.left + actualWidth) < ($(window).scrollLeft() + $(window).width())) { | ||||
|                                 placement = 'right'; | ||||
|                             } else if (tpl.left > $(window).scrollLeft()) { | ||||
|                                 placement = 'left'; | ||||
|                             } else { | ||||
|                                 placement = 'right'; | ||||
|                             } | ||||
|                         } | ||||
|                         break; | ||||
|                     case 'top': | ||||
|                         if (tpt.top < $(window).scrollTop()) { | ||||
|                             if ((tpb.top + actualHeight) < ($(window).scrollTop() + $(window).height())) { | ||||
|                                 placement = 'bottom'; | ||||
|                             } else if ((tpr.left + actualWidth) < ($(window).scrollLeft() + $(window).width())) { | ||||
|                                 placement = 'right'; | ||||
|                             } else if (tpl.left > $(window).scrollLeft()) { | ||||
|                                 placement = 'left'; | ||||
|                             } else { | ||||
|                                 placement = 'right'; | ||||
|                             } | ||||
|                         } | ||||
|                         break; | ||||
|                     case 'left': | ||||
|                         if (tpl.left < $(window).scrollLeft()) { | ||||
|                             if ((tpr.left + actualWidth) < ($(window).scrollLeft() + $(window).width())) { | ||||
|                                 placement = 'right'; | ||||
|                             } else if (tpt.top > $(window).scrollTop()) { | ||||
|                                 placement = 'top'; | ||||
|                             } else if (tpt.top > $(window).scrollTop()) { | ||||
|                                 placement = 'bottom'; | ||||
|                             } else { | ||||
|                                 placement = 'right'; | ||||
|                             } | ||||
|                         } | ||||
|                         break; | ||||
|                     case 'right': | ||||
|                         if ((tpr.left + actualWidth) > ($(window).scrollLeft() + $(window).width())) { | ||||
|                             if (tpl.left > $(window).scrollLeft()) { | ||||
|                                 placement = 'left'; | ||||
|                             } else if (tpt.top > $(window).scrollTop()) { | ||||
|                                 placement = 'top'; | ||||
|                             } else if (tpt.top > $(window).scrollTop()) { | ||||
|                                 placement = 'bottom'; | ||||
|                             } | ||||
|                         } | ||||
|                         break; | ||||
|                 } | ||||
|  | ||||
|                 switch (placement) { | ||||
|                     case 'bottom': | ||||
|                         tp = tpb; | ||||
|                         break; | ||||
|                     case 'top': | ||||
|                         tp = tpt; | ||||
|                         break; | ||||
|                     case 'left': | ||||
|                         tp = tpl; | ||||
|                         break; | ||||
|                     case 'right': | ||||
|                         tp = tpr; | ||||
|                         break; | ||||
|                 } | ||||
|  | ||||
|                 $tip | ||||
|                 .offset(tp) | ||||
|                 .addClass(placement) | ||||
|                 .addClass('in'); | ||||
|                  | ||||
|             }).call(this.container()); | ||||
|           /*jshint laxcomma: false*/   | ||||
|         }             | ||||
|     }); | ||||
|  | ||||
| }(window.jQuery)); | ||||
| @@ -1,207 +0,0 @@ | ||||
| /** | ||||
| * Editable Poshytip  | ||||
| * --------------------- | ||||
| * requires jquery.poshytip.js | ||||
| */ | ||||
| (function ($) { | ||||
|     "use strict"; | ||||
|      | ||||
|     //extend methods | ||||
|     $.extend($.fn.editableContainer.Popup.prototype, { | ||||
|         containerName: 'poshytip', | ||||
|         innerCss: 'div.tip-inner', | ||||
|         defaults: $.fn.poshytip.defaults, | ||||
|          | ||||
|         initContainer: function(){ | ||||
|             this.handlePlacement(); | ||||
|              | ||||
|             $.extend(this.containerOptions, { | ||||
|                 showOn: 'none', | ||||
|                 content: '', | ||||
|                 alignTo: 'target' | ||||
|             });             | ||||
|              | ||||
|             this.call(this.containerOptions); | ||||
|         },         | ||||
|          | ||||
|         /* | ||||
|         Overwrite totally show() method as poshytip requires content is set before show  | ||||
|         */ | ||||
|         show: function (closeAll) { | ||||
|             this.$element.addClass('editable-open'); | ||||
|             if(closeAll !== false) { | ||||
|                 //close all open containers (except this) | ||||
|                 this.closeOthers(this.$element[0]);   | ||||
|             }             | ||||
|              | ||||
|             //render form | ||||
|             this.$form = $('<div>'); | ||||
|             this.renderForm();              | ||||
|            | ||||
|             var $label = $('<label>').text(this.options.title || this.$element.data( "title") || this.$element.data( "originalTitle")), | ||||
|                 $content = $('<div>').append($label).append(this.$form);            | ||||
|            | ||||
|             this.call('update', $content); | ||||
|             this.call('show'); | ||||
|              | ||||
|             this.tip().addClass(this.containerClass); | ||||
|             this.$form.data('editableform').input.activate(); | ||||
|         },      | ||||
|          | ||||
|         /* hide */ | ||||
|         innerHide: function () { | ||||
|             this.call('hide');        | ||||
|         }, | ||||
|          | ||||
|         /* destroy */ | ||||
|         innerDestroy: function() { | ||||
|             this.call('destroy'); | ||||
|         },              | ||||
|           | ||||
|         setPosition: function() { | ||||
|             this.container().refresh(false); | ||||
|         }, | ||||
|          | ||||
|         handlePlacement: function() { | ||||
|            var x, y, ox = 0, oy = 0;  | ||||
|            switch(this.options.placement) { | ||||
|                case 'top': | ||||
|                       x = 'center'; | ||||
|                       y = 'top'; | ||||
|                       oy = 5; | ||||
|                break; | ||||
|                case 'right': | ||||
|                       x = 'right'; | ||||
|                       y = 'center'; | ||||
|                       ox = 10; | ||||
|                break; | ||||
|                case 'bottom': | ||||
|                       x = 'center'; | ||||
|                       y = 'bottom'; | ||||
|                       oy = 5; | ||||
|                break; | ||||
|                case 'left': | ||||
|                       x = 'left'; | ||||
|                       y = 'center'; | ||||
|                       ox = 10; | ||||
|                break;                                              | ||||
|            } | ||||
|             | ||||
|            $.extend(this.containerOptions, { | ||||
|                alignX: x, | ||||
|                offsetX: ox, | ||||
|                alignY: y, | ||||
|                offsetY:oy | ||||
|            }); | ||||
|         } | ||||
|     }); | ||||
|      | ||||
|     //defaults | ||||
|     $.fn.editableContainer.defaults = $.extend({}, $.fn.editableContainer.defaults, { | ||||
|         className: 'tip-yellowsimple' | ||||
|     }); | ||||
|      | ||||
|      | ||||
|     /** | ||||
|     * Poshytip fix: disable incorrect table display | ||||
|     * see https://github.com/vadikom/poshytip/issues/7 | ||||
|     */  | ||||
|     /*jshint eqeqeq:false, curly: false*/ | ||||
|     if($.Poshytip) {  //need this check, because in inline mode poshytip may not be loaded! | ||||
|       var tips = [], | ||||
|       reBgImage = /^url\(["']?([^"'\)]*)["']?\);?$/i, | ||||
|       rePNG = /\.png$/i, | ||||
|       ie6 = !!window.createPopup && document.documentElement.currentStyle.minWidth == 'undefined'; | ||||
|        | ||||
|       $.Poshytip.prototype.refresh = function(async) { | ||||
|           if (this.disabled) | ||||
|               return; | ||||
|                | ||||
|           var currPos; | ||||
|           if (async) { | ||||
|               if (!this.$tip.data('active')) | ||||
|                   return; | ||||
|               // save current position as we will need to animate | ||||
|               currPos = {left: this.$tip.css('left'), top: this.$tip.css('top')}; | ||||
|           } | ||||
|  | ||||
|           // reset position to avoid text wrapping, etc. | ||||
|           this.$tip.css({left: 0, top: 0}).appendTo(document.body); | ||||
|  | ||||
|           // save default opacity | ||||
|           if (this.opacity === undefined) | ||||
|               this.opacity = this.$tip.css('opacity'); | ||||
|  | ||||
|           // check for images - this code is here (i.e. executed each time we show the tip and not on init) due to some browser inconsistencies | ||||
|           var bgImage = this.$tip.css('background-image').match(reBgImage), | ||||
|           arrow = this.$arrow.css('background-image').match(reBgImage); | ||||
|  | ||||
|           if (bgImage) { | ||||
|               var bgImagePNG = rePNG.test(bgImage[1]); | ||||
|               // fallback to background-color/padding/border in IE6 if a PNG is used | ||||
|               if (ie6 && bgImagePNG) { | ||||
|                   this.$tip.css('background-image', 'none'); | ||||
|                   this.$inner.css({margin: 0, border: 0, padding: 0}); | ||||
|                   bgImage = bgImagePNG = false; | ||||
|               } else { | ||||
|                   this.$tip.prepend('<table class="fallback" border="0" cellpadding="0" cellspacing="0"><tr><td class="tip-top tip-bg-image" colspan="2"><span></span></td><td class="tip-right tip-bg-image" rowspan="2"><span></span></td></tr><tr><td class="tip-left tip-bg-image" rowspan="2"><span></span></td><td></td></tr><tr><td class="tip-bottom tip-bg-image" colspan="2"><span></span></td></tr></table>') | ||||
|                   .css({border: 0, padding: 0, 'background-image': 'none', 'background-color': 'transparent'}) | ||||
|                   .find('.tip-bg-image').css('background-image', 'url("' + bgImage[1] +'")').end() | ||||
|                   .find('td').eq(3).append(this.$inner); | ||||
|               } | ||||
|               // disable fade effect in IE due to Alpha filter + translucent PNG issue | ||||
|               if (bgImagePNG && !$.support.opacity) | ||||
|                   this.opts.fade = false; | ||||
|           } | ||||
|           // IE arrow fixes | ||||
|           if (arrow && !$.support.opacity) { | ||||
|               // disable arrow in IE6 if using a PNG | ||||
|               if (ie6 && rePNG.test(arrow[1])) { | ||||
|                   arrow = false; | ||||
|                   this.$arrow.css('background-image', 'none'); | ||||
|               } | ||||
|               // disable fade effect in IE due to Alpha filter + translucent PNG issue | ||||
|               this.opts.fade = false; | ||||
|           } | ||||
|  | ||||
|           var $table = this.$tip.find('table.fallback'); | ||||
|           if (ie6) { | ||||
|               // fix min/max-width in IE6 | ||||
|               this.$tip[0].style.width = ''; | ||||
|               $table.width('auto').find('td').eq(3).width('auto'); | ||||
|               var tipW = this.$tip.width(), | ||||
|               minW = parseInt(this.$tip.css('min-width'), 10), | ||||
|               maxW = parseInt(this.$tip.css('max-width'), 10); | ||||
|               if (!isNaN(minW) && tipW < minW) | ||||
|                   tipW = minW; | ||||
|               else if (!isNaN(maxW) && tipW > maxW) | ||||
|                   tipW = maxW; | ||||
|               this.$tip.add($table).width(tipW).eq(0).find('td').eq(3).width('100%'); | ||||
|           } else if ($table[0]) { | ||||
|               // fix the table width if we are using a background image | ||||
|               // IE9, FF4 use float numbers for width/height so use getComputedStyle for them to avoid text wrapping | ||||
|               // for details look at: http://vadikom.com/dailies/offsetwidth-offsetheight-useless-in-ie9-firefox4/ | ||||
|               $table.width('auto').find('td').eq(3).width('auto').end().end().width(document.defaultView && document.defaultView.getComputedStyle && parseFloat(document.defaultView.getComputedStyle(this.$tip[0], null).width) || this.$tip.width()).find('td').eq(3).width('100%'); | ||||
|           } | ||||
|           this.tipOuterW = this.$tip.outerWidth(); | ||||
|           this.tipOuterH = this.$tip.outerHeight(); | ||||
|  | ||||
|           this.calcPos(); | ||||
|  | ||||
|           // position and show the arrow image | ||||
|           if (arrow && this.pos.arrow) { | ||||
|               this.$arrow[0].className = 'tip-arrow tip-arrow-' + this.pos.arrow; | ||||
|               this.$arrow.css('visibility', 'inherit'); | ||||
|           } | ||||
|  | ||||
|           if (async) { | ||||
|               this.asyncAnimating = true; | ||||
|               var self = this; | ||||
|               this.$tip.css(currPos).animate({left: this.pos.l, top: this.pos.t}, 200, function() { self.asyncAnimating = false; }); | ||||
|           } else { | ||||
|               this.$tip.css({left: this.pos.l, top: this.pos.t}); | ||||
|           } | ||||
|       }; | ||||
|     } | ||||
|     /*jshinteqeqeq: true, curly: true*/ | ||||
| }(window.jQuery)); | ||||
| @@ -1,121 +0,0 @@ | ||||
| /** | ||||
| * Editable jQuery UI Tooltip  | ||||
| * --------------------- | ||||
| * requires jquery ui 1.9.x  | ||||
| */ | ||||
| (function ($) { | ||||
|     "use strict"; | ||||
|  | ||||
|     //extend methods | ||||
|     $.extend($.fn.editableContainer.Popup.prototype, { | ||||
|         containerName: 'tooltip',  //jQuery method, aplying the widget | ||||
|         //object name in element's .data()  | ||||
|         containerDataName: 'ui-tooltip',  | ||||
|         innerCss: '.ui-tooltip-content',  | ||||
|         defaults: $.ui.tooltip.prototype.options, | ||||
|          | ||||
|         //split options on containerOptions and formOptions | ||||
|         splitOptions: function() { | ||||
|             this.containerOptions = {}; | ||||
|             this.formOptions = {}; | ||||
|              | ||||
|             //check that jQueryUI build contains tooltip widget | ||||
|             if(!$.ui[this.containerName]) { | ||||
|                 $.error('Please use jQueryUI with "tooltip" widget! http://jqueryui.com/download'); | ||||
|                 return; | ||||
|             } | ||||
|              | ||||
|             //defaults for tooltip | ||||
|             for(var k in this.options) { | ||||
|               if(k in this.defaults) { | ||||
|                  this.containerOptions[k] = this.options[k]; | ||||
|               } else { | ||||
|                  this.formOptions[k] = this.options[k]; | ||||
|               }  | ||||
|             } | ||||
|         },         | ||||
|          | ||||
|         initContainer: function(){ | ||||
|             this.handlePlacement(); | ||||
|             $.extend(this.containerOptions, { | ||||
|                 items: '*', | ||||
|                 content: ' ', | ||||
|                 track:  false, | ||||
|                 open: $.proxy(function() { | ||||
|                         //disable events hiding tooltip by default | ||||
|                         this.container()._on(this.container().element, { | ||||
|                             mouseleave: function(e){ e.stopImmediatePropagation(); }, | ||||
|                             focusout: function(e){ e.stopImmediatePropagation(); } | ||||
|                         });   | ||||
|                     }, this) | ||||
|             }); | ||||
|              | ||||
|             this.call(this.containerOptions); | ||||
|              | ||||
|             //disable standart triggering tooltip events | ||||
|             this.container()._off(this.container().element, 'mouseover focusin'); | ||||
|         },          | ||||
|          | ||||
|         tip: function() { | ||||
|             return this.container() ? this.container()._find(this.container().element) : null; | ||||
|         }, | ||||
|          | ||||
|         innerShow: function() { | ||||
|             this.call('open'); | ||||
|             var label = this.options.title || this.$element.data( "ui-tooltip-title") || this.$element.data( "originalTitle");  | ||||
|             this.tip().find(this.innerCss).empty().append($('<label>').text(label)); | ||||
|         },   | ||||
|          | ||||
|         innerHide: function() { | ||||
|             this.call('close');  | ||||
|         }, | ||||
|          | ||||
|         innerDestroy: function() { | ||||
|             /* tooltip destroys itself on hide */ | ||||
|         },          | ||||
|          | ||||
|         setPosition: function() { | ||||
|             this.tip().position( $.extend({ | ||||
|                 of: this.$element | ||||
|             }, this.containerOptions.position ) );      | ||||
|         }, | ||||
|          | ||||
|         handlePlacement: function() { | ||||
|            var pos;  | ||||
|            switch(this.options.placement) { | ||||
|                case 'top': | ||||
|                       pos = { | ||||
|                           my: "center bottom-5",  | ||||
|                           at: "center top",  | ||||
|                           collision: 'flipfit' | ||||
|                       }; | ||||
|                break; | ||||
|                case 'right': | ||||
|                       pos = { | ||||
|                           my: "left+5 center",  | ||||
|                           at: "right center",  | ||||
|                           collision: 'flipfit' | ||||
|                       }; | ||||
|                break; | ||||
|                case 'bottom': | ||||
|                       pos = { | ||||
|                           my: "center top+5",  | ||||
|                           at: "center bottom",  | ||||
|                           collision: 'flipfit' | ||||
|                       }; | ||||
|                break; | ||||
|                case 'left': | ||||
|                       pos = { | ||||
|                           my: "right-5 center",  | ||||
|                           at: "left center",  | ||||
|                           collision: 'flipfit' | ||||
|                       }; | ||||
|                break;                                              | ||||
|            } | ||||
|             | ||||
|            this.containerOptions.position = pos; | ||||
|         } | ||||
|                  | ||||
|     }); | ||||
|      | ||||
| }(window.jQuery)); | ||||
| @@ -1,42 +0,0 @@ | ||||
| /* | ||||
| Editableform based on Twitter Bootstrap 2 | ||||
| */ | ||||
| (function ($) { | ||||
|     "use strict"; | ||||
|      | ||||
|     //store parent methods | ||||
|     var pInitInput = $.fn.editableform.Constructor.prototype.initInput;     | ||||
|      | ||||
|     $.extend($.fn.editableform.Constructor.prototype, { | ||||
|          initTemplate: function() { | ||||
|             this.$form = $($.fn.editableform.template);  | ||||
|             this.$form.find('.editable-error-block').addClass('help-block'); | ||||
|          }, | ||||
|          initInput: function() {   | ||||
|             pInitInput.apply(this); | ||||
|  | ||||
|             //for bs2 set default class `input-medium` to standard inputs | ||||
|             var emptyInputClass = this.input.options.inputclass === null || this.input.options.inputclass === false; | ||||
|             var defaultClass = 'input-medium'; | ||||
|              | ||||
|             //add bs2 default class to standard inputs | ||||
|             //if(this.input.$input.is('input,select,textarea')) { | ||||
|             var stdtypes = 'text,select,textarea,password,email,url,tel,number,range,time'.split(',');  | ||||
|             if(~$.inArray(this.input.type, stdtypes) && emptyInputClass) { | ||||
|                 this.input.options.inputclass = defaultClass; | ||||
|                 this.input.$input.addClass(defaultClass); | ||||
|             }          | ||||
|          } | ||||
|     });     | ||||
|      | ||||
|     //buttons | ||||
|     $.fn.editableform.buttons = '<button type="submit" class="btn btn-primary editable-submit"><i class="icon-ok icon-white"></i></button>'+ | ||||
|                                 '<button type="button" class="btn editable-cancel"><i class="icon-remove"></i></button>';          | ||||
|      | ||||
|     //error classes | ||||
|     $.fn.editableform.errorGroupClass = 'error'; | ||||
|     $.fn.editableform.errorBlockClass = null; | ||||
|     //engine  | ||||
|     $.fn.editableform.engine = 'bs2';    | ||||
|      | ||||
| }(window.jQuery)); | ||||
| @@ -1,64 +0,0 @@ | ||||
| /* | ||||
| Editableform based on Twitter Bootstrap 3 | ||||
| */ | ||||
| (function ($) { | ||||
|     "use strict"; | ||||
|      | ||||
|     //store parent methods | ||||
|     var pInitInput = $.fn.editableform.Constructor.prototype.initInput; | ||||
|      | ||||
|     $.extend($.fn.editableform.Constructor.prototype, { | ||||
|         initTemplate: function() { | ||||
|             this.$form = $($.fn.editableform.template);  | ||||
|             this.$form.find('.control-group').addClass('form-group'); | ||||
|             this.$form.find('.editable-error-block').addClass('help-block'); | ||||
|         }, | ||||
|         initInput: function() {   | ||||
|             pInitInput.apply(this); | ||||
|  | ||||
|             //for bs3 set default class `input-sm` to standard inputs | ||||
|             var emptyInputClass = this.input.options.inputclass === null || this.input.options.inputclass === false; | ||||
|             var defaultClass = 'input-sm'; | ||||
|              | ||||
|             //bs3 add `form-control` class to standard inputs | ||||
|             var stdtypes = 'text,select,textarea,password,email,url,tel,number,range,time,typeaheadjs'.split(',');  | ||||
|             if(~$.inArray(this.input.type, stdtypes)) { | ||||
|                 this.input.$input.addClass('form-control'); | ||||
|                 if(emptyInputClass) { | ||||
|                     this.input.options.inputclass = defaultClass; | ||||
|                     this.input.$input.addClass(defaultClass); | ||||
|                 } | ||||
|             }              | ||||
|          | ||||
|             //apply bs3 size class also to buttons (to fit size of control) | ||||
|             var $btn = this.$form.find('.editable-buttons'); | ||||
|             var classes = emptyInputClass ? [defaultClass] : this.input.options.inputclass.split(' '); | ||||
|             for(var i=0; i<classes.length; i++) { | ||||
|                 // `btn-sm` is default now | ||||
|                 /* | ||||
|                 if(classes[i].toLowerCase() === 'input-sm') {  | ||||
|                     $btn.find('button').addClass('btn-sm');   | ||||
|                 } | ||||
|                 */ | ||||
|                 if(classes[i].toLowerCase() === 'input-lg') { | ||||
|                     $btn.find('button').removeClass('btn-sm').addClass('btn-lg');  | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     });     | ||||
|      | ||||
|     //buttons | ||||
|     $.fn.editableform.buttons =  | ||||
|       '<button type="submit" class="btn btn-primary btn-sm editable-submit">'+ | ||||
|         '<i class="glyphicon glyphicon-ok"></i>'+ | ||||
|       '</button>'+ | ||||
|       '<button type="button" class="btn btn-default btn-sm editable-cancel">'+ | ||||
|         '<i class="glyphicon glyphicon-remove"></i>'+ | ||||
|       '</button>';          | ||||
|      | ||||
|     //error classes | ||||
|     $.fn.editableform.errorGroupClass = 'has-error'; | ||||
|     $.fn.editableform.errorBlockClass = null;   | ||||
|     //engine | ||||
|     $.fn.editableform.engine = 'bs3';   | ||||
| }(window.jQuery)); | ||||
| @@ -1,32 +0,0 @@ | ||||
| /* | ||||
| Editableform based on jQuery UI | ||||
| */ | ||||
| (function ($) { | ||||
|     "use strict"; | ||||
|      | ||||
|     $.extend($.fn.editableform.Constructor.prototype, { | ||||
|         initButtons: function() { | ||||
|             var $btn = this.$form.find('.editable-buttons'); | ||||
|             $btn.append($.fn.editableform.buttons); | ||||
|             if(this.options.showbuttons === 'bottom') { | ||||
|                 $btn.addClass('editable-buttons-bottom'); | ||||
|             } | ||||
|                            | ||||
|             this.$form.find('.editable-submit').button({ | ||||
|                 icons: { primary: "ui-icon-check" }, | ||||
|                 text: false | ||||
|             }).removeAttr('title'); | ||||
|             this.$form.find('.editable-cancel').button({ | ||||
|                 icons: { primary: "ui-icon-closethick" }, | ||||
|                 text: false | ||||
|             }).removeAttr('title'); | ||||
|         } | ||||
|     }); | ||||
|      | ||||
|     //error classes | ||||
|     $.fn.editableform.errorGroupClass = null; | ||||
|     $.fn.editableform.errorBlockClass = 'ui-state-error'; | ||||
|     //engine | ||||
|     $.fn.editableform.engine = 'jquery-ui'; | ||||
|      | ||||
| }(window.jQuery)); | ||||
| @@ -1,9 +0,0 @@ | ||||
| .editable-address { | ||||
|     display: block; | ||||
|     margin-bottom: 5px;   | ||||
| } | ||||
|  | ||||
| .editable-address span { | ||||
|     width: 70px;   | ||||
|     display: inline-block; | ||||
| } | ||||
| @@ -1,170 +0,0 @@ | ||||
| /** | ||||
| Address editable input. | ||||
| Internally value stored as {city: "Moscow", street: "Lenina", building: "15"} | ||||
|  | ||||
| @class address | ||||
| @extends abstractinput | ||||
| @final | ||||
| @example | ||||
| <a href="#" id="address" data-type="address" data-pk="1">awesome</a> | ||||
| <script> | ||||
| $(function(){ | ||||
|     $('#address').editable({ | ||||
|         url: '/post', | ||||
|         title: 'Enter city, street and building #', | ||||
|         value: { | ||||
|             city: "Moscow",  | ||||
|             street: "Lenina",  | ||||
|             building: "15" | ||||
|         } | ||||
|     }); | ||||
| }); | ||||
| </script> | ||||
| **/ | ||||
| (function ($) { | ||||
|     "use strict"; | ||||
|      | ||||
|     var Address = function (options) { | ||||
|         this.init('address', options, Address.defaults); | ||||
|     }; | ||||
|  | ||||
|     //inherit from Abstract input | ||||
|     $.fn.editableutils.inherit(Address, $.fn.editabletypes.abstractinput); | ||||
|  | ||||
|     $.extend(Address.prototype, { | ||||
|         /** | ||||
|         Renders input from tpl | ||||
|  | ||||
|         @method render()  | ||||
|         **/         | ||||
|         render: function() { | ||||
|            this.$input = this.$tpl.find('input'); | ||||
|         }, | ||||
|          | ||||
|         /** | ||||
|         Default method to show value in element. Can be overwritten by display option. | ||||
|          | ||||
|         @method value2html(value, element)  | ||||
|         **/ | ||||
|         value2html: function(value, element) { | ||||
|             if(!value) { | ||||
|                 $(element).empty(); | ||||
|                 return;  | ||||
|             } | ||||
|             var html = $('<div>').text(value.city).html() + ', ' + $('<div>').text(value.street).html() + ' st., bld. ' + $('<div>').text(value.building).html(); | ||||
|             $(element).html(html);  | ||||
|         }, | ||||
|          | ||||
|         /** | ||||
|         Gets value from element's html | ||||
|          | ||||
|         @method html2value(html)  | ||||
|         **/         | ||||
|         html2value: function(html) {         | ||||
|           /* | ||||
|             you may write parsing method to get value by element's html | ||||
|             e.g. "Moscow, st. Lenina, bld. 15" => {city: "Moscow", street: "Lenina", building: "15"} | ||||
|             but for complex structures it's not recommended. | ||||
|             Better set value directly via javascript, e.g.  | ||||
|             editable({ | ||||
|                 value: { | ||||
|                     city: "Moscow",  | ||||
|                     street: "Lenina",  | ||||
|                     building: "15" | ||||
|                 } | ||||
|             }); | ||||
|           */  | ||||
|           return null;   | ||||
|         }, | ||||
|        | ||||
|        /** | ||||
|         Converts value to string.  | ||||
|         It is used in internal comparing (not for sending to server). | ||||
|          | ||||
|         @method value2str(value)   | ||||
|        **/ | ||||
|        value2str: function(value) { | ||||
|            var str = ''; | ||||
|            if(value) { | ||||
|                for(var k in value) { | ||||
|                    str = str + k + ':' + value[k] + ';';   | ||||
|                } | ||||
|            } | ||||
|            return str; | ||||
|        },  | ||||
|         | ||||
|        /* | ||||
|         Converts string to value. Used for reading value from 'data-value' attribute. | ||||
|          | ||||
|         @method str2value(str)   | ||||
|        */ | ||||
|        str2value: function(str) { | ||||
|            /* | ||||
|            this is mainly for parsing value defined in data-value attribute.  | ||||
|            If you will always set value by javascript, no need to overwrite it | ||||
|            */ | ||||
|            return str; | ||||
|        },                 | ||||
|         | ||||
|        /** | ||||
|         Sets value of input. | ||||
|          | ||||
|         @method value2input(value)  | ||||
|         @param {mixed} value | ||||
|        **/          | ||||
|        value2input: function(value) { | ||||
|            if(!value) { | ||||
|              return; | ||||
|            } | ||||
|            this.$input.filter('[name="city"]').val(value.city); | ||||
|            this.$input.filter('[name="street"]').val(value.street); | ||||
|            this.$input.filter('[name="building"]').val(value.building); | ||||
|        },        | ||||
|         | ||||
|        /** | ||||
|         Returns value of input. | ||||
|          | ||||
|         @method input2value()  | ||||
|        **/           | ||||
|        input2value: function() {  | ||||
|            return { | ||||
|               city: this.$input.filter('[name="city"]').val(),  | ||||
|               street: this.$input.filter('[name="street"]').val(),  | ||||
|               building: this.$input.filter('[name="building"]').val() | ||||
|            }; | ||||
|        },         | ||||
|         | ||||
|         /** | ||||
|         Activates input: sets focus on the first field. | ||||
|          | ||||
|         @method activate()  | ||||
|        **/         | ||||
|        activate: function() { | ||||
|             this.$input.filter('[name="city"]').focus(); | ||||
|        },   | ||||
|         | ||||
|        /** | ||||
|         Attaches handler to submit form in case of 'showbuttons=false' mode | ||||
|          | ||||
|         @method autosubmit()  | ||||
|        **/        | ||||
|        autosubmit: function() { | ||||
|            this.$input.keydown(function (e) { | ||||
|                 if (e.which === 13) { | ||||
|                     $(this).closest('form').submit(); | ||||
|                 } | ||||
|            }); | ||||
|        }        | ||||
|     }); | ||||
|  | ||||
|     Address.defaults = $.extend({}, $.fn.editabletypes.abstractinput.defaults, { | ||||
|         tpl: '<div class="editable-address"><label><span>City: </span><input type="text" name="city" class="input-small"></label></div>'+ | ||||
|              '<div class="editable-address"><label><span>Street: </span><input type="text" name="street" class="input-small"></label></div>'+ | ||||
|              '<div class="editable-address"><label><span>Building: </span><input type="text" name="building" class="input-mini"></label></div>', | ||||
|               | ||||
|         inputclass: '' | ||||
|     }); | ||||
|  | ||||
|     $.fn.editabletypes.address = Address; | ||||
|  | ||||
| }(window.jQuery)); | ||||
| @@ -1,68 +0,0 @@ | ||||
| /** | ||||
| Slider, based on the Slider plugin by Stefan Petre (http://www.eyecon.ro/bootstrap-slider). | ||||
|  | ||||
| Make sure to include the plugin's code before using this editor. | ||||
|  | ||||
| @class slider | ||||
| @extends text | ||||
| @since 1.5.0 | ||||
| @final | ||||
| **/ | ||||
| (function ($) { | ||||
|     "use strict"; | ||||
|      | ||||
|     var Constructor = function (options) { | ||||
|         this.init('slider', options, Constructor.defaults); | ||||
|     }; | ||||
|  | ||||
|     $.fn.editableutils.inherit(Constructor, $.fn.editabletypes.text); | ||||
|  | ||||
|     $.extend(Constructor.prototype, { | ||||
|         render: function() { | ||||
|             // need to set kewdown handler before apply slider | ||||
|             // for correct autosubmit | ||||
|             this.isAutosubmit = false; | ||||
|             var that = this;             | ||||
|             this.$input.on('keydown', function (e) { | ||||
|                 if (!that.isAutosubmit) { | ||||
|                     return; | ||||
|                 } | ||||
|                 if (e.which === 13) { | ||||
|                     that.$input.closest('form').submit(); | ||||
|                 } | ||||
|             });             | ||||
|              | ||||
|             // apply slider | ||||
|             this.$input.slider(this.options.slider); | ||||
|         }, | ||||
|          | ||||
|        value2input: function(value) { | ||||
|        		// make sure it's a number | ||||
|        		if(typeof value!='number') | ||||
|        			value=Number(value); | ||||
|        		if(isNaN(value)) | ||||
|        			value=0; | ||||
|        		 | ||||
|            this.$input.val(value); | ||||
|            this.$input.slider('setValue', value); | ||||
|        }, | ||||
|  | ||||
|         autosubmit: function() { | ||||
|             this.isAutosubmit = true; | ||||
|         }         | ||||
|     });       | ||||
|  | ||||
|     Constructor.defaults = $.extend({}, $.fn.editabletypes.list.defaults, { | ||||
|         /** | ||||
|         @property tpl  | ||||
|         @default <input type="text"> | ||||
|         **/          | ||||
|         tpl:'<input type="text">', | ||||
|         /** | ||||
|         **/ | ||||
|         slider: null, | ||||
|     }); | ||||
|  | ||||
|     $.fn.editabletypes.slider = Constructor;       | ||||
|      | ||||
| }(window.jQuery)); | ||||
| @@ -1,49 +0,0 @@ | ||||
| .twitter-typeahead .tt-query, | ||||
| .twitter-typeahead .tt-hint { | ||||
|   margin-bottom: 0; | ||||
| } | ||||
|  | ||||
| .tt-dropdown-menu { | ||||
|   min-width: 160px; | ||||
|   margin-top: 2px; | ||||
|   padding: 5px 0; | ||||
|   background-color: #fff; | ||||
|   border: 1px solid #ccc; | ||||
|   border: 1px solid rgba(0,0,0,.2); | ||||
|   *border-right-width: 2px; | ||||
|   *border-bottom-width: 2px; | ||||
|   -webkit-border-radius: 6px; | ||||
|      -moz-border-radius: 6px; | ||||
|           border-radius: 6px; | ||||
|   -webkit-box-shadow: 0 5px 10px rgba(0,0,0,.2); | ||||
|      -moz-box-shadow: 0 5px 10px rgba(0,0,0,.2); | ||||
|           box-shadow: 0 5px 10px rgba(0,0,0,.2); | ||||
|   -webkit-background-clip: padding-box; | ||||
|      -moz-background-clip: padding; | ||||
|           background-clip: padding-box; | ||||
| } | ||||
|  | ||||
| .tt-suggestion { | ||||
|   display: block; | ||||
|   padding: 3px 20px; | ||||
| } | ||||
|  | ||||
| .tt-suggestion.tt-is-under-cursor { | ||||
|   color: #fff; | ||||
|   background-color: #0081c2; | ||||
|   background-image: -moz-linear-gradient(top, #0088cc, #0077b3); | ||||
|   background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#0088cc), to(#0077b3)); | ||||
|   background-image: -webkit-linear-gradient(top, #0088cc, #0077b3); | ||||
|   background-image: -o-linear-gradient(top, #0088cc, #0077b3); | ||||
|   background-image: linear-gradient(to bottom, #0088cc, #0077b3); | ||||
|   background-repeat: repeat-x; | ||||
|   filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff0088cc', endColorstr='#ff0077b3', GradientType=0) | ||||
| } | ||||
|  | ||||
| .tt-suggestion.tt-is-under-cursor a { | ||||
|   color: #fff; | ||||
| } | ||||
|  | ||||
| .tt-suggestion p { | ||||
|   margin: 0; | ||||
| } | ||||
| @@ -1,86 +0,0 @@ | ||||
| /** | ||||
| Typeahead.js input, based on [Twitter Typeahead](http://twitter.github.io/typeahead.js).    | ||||
| It is mainly replacement of typeahead in Bootstrap 3. | ||||
|  | ||||
|  | ||||
| @class typeaheadjs | ||||
| @extends text | ||||
| @since 1.5.0 | ||||
| @final | ||||
| @example | ||||
| <a href="#" id="country" data-type="typeaheadjs" data-pk="1" data-url="/post" data-title="Input country"></a> | ||||
| <script> | ||||
| $(function(){ | ||||
|     $('#country').editable({ | ||||
|         value: 'ru', | ||||
|         typeahead: { | ||||
|             name: 'country', | ||||
|             local: [ | ||||
|                 {value: 'ru', tokens: ['Russia']},  | ||||
|                 {value: 'gb', tokens: ['Great Britain']},  | ||||
|                 {value: 'us', tokens: ['United States']} | ||||
|             ], | ||||
|             template: function(item) { | ||||
|                 return item.tokens[0] + ' (' + item.value + ')';  | ||||
|             }  | ||||
|         } | ||||
|     }); | ||||
| }); | ||||
| </script> | ||||
| **/ | ||||
| (function ($) { | ||||
|     "use strict"; | ||||
|      | ||||
|     var Constructor = function (options) { | ||||
|         this.init('typeaheadjs', options, Constructor.defaults); | ||||
|     }; | ||||
|  | ||||
|     $.fn.editableutils.inherit(Constructor, $.fn.editabletypes.text); | ||||
|  | ||||
|     $.extend(Constructor.prototype, { | ||||
|         render: function() { | ||||
|             this.renderClear(); | ||||
|             this.setClass(); | ||||
|             this.setAttr('placeholder'); | ||||
|             this.$input.typeahead(this.options.typeahead); | ||||
|              | ||||
|             // copy `input-sm | input-lg` classes to placeholder input | ||||
|             if($.fn.editableform.engine === 'bs3') { | ||||
|                 if(this.$input.hasClass('input-sm')) { | ||||
|                     this.$input.siblings('input.tt-hint').addClass('input-sm'); | ||||
|                 } | ||||
|                 if(this.$input.hasClass('input-lg')) { | ||||
|                     this.$input.siblings('input.tt-hint').addClass('input-lg'); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     });       | ||||
|  | ||||
|     Constructor.defaults = $.extend({}, $.fn.editabletypes.list.defaults, { | ||||
|         /** | ||||
|         @property tpl  | ||||
|         @default <input type="text"> | ||||
|         **/          | ||||
|         tpl:'<input type="text">', | ||||
|         /** | ||||
|         Configuration of typeahead itself.  | ||||
|         [Full list of options](https://github.com/twitter/typeahead.js#dataset). | ||||
|          | ||||
|         @property typeahead  | ||||
|         @type object | ||||
|         @default null | ||||
|         **/ | ||||
|         typeahead: null, | ||||
|         /** | ||||
|         Whether to show `clear` button  | ||||
|          | ||||
|         @property clear  | ||||
|         @type boolean | ||||
|         @default true         | ||||
|         **/ | ||||
|         clear: true | ||||
|     }); | ||||
|  | ||||
|     $.fn.editabletypes.typeaheadjs = Constructor;       | ||||
|      | ||||
| }(window.jQuery)); | ||||
| @@ -1,102 +0,0 @@ | ||||
| ul.wysihtml5-toolbar { | ||||
| 	margin: 0; | ||||
| 	padding: 0; | ||||
| 	display: block; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar::after { | ||||
| 	clear: both; | ||||
| 	display: table; | ||||
| 	content: ""; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar > li { | ||||
| 	float: left; | ||||
| 	display: list-item; | ||||
| 	list-style: none; | ||||
| 	margin: 0 5px 10px 0; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar a[data-wysihtml5-command=bold] { | ||||
| 	font-weight: bold; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar a[data-wysihtml5-command=italic] { | ||||
| 	font-style: italic; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar a[data-wysihtml5-command=underline] { | ||||
| 	text-decoration: underline; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar a.btn.wysihtml5-command-active { | ||||
| 	background-image: none; | ||||
| 	-webkit-box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.15),0 1px 2px rgba(0, 0, 0, 0.05); | ||||
| 	-moz-box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.15),0 1px 2px rgba(0, 0, 0, 0.05); | ||||
| 	box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.15),0 1px 2px rgba(0, 0, 0, 0.05); | ||||
| 	background-color: #E6E6E6; | ||||
| 	background-color: #D9D9D9; | ||||
| 	outline: 0; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-commands-disabled .dropdown-menu { | ||||
| 	display: none !important; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar div.wysihtml5-colors { | ||||
|   display:block; | ||||
|   width: 50px; | ||||
|   height: 20px; | ||||
|   margin-top: 2px; | ||||
|   margin-left: 5px; | ||||
|   position: absolute; | ||||
|   pointer-events: none; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar a.wysihtml5-colors-title { | ||||
|   padding-left: 70px; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar div[data-wysihtml5-command-value="black"] { | ||||
|   background: black !important; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar div[data-wysihtml5-command-value="silver"] { | ||||
|   background: silver !important; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar div[data-wysihtml5-command-value="gray"] { | ||||
|   background: gray !important; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar div[data-wysihtml5-command-value="maroon"] { | ||||
|   background: maroon !important; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar div[data-wysihtml5-command-value="red"] { | ||||
|   background: red !important; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar div[data-wysihtml5-command-value="purple"] { | ||||
|   background: purple !important; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar div[data-wysihtml5-command-value="green"] { | ||||
|   background: green !important; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar div[data-wysihtml5-command-value="olive"] { | ||||
|   background: olive !important; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar div[data-wysihtml5-command-value="navy"] { | ||||
|   background: navy !important; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar div[data-wysihtml5-command-value="blue"] { | ||||
|   background: blue !important; | ||||
| } | ||||
|  | ||||
| ul.wysihtml5-toolbar div[data-wysihtml5-command-value="orange"] { | ||||
|   background: orange !important; | ||||
| } | ||||
| @@ -1,499 +0,0 @@ | ||||
| !function($, wysi) { | ||||
|     "use strict"; | ||||
|  | ||||
|     var tpl = { | ||||
|         "font-styles": function(locale, options) { | ||||
|             var size = (options && options.size) ? ' btn-'+options.size : ''; | ||||
|             return "<li class='dropdown'>" + | ||||
|               "<a class='btn dropdown-toggle" + size + "' data-toggle='dropdown' href='#'>" + | ||||
|               "<i class='icon-font'></i> <span class='current-font'>" + locale.font_styles.normal + "</span> <b class='caret'></b>" + | ||||
|               "</a>" + | ||||
|               "<ul class='dropdown-menu'>" + | ||||
|                 "<li><a data-wysihtml5-command='formatBlock' data-wysihtml5-command-value='div' tabindex='-1'>" + locale.font_styles.normal + "</a></li>" + | ||||
|                 "<li><a data-wysihtml5-command='formatBlock' data-wysihtml5-command-value='h1' tabindex='-1'>" + locale.font_styles.h1 + "</a></li>" + | ||||
|                 "<li><a data-wysihtml5-command='formatBlock' data-wysihtml5-command-value='h2' tabindex='-1'>" + locale.font_styles.h2 + "</a></li>" + | ||||
|                 "<li><a data-wysihtml5-command='formatBlock' data-wysihtml5-command-value='h3' tabindex='-1'>" + locale.font_styles.h3 + "</a></li>" + | ||||
|               "</ul>" + | ||||
|             "</li>"; | ||||
|         }, | ||||
|  | ||||
|         "emphasis": function(locale, options) { | ||||
|             var size = (options && options.size) ? ' btn-'+options.size : ''; | ||||
|             return "<li>" + | ||||
|               "<div class='btn-group'>" + | ||||
|                 "<a class='btn" + size + "' data-wysihtml5-command='bold' title='CTRL+B' tabindex='-1'>" + locale.emphasis.bold + "</a>" + | ||||
|                 "<a class='btn" + size + "' data-wysihtml5-command='italic' title='CTRL+I' tabindex='-1'>" + locale.emphasis.italic + "</a>" + | ||||
|                 "<a class='btn" + size + "' data-wysihtml5-command='underline' title='CTRL+U' tabindex='-1'>" + locale.emphasis.underline + "</a>" + | ||||
|               "</div>" + | ||||
|             "</li>"; | ||||
|         }, | ||||
|  | ||||
|         "lists": function(locale, options) { | ||||
|             var size = (options && options.size) ? ' btn-'+options.size : ''; | ||||
|             return "<li>" + | ||||
|               "<div class='btn-group'>" + | ||||
|                 "<a class='btn" + size + "' data-wysihtml5-command='insertUnorderedList' title='" + locale.lists.unordered + "' tabindex='-1'><i class='icon-list'></i></a>" + | ||||
|                 "<a class='btn" + size + "' data-wysihtml5-command='insertOrderedList' title='" + locale.lists.ordered + "' tabindex='-1'><i class='icon-th-list'></i></a>" + | ||||
|                 "<a class='btn" + size + "' data-wysihtml5-command='Outdent' title='" + locale.lists.outdent + "' tabindex='-1'><i class='icon-indent-right'></i></a>" + | ||||
|                 "<a class='btn" + size + "' data-wysihtml5-command='Indent' title='" + locale.lists.indent + "' tabindex='-1'><i class='icon-indent-left'></i></a>" + | ||||
|               "</div>" + | ||||
|             "</li>"; | ||||
|         }, | ||||
|  | ||||
|         "link": function(locale, options) { | ||||
|             var size = (options && options.size) ? ' btn-'+options.size : ''; | ||||
|             return "<li>" + | ||||
|               "<div class='bootstrap-wysihtml5-insert-link-modal modal hide fade'>" + | ||||
|                 "<div class='modal-header'>" + | ||||
|                   "<a class='close' data-dismiss='modal'>×</a>" + | ||||
|                   "<h3>" + locale.link.insert + "</h3>" + | ||||
|                 "</div>" + | ||||
|                 "<div class='modal-body'>" + | ||||
|                   "<input value='http://' class='bootstrap-wysihtml5-insert-link-url input-xlarge'>" + | ||||
|                 "</div>" + | ||||
|                 "<div class='modal-footer'>" + | ||||
|                   "<a href='#' class='btn' data-dismiss='modal'>" + locale.link.cancel + "</a>" + | ||||
|                   "<a href='#' class='btn btn-primary' data-dismiss='modal'>" + locale.link.insert + "</a>" + | ||||
|                 "</div>" + | ||||
|               "</div>" + | ||||
|               "<a class='btn" + size + "' data-wysihtml5-command='createLink' title='" + locale.link.insert + "' tabindex='-1'><i class='icon-share'></i></a>" + | ||||
|             "</li>"; | ||||
|         }, | ||||
|  | ||||
|         "image": function(locale, options) { | ||||
|             var size = (options && options.size) ? ' btn-'+options.size : ''; | ||||
|             return "<li>" + | ||||
|               "<div class='bootstrap-wysihtml5-insert-image-modal modal hide fade'>" + | ||||
|                 "<div class='modal-header'>" + | ||||
|                   "<a class='close' data-dismiss='modal'>×</a>" + | ||||
|                   "<h3>" + locale.image.insert + "</h3>" + | ||||
|                 "</div>" + | ||||
|                 "<div class='modal-body'>" + | ||||
|                   "<input value='http://' class='bootstrap-wysihtml5-insert-image-url input-xlarge'>" + | ||||
|                 "</div>" + | ||||
|                 "<div class='modal-footer'>" + | ||||
|                   "<a href='#' class='btn' data-dismiss='modal'>" + locale.image.cancel + "</a>" + | ||||
|                   "<a href='#' class='btn btn-primary' data-dismiss='modal'>" + locale.image.insert + "</a>" + | ||||
|                 "</div>" + | ||||
|               "</div>" + | ||||
|               "<a class='btn" + size + "' data-wysihtml5-command='insertImage' title='" + locale.image.insert + "' tabindex='-1'><i class='icon-picture'></i></a>" + | ||||
|             "</li>"; | ||||
|         }, | ||||
|  | ||||
|         "html": function(locale, options) { | ||||
|             var size = (options && options.size) ? ' btn-'+options.size : ''; | ||||
|             return "<li>" + | ||||
|               "<div class='btn-group'>" + | ||||
|                 "<a class='btn" + size + "' data-wysihtml5-action='change_view' title='" + locale.html.edit + "' tabindex='-1'><i class='icon-pencil'></i></a>" + | ||||
|               "</div>" + | ||||
|             "</li>"; | ||||
|         }, | ||||
|  | ||||
|         "color": function(locale, options) { | ||||
|             var size = (options && options.size) ? ' btn-'+options.size : ''; | ||||
|             return "<li class='dropdown'>" + | ||||
|               "<a class='btn dropdown-toggle" + size + "' data-toggle='dropdown' href='#' tabindex='-1'>" + | ||||
|                 "<span class='current-color'>" + locale.colours.black + "</span> <b class='caret'></b>" + | ||||
|               "</a>" + | ||||
|               "<ul class='dropdown-menu'>" + | ||||
|                 "<li><div class='wysihtml5-colors' data-wysihtml5-command-value='black'></div><a class='wysihtml5-colors-title' data-wysihtml5-command='foreColor' data-wysihtml5-command-value='black'>" + locale.colours.black + "</a></li>" + | ||||
|                 "<li><div class='wysihtml5-colors' data-wysihtml5-command-value='silver'></div><a class='wysihtml5-colors-title' data-wysihtml5-command='foreColor' data-wysihtml5-command-value='silver'>" + locale.colours.silver + "</a></li>" + | ||||
|                 "<li><div class='wysihtml5-colors' data-wysihtml5-command-value='gray'></div><a class='wysihtml5-colors-title' data-wysihtml5-command='foreColor' data-wysihtml5-command-value='gray'>" + locale.colours.gray + "</a></li>" + | ||||
|                 "<li><div class='wysihtml5-colors' data-wysihtml5-command-value='maroon'></div><a class='wysihtml5-colors-title' data-wysihtml5-command='foreColor' data-wysihtml5-command-value='maroon'>" + locale.colours.maroon + "</a></li>" + | ||||
|                 "<li><div class='wysihtml5-colors' data-wysihtml5-command-value='red'></div><a class='wysihtml5-colors-title' data-wysihtml5-command='foreColor' data-wysihtml5-command-value='red'>" + locale.colours.red + "</a></li>" + | ||||
|                 "<li><div class='wysihtml5-colors' data-wysihtml5-command-value='purple'></div><a class='wysihtml5-colors-title' data-wysihtml5-command='foreColor' data-wysihtml5-command-value='purple'>" + locale.colours.purple + "</a></li>" + | ||||
|                 "<li><div class='wysihtml5-colors' data-wysihtml5-command-value='green'></div><a class='wysihtml5-colors-title' data-wysihtml5-command='foreColor' data-wysihtml5-command-value='green'>" + locale.colours.green + "</a></li>" + | ||||
|                 "<li><div class='wysihtml5-colors' data-wysihtml5-command-value='olive'></div><a class='wysihtml5-colors-title' data-wysihtml5-command='foreColor' data-wysihtml5-command-value='olive'>" + locale.colours.olive + "</a></li>" + | ||||
|                 "<li><div class='wysihtml5-colors' data-wysihtml5-command-value='navy'></div><a class='wysihtml5-colors-title' data-wysihtml5-command='foreColor' data-wysihtml5-command-value='navy'>" + locale.colours.navy + "</a></li>" + | ||||
|                 "<li><div class='wysihtml5-colors' data-wysihtml5-command-value='blue'></div><a class='wysihtml5-colors-title' data-wysihtml5-command='foreColor' data-wysihtml5-command-value='blue'>" + locale.colours.blue + "</a></li>" + | ||||
|                 "<li><div class='wysihtml5-colors' data-wysihtml5-command-value='orange'></div><a class='wysihtml5-colors-title' data-wysihtml5-command='foreColor' data-wysihtml5-command-value='orange'>" + locale.colours.orange + "</a></li>" + | ||||
|               "</ul>" + | ||||
|             "</li>"; | ||||
|         } | ||||
|     }; | ||||
|  | ||||
|     var templates = function(key, locale, options) { | ||||
|         return tpl[key](locale, options); | ||||
|     }; | ||||
|  | ||||
|  | ||||
|     var Wysihtml5 = function(el, options) { | ||||
|         this.el = el; | ||||
|         var toolbarOpts = options || defaultOptions; | ||||
|         for(var t in toolbarOpts.customTemplates) { | ||||
|           tpl[t] = toolbarOpts.customTemplates[t]; | ||||
|         } | ||||
|         this.toolbar = this.createToolbar(el, toolbarOpts); | ||||
|         this.editor =  this.createEditor(options); | ||||
|  | ||||
|         window.editor = this.editor; | ||||
|  | ||||
|         $('iframe.wysihtml5-sandbox').each(function(i, el){ | ||||
|             $(el.contentWindow).off('focus.wysihtml5').on({ | ||||
|                 'focus.wysihtml5' : function(){ | ||||
|                     $('li.dropdown').removeClass('open'); | ||||
|                 } | ||||
|             }); | ||||
|         }); | ||||
|     }; | ||||
|  | ||||
|     Wysihtml5.prototype = { | ||||
|  | ||||
|         constructor: Wysihtml5, | ||||
|  | ||||
|         createEditor: function(options) { | ||||
|             options = options || {}; | ||||
|              | ||||
|             // Add the toolbar to a clone of the options object so multiple instances | ||||
|             // of the WYISYWG don't break because "toolbar" is already defined | ||||
|             options = $.extend(true, {}, options); | ||||
|             options.toolbar = this.toolbar[0]; | ||||
|  | ||||
|             var editor = new wysi.Editor(this.el[0], options); | ||||
|  | ||||
|             if(options && options.events) { | ||||
|                 for(var eventName in options.events) { | ||||
|                     editor.on(eventName, options.events[eventName]); | ||||
|                 } | ||||
|             } | ||||
|             return editor; | ||||
|         }, | ||||
|  | ||||
|         createToolbar: function(el, options) { | ||||
|             var self = this; | ||||
|             var toolbar = $("<ul/>", { | ||||
|                 'class' : "wysihtml5-toolbar", | ||||
|                 'style': "display:none" | ||||
|             }); | ||||
|             var culture = options.locale || defaultOptions.locale || "en"; | ||||
|             for(var key in defaultOptions) { | ||||
|                 var value = false; | ||||
|  | ||||
|                 if(options[key] !== undefined) { | ||||
|                     if(options[key] === true) { | ||||
|                         value = true; | ||||
|                     } | ||||
|                 } else { | ||||
|                     value = defaultOptions[key]; | ||||
|                 } | ||||
|  | ||||
|                 if(value === true) { | ||||
|                     toolbar.append(templates(key, locale[culture], options)); | ||||
|  | ||||
|                     if(key === "html") { | ||||
|                         this.initHtml(toolbar); | ||||
|                     } | ||||
|  | ||||
|                     if(key === "link") { | ||||
|                         this.initInsertLink(toolbar); | ||||
|                     } | ||||
|  | ||||
|                     if(key === "image") { | ||||
|                         this.initInsertImage(toolbar); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             if(options.toolbar) { | ||||
|                 for(key in options.toolbar) { | ||||
|                     toolbar.append(options.toolbar[key]); | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             toolbar.find("a[data-wysihtml5-command='formatBlock']").click(function(e) { | ||||
|                 var target = e.target || e.srcElement; | ||||
|                 var el = $(target); | ||||
|                 self.toolbar.find('.current-font').text(el.html()); | ||||
|             }); | ||||
|  | ||||
|             toolbar.find("a[data-wysihtml5-command='foreColor']").click(function(e) { | ||||
|                 var target = e.target || e.srcElement; | ||||
|                 var el = $(target); | ||||
|                 self.toolbar.find('.current-color').text(el.html()); | ||||
|             }); | ||||
|  | ||||
|             this.el.before(toolbar); | ||||
|  | ||||
|             return toolbar; | ||||
|         }, | ||||
|  | ||||
|         initHtml: function(toolbar) { | ||||
|             var changeViewSelector = "a[data-wysihtml5-action='change_view']"; | ||||
|             toolbar.find(changeViewSelector).click(function(e) { | ||||
|                 toolbar.find('a.btn').not(changeViewSelector).toggleClass('disabled'); | ||||
|             }); | ||||
|         }, | ||||
|  | ||||
|         initInsertImage: function(toolbar) { | ||||
|             var self = this; | ||||
|             var insertImageModal = toolbar.find('.bootstrap-wysihtml5-insert-image-modal'); | ||||
|             var urlInput = insertImageModal.find('.bootstrap-wysihtml5-insert-image-url'); | ||||
|             var insertButton = insertImageModal.find('a.btn-primary'); | ||||
|             var initialValue = urlInput.val(); | ||||
|             var caretBookmark; | ||||
|  | ||||
|             var insertImage = function() { | ||||
|                 var url = urlInput.val(); | ||||
|                 urlInput.val(initialValue); | ||||
|                 self.editor.currentView.element.focus(); | ||||
|                 if (caretBookmark) { | ||||
|                   self.editor.composer.selection.setBookmark(caretBookmark); | ||||
|                   caretBookmark = null; | ||||
|                 } | ||||
|                 self.editor.composer.commands.exec("insertImage", url); | ||||
|             }; | ||||
|  | ||||
|             urlInput.keypress(function(e) { | ||||
|                 if(e.which == 13) { | ||||
|                     insertImage(); | ||||
|                     insertImageModal.modal('hide'); | ||||
|                 } | ||||
|             }); | ||||
|  | ||||
|             insertButton.click(insertImage); | ||||
|  | ||||
|             insertImageModal.on('shown', function() { | ||||
|                 urlInput.focus(); | ||||
|             }); | ||||
|  | ||||
|             insertImageModal.on('hide', function() { | ||||
|                 self.editor.currentView.element.focus(); | ||||
|             }); | ||||
|  | ||||
|             toolbar.find('a[data-wysihtml5-command=insertImage]').click(function() { | ||||
|                 var activeButton = $(this).hasClass("wysihtml5-command-active"); | ||||
|  | ||||
|                 if (!activeButton) { | ||||
|                     self.editor.currentView.element.focus(false); | ||||
|                     caretBookmark = self.editor.composer.selection.getBookmark(); | ||||
|                     insertImageModal.appendTo('body').modal('show'); | ||||
|                     insertImageModal.on('click.dismiss.modal', '[data-dismiss="modal"]', function(e) { | ||||
|                         e.stopPropagation(); | ||||
|                     }); | ||||
|                     return false; | ||||
|                 } | ||||
|                 else { | ||||
|                     return true; | ||||
|                 } | ||||
|             }); | ||||
|         }, | ||||
|  | ||||
|         initInsertLink: function(toolbar) { | ||||
|             var self = this; | ||||
|             var insertLinkModal = toolbar.find('.bootstrap-wysihtml5-insert-link-modal'); | ||||
|             var urlInput = insertLinkModal.find('.bootstrap-wysihtml5-insert-link-url'); | ||||
|             var insertButton = insertLinkModal.find('a.btn-primary'); | ||||
|             var initialValue = urlInput.val(); | ||||
|             var caretBookmark; | ||||
|  | ||||
|             var insertLink = function() { | ||||
|                 var url = urlInput.val(); | ||||
|                 urlInput.val(initialValue); | ||||
|                 self.editor.currentView.element.focus(); | ||||
|                 if (caretBookmark) { | ||||
|                   self.editor.composer.selection.setBookmark(caretBookmark); | ||||
|                   caretBookmark = null; | ||||
|                 } | ||||
|                 self.editor.composer.commands.exec("createLink", { | ||||
|                     href: url, | ||||
|                     target: "_blank", | ||||
|                     rel: "nofollow" | ||||
|                 }); | ||||
|             }; | ||||
|             var pressedEnter = false; | ||||
|  | ||||
|             urlInput.keypress(function(e) { | ||||
|                 if(e.which == 13) { | ||||
|                     insertLink(); | ||||
|                     insertLinkModal.modal('hide'); | ||||
|                 } | ||||
|             }); | ||||
|  | ||||
|             insertButton.click(insertLink); | ||||
|  | ||||
|             insertLinkModal.on('shown', function() { | ||||
|                 urlInput.focus(); | ||||
|             }); | ||||
|  | ||||
|             insertLinkModal.on('hide', function() { | ||||
|                 self.editor.currentView.element.focus(); | ||||
|             }); | ||||
|  | ||||
|             toolbar.find('a[data-wysihtml5-command=createLink]').click(function() { | ||||
|                 var activeButton = $(this).hasClass("wysihtml5-command-active"); | ||||
|  | ||||
|                 if (!activeButton) { | ||||
|                     self.editor.currentView.element.focus(false); | ||||
|                     caretBookmark = self.editor.composer.selection.getBookmark(); | ||||
|                     insertLinkModal.appendTo('body').modal('show'); | ||||
|                     insertLinkModal.on('click.dismiss.modal', '[data-dismiss="modal"]', function(e) { | ||||
|                         e.stopPropagation(); | ||||
|                     }); | ||||
|                     return false; | ||||
|                 } | ||||
|                 else { | ||||
|                     return true; | ||||
|                 } | ||||
|             }); | ||||
|         } | ||||
|     }; | ||||
|  | ||||
|     // these define our public api | ||||
|     var methods = { | ||||
|         resetDefaults: function() { | ||||
|             $.fn.wysihtml5.defaultOptions = $.extend(true, {}, $.fn.wysihtml5.defaultOptionsCache); | ||||
|         }, | ||||
|         bypassDefaults: function(options) { | ||||
|             return this.each(function () { | ||||
|                 var $this = $(this); | ||||
|                 $this.data('wysihtml5', new Wysihtml5($this, options)); | ||||
|             }); | ||||
|         }, | ||||
|         shallowExtend: function (options) { | ||||
|             var settings = $.extend({}, $.fn.wysihtml5.defaultOptions, options || {}); | ||||
|             var that = this; | ||||
|             return methods.bypassDefaults.apply(that, [settings]); | ||||
|         }, | ||||
|         deepExtend: function(options) { | ||||
|             var settings = $.extend(true, {}, $.fn.wysihtml5.defaultOptions, options || {}); | ||||
|             var that = this; | ||||
|             return methods.bypassDefaults.apply(that, [settings]); | ||||
|         }, | ||||
|         init: function(options) { | ||||
|             var that = this; | ||||
|             return methods.shallowExtend.apply(that, [options]); | ||||
|         } | ||||
|     }; | ||||
|  | ||||
|     $.fn.wysihtml5 = function ( method ) { | ||||
|         if ( methods[method] ) { | ||||
|             return methods[method].apply( this, Array.prototype.slice.call( arguments, 1 )); | ||||
|         } else if ( typeof method === 'object' || ! method ) { | ||||
|             return methods.init.apply( this, arguments ); | ||||
|         } else { | ||||
|             $.error( 'Method ' +  method + ' does not exist on jQuery.wysihtml5' ); | ||||
|         }     | ||||
|     }; | ||||
|  | ||||
|     $.fn.wysihtml5.Constructor = Wysihtml5; | ||||
|  | ||||
|     var defaultOptions = $.fn.wysihtml5.defaultOptions = { | ||||
|         "font-styles": true, | ||||
|         "color": false, | ||||
|         "emphasis": true, | ||||
|         "lists": true, | ||||
|         "html": false, | ||||
|         "link": true, | ||||
|         "image": true, | ||||
|         events: {}, | ||||
|         parserRules: { | ||||
|             classes: { | ||||
|                 // (path_to_project/lib/css/wysiwyg-color.css) | ||||
|                 "wysiwyg-color-silver" : 1, | ||||
|                 "wysiwyg-color-gray" : 1, | ||||
|                 "wysiwyg-color-white" : 1, | ||||
|                 "wysiwyg-color-maroon" : 1, | ||||
|                 "wysiwyg-color-red" : 1, | ||||
|                 "wysiwyg-color-purple" : 1, | ||||
|                 "wysiwyg-color-fuchsia" : 1, | ||||
|                 "wysiwyg-color-green" : 1, | ||||
|                 "wysiwyg-color-lime" : 1, | ||||
|                 "wysiwyg-color-olive" : 1, | ||||
|                 "wysiwyg-color-yellow" : 1, | ||||
|                 "wysiwyg-color-navy" : 1, | ||||
|                 "wysiwyg-color-blue" : 1, | ||||
|                 "wysiwyg-color-teal" : 1, | ||||
|                 "wysiwyg-color-aqua" : 1, | ||||
|                 "wysiwyg-color-orange" : 1 | ||||
|             }, | ||||
|             tags: { | ||||
|                 "b":  {}, | ||||
|                 "i":  {}, | ||||
|                 "br": {}, | ||||
|                 "ol": {}, | ||||
|                 "ul": {}, | ||||
|                 "li": {}, | ||||
|                 "h1": {}, | ||||
|                 "h2": {}, | ||||
|                 "h3": {}, | ||||
|                 "blockquote": {}, | ||||
|                 "u": 1, | ||||
|                 "img": { | ||||
|                     "check_attributes": { | ||||
|                         "width": "numbers", | ||||
|                         "alt": "alt", | ||||
|                         "src": "url", | ||||
|                         "height": "numbers" | ||||
|                     } | ||||
|                 }, | ||||
|                 "a":  { | ||||
|                     set_attributes: { | ||||
|                         target: "_blank", | ||||
|                         rel:    "nofollow" | ||||
|                     }, | ||||
|                     check_attributes: { | ||||
|                         href:   "url" // important to avoid XSS | ||||
|                     } | ||||
|                 }, | ||||
|                 "span": 1, | ||||
|                 "div": 1, | ||||
|                 // to allow save and edit files with code tag hacks | ||||
|                 "code": 1, | ||||
|                 "pre": 1 | ||||
|             } | ||||
|         }, | ||||
|         stylesheets: ["./lib/css/wysiwyg-color.css"], // (path_to_project/lib/css/wysiwyg-color.css) | ||||
|         locale: "en" | ||||
|     }; | ||||
|  | ||||
|     if (typeof $.fn.wysihtml5.defaultOptionsCache === 'undefined') { | ||||
|         $.fn.wysihtml5.defaultOptionsCache = $.extend(true, {}, $.fn.wysihtml5.defaultOptions); | ||||
|     } | ||||
|  | ||||
|     var locale = $.fn.wysihtml5.locale = { | ||||
|         en: { | ||||
|             font_styles: { | ||||
|                 normal: "Normal text", | ||||
|                 h1: "Heading 1", | ||||
|                 h2: "Heading 2", | ||||
|                 h3: "Heading 3" | ||||
|             }, | ||||
|             emphasis: { | ||||
|                 bold: "Bold", | ||||
|                 italic: "Italic", | ||||
|                 underline: "Underline" | ||||
|             }, | ||||
|             lists: { | ||||
|                 unordered: "Unordered list", | ||||
|                 ordered: "Ordered list", | ||||
|                 outdent: "Outdent", | ||||
|                 indent: "Indent" | ||||
|             }, | ||||
|             link: { | ||||
|                 insert: "Insert link", | ||||
|                 cancel: "Cancel" | ||||
|             }, | ||||
|             image: { | ||||
|                 insert: "Insert image", | ||||
|                 cancel: "Cancel" | ||||
|             }, | ||||
|             html: { | ||||
|                 edit: "Edit HTML" | ||||
|             }, | ||||
|             colours: { | ||||
|                 black: "Black", | ||||
|                 silver: "Silver", | ||||
|                 gray: "Grey", | ||||
|                 maroon: "Maroon", | ||||
|                 red: "Red", | ||||
|                 purple: "Purple", | ||||
|                 green: "Green", | ||||
|                 olive: "Olive", | ||||
|                 navy: "Navy", | ||||
|                 blue: "Blue", | ||||
|                 orange: "Orange" | ||||
|             } | ||||
|         } | ||||
|     }; | ||||
|  | ||||
| }(window.jQuery, window.wysihtml5); | ||||
| @@ -1,261 +0,0 @@ | ||||
| /* | ||||
|  wysihtml5 v0.3.0 | ||||
|  https://github.com/xing/wysihtml5 | ||||
|  | ||||
|  Author: Christopher Blum (https://github.com/tiff) | ||||
|  | ||||
|  Copyright (C) 2012 XING AG | ||||
|  Licensed under the MIT license (MIT) | ||||
|  | ||||
|  Rangy, a cross-browser JavaScript range and selection library | ||||
|  http://code.google.com/p/rangy/ | ||||
|  | ||||
|  Copyright 2011, Tim Down | ||||
|  Licensed under the MIT license. | ||||
|  Version: 1.2.2 | ||||
|  Build date: 13 November 2011 | ||||
| */ | ||||
| var wysihtml5={version:"0.3.0",commands:{},dom:{},quirks:{},toolbar:{},lang:{},selection:{},views:{},INVISIBLE_SPACE:"\ufeff",EMPTY_FUNCTION:function(){},ELEMENT_NODE:1,TEXT_NODE:3,BACKSPACE_KEY:8,ENTER_KEY:13,ESCAPE_KEY:27,SPACE_KEY:32,DELETE_KEY:46}; | ||||
| window.rangy=function(){function b(a,b){var c=typeof a[b];return c==k||!!(c==h&&a[b])||"unknown"==c}function c(a,b){return!!(typeof a[b]==h&&a[b])}function a(a,b){return typeof a[b]!=j}function d(a){return function(b,c){for(var d=c.length;d--;)if(!a(b,c[d]))return!1;return!0}}function e(a){return a&&m(a,r)&&x(a,q)}function f(a){window.alert("Rangy not supported in your browser. Reason: "+a);o.initialized=!0;o.supported=!1}function g(){if(!o.initialized){var a,d=!1,h=!1;b(document,"createRange")&& | ||||
| (a=document.createRange(),m(a,p)&&x(a,n)&&(d=!0),a.detach());if((a=c(document,"body")?document.body:document.getElementsByTagName("body")[0])&&b(a,"createTextRange"))a=a.createTextRange(),e(a)&&(h=!0);!d&&!h&&f("Neither Range nor TextRange are implemented");o.initialized=!0;o.features={implementsDomRange:d,implementsTextRange:h};d=w.concat(z);h=0;for(a=d.length;h<a;++h)try{d[h](o)}catch(j){c(window,"console")&&b(window.console,"log")&&window.console.log("Init listener threw an exception. Continuing.", | ||||
| j)}}}function i(a){this.name=a;this.supported=this.initialized=!1}var h="object",k="function",j="undefined",n="startContainer startOffset endContainer endOffset collapsed commonAncestorContainer START_TO_START START_TO_END END_TO_START END_TO_END".split(" "),p="setStart setStartBefore setStartAfter setEnd setEndBefore setEndAfter collapse selectNode selectNodeContents compareBoundaryPoints deleteContents extractContents cloneContents insertNode surroundContents cloneRange toString detach".split(" "), | ||||
| q="boundingHeight boundingLeft boundingTop boundingWidth htmlText text".split(" "),r="collapse compareEndPoints duplicate getBookmark moveToBookmark moveToElementText parentElement pasteHTML select setEndPoint getBoundingClientRect".split(" "),m=d(b),s=d(c),x=d(a),o={version:"1.2.2",initialized:!1,supported:!0,util:{isHostMethod:b,isHostObject:c,isHostProperty:a,areHostMethods:m,areHostObjects:s,areHostProperties:x,isTextRange:e},features:{},modules:{},config:{alertOnWarn:!1,preferTextRange:!1}}; | ||||
| o.fail=f;o.warn=function(a){a="Rangy warning: "+a;o.config.alertOnWarn?window.alert(a):typeof window.console!=j&&typeof window.console.log!=j&&window.console.log(a)};({}).hasOwnProperty?o.util.extend=function(a,b){for(var c in b)b.hasOwnProperty(c)&&(a[c]=b[c])}:f("hasOwnProperty not supported");var z=[],w=[];o.init=g;o.addInitListener=function(a){o.initialized?a(o):z.push(a)};var y=[];o.addCreateMissingNativeApiListener=function(a){y.push(a)};o.createMissingNativeApi=function(a){a=a||window;g(); | ||||
| for(var b=0,c=y.length;b<c;++b)y[b](a)};i.prototype.fail=function(a){this.initialized=!0;this.supported=!1;throw Error("Module '"+this.name+"' failed to load: "+a);};i.prototype.warn=function(a){o.warn("Module "+this.name+": "+a)};i.prototype.createError=function(a){return Error("Error in Rangy "+this.name+" module: "+a)};o.createModule=function(a,b){var c=new i(a);o.modules[a]=c;w.push(function(a){b(a,c);c.initialized=!0;c.supported=!0})};o.requireModules=function(a){for(var b=0,c=a.length,d,h;b< | ||||
| c;++b){h=a[b];d=o.modules[h];if(!d||!(d instanceof i))throw Error("Module '"+h+"' not found");if(!d.supported)throw Error("Module '"+h+"' not supported");}};var A=!1,s=function(){A||(A=!0,o.initialized||g())};if(typeof window==j)f("No window found");else if(typeof document==j)f("No document found");else return b(document,"addEventListener")&&document.addEventListener("DOMContentLoaded",s,!1),b(window,"addEventListener")?window.addEventListener("load",s,!1):b(window,"attachEvent")?window.attachEvent("onload", | ||||
| s):f("Window does not have required addEventListener or attachEvent method"),o}(); | ||||
| rangy.createModule("DomUtil",function(b,c){function a(a){for(var b=0;a=a.previousSibling;)b++;return b}function d(a,b){var c=[],d;for(d=a;d;d=d.parentNode)c.push(d);for(d=b;d;d=d.parentNode)if(m(c,d))return d;return null}function e(a,b,c){for(c=c?a:a.parentNode;c;){a=c.parentNode;if(a===b)return c;c=a}return null}function f(a){a=a.nodeType;return 3==a||4==a||8==a}function g(a,b){var c=b.nextSibling,d=b.parentNode;c?d.insertBefore(a,c):d.appendChild(a);return a}function i(a){if(9==a.nodeType)return a; | ||||
| if(typeof a.ownerDocument!=p)return a.ownerDocument;if(typeof a.document!=p)return a.document;if(a.parentNode)return i(a.parentNode);throw Error("getDocument: no document found for node");}function h(a){return!a?"[No node]":f(a)?'"'+a.data+'"':1==a.nodeType?"<"+a.nodeName+(a.id?' id="'+a.id+'"':"")+">["+a.childNodes.length+"]":a.nodeName}function k(a){this._next=this.root=a}function j(a,b){this.node=a;this.offset=b}function n(a){this.code=this[a];this.codeName=a;this.message="DOMException: "+this.codeName} | ||||
| var p="undefined",q=b.util;q.areHostMethods(document,["createDocumentFragment","createElement","createTextNode"])||c.fail("document missing a Node creation method");q.isHostMethod(document,"getElementsByTagName")||c.fail("document missing getElementsByTagName method");var r=document.createElement("div");q.areHostMethods(r,["insertBefore","appendChild","cloneNode"])||c.fail("Incomplete Element implementation");q.isHostProperty(r,"innerHTML")||c.fail("Element is missing innerHTML property");r=document.createTextNode("test"); | ||||
| q.areHostMethods(r,["splitText","deleteData","insertData","appendData","cloneNode"])||c.fail("Incomplete Text Node implementation");var m=function(a,b){for(var c=a.length;c--;)if(a[c]===b)return!0;return!1};k.prototype={_current:null,hasNext:function(){return!!this._next},next:function(){var a=this._current=this._next,b;if(this._current){b=a.firstChild;if(!b)for(b=null;a!==this.root&&!(b=a.nextSibling);)a=a.parentNode;this._next=b}return this._current},detach:function(){this._current=this._next=this.root= | ||||
| null}};j.prototype={equals:function(a){return this.node===a.node&this.offset==a.offset},inspect:function(){return"[DomPosition("+h(this.node)+":"+this.offset+")]"}};n.prototype={INDEX_SIZE_ERR:1,HIERARCHY_REQUEST_ERR:3,WRONG_DOCUMENT_ERR:4,NO_MODIFICATION_ALLOWED_ERR:7,NOT_FOUND_ERR:8,NOT_SUPPORTED_ERR:9,INVALID_STATE_ERR:11};n.prototype.toString=function(){return this.message};b.dom={arrayContains:m,isHtmlNamespace:function(a){var b;return typeof a.namespaceURI==p||null===(b=a.namespaceURI)||"http://www.w3.org/1999/xhtml"== | ||||
| b},parentElement:function(a){a=a.parentNode;return 1==a.nodeType?a:null},getNodeIndex:a,getNodeLength:function(a){var b;return f(a)?a.length:(b=a.childNodes)?b.length:0},getCommonAncestor:d,isAncestorOf:function(a,b,c){for(b=c?b:b.parentNode;b;){if(b===a)return!0;b=b.parentNode}return!1},getClosestAncestorIn:e,isCharacterDataNode:f,insertAfter:g,splitDataNode:function(a,b){var c=a.cloneNode(!1);c.deleteData(0,b);a.deleteData(b,a.length-b);g(c,a);return c},getDocument:i,getWindow:function(a){a=i(a); | ||||
| if(typeof a.defaultView!=p)return a.defaultView;if(typeof a.parentWindow!=p)return a.parentWindow;throw Error("Cannot get a window object for node");},getIframeWindow:function(a){if(typeof a.contentWindow!=p)return a.contentWindow;if(typeof a.contentDocument!=p)return a.contentDocument.defaultView;throw Error("getIframeWindow: No Window object found for iframe element");},getIframeDocument:function(a){if(typeof a.contentDocument!=p)return a.contentDocument;if(typeof a.contentWindow!=p)return a.contentWindow.document; | ||||
| throw Error("getIframeWindow: No Document object found for iframe element");},getBody:function(a){return q.isHostObject(a,"body")?a.body:a.getElementsByTagName("body")[0]},getRootContainer:function(a){for(var b;b=a.parentNode;)a=b;return a},comparePoints:function(b,c,h,j){var k;if(b==h)return c===j?0:c<j?-1:1;if(k=e(h,b,!0))return c<=a(k)?-1:1;if(k=e(b,h,!0))return a(k)<j?-1:1;c=d(b,h);b=b===c?c:e(b,c,!0);h=h===c?c:e(h,c,!0);if(b===h)throw Error("comparePoints got to case 4 and childA and childB are the same!"); | ||||
| for(c=c.firstChild;c;){if(c===b)return-1;if(c===h)return 1;c=c.nextSibling}throw Error("Should not be here!");},inspectNode:h,fragmentFromNodeChildren:function(a){for(var b=i(a).createDocumentFragment(),c;c=a.firstChild;)b.appendChild(c);return b},createIterator:function(a){return new k(a)},DomPosition:j};b.DOMException=n}); | ||||
| rangy.createModule("DomRange",function(b){function c(a,b){return 3!=a.nodeType&&(l.isAncestorOf(a,b.startContainer,!0)||l.isAncestorOf(a,b.endContainer,!0))}function a(a){return l.getDocument(a.startContainer)}function d(a,b,c){if(b=a._listeners[b])for(var d=0,h=b.length;d<h;++d)b[d].call(a,{target:a,args:c})}function e(a){return new u(a.parentNode,l.getNodeIndex(a))}function f(a){return new u(a.parentNode,l.getNodeIndex(a)+1)}function g(a,b,c){var d=11==a.nodeType?a.firstChild:a;l.isCharacterDataNode(b)? | ||||
| c==b.length?l.insertAfter(a,b):b.parentNode.insertBefore(a,0==c?b:l.splitDataNode(b,c)):c>=b.childNodes.length?b.appendChild(a):b.insertBefore(a,b.childNodes[c]);return d}function i(b){for(var c,d,h=a(b.range).createDocumentFragment();d=b.next();){c=b.isPartiallySelectedSubtree();d=d.cloneNode(!c);c&&(c=b.getSubtreeIterator(),d.appendChild(i(c)),c.detach(!0));if(10==d.nodeType)throw new B("HIERARCHY_REQUEST_ERR");h.appendChild(d)}return h}function h(a,b,c){for(var d,e,c=c||{stop:!1};d=a.next();)if(a.isPartiallySelectedSubtree())if(!1=== | ||||
| b(d)){c.stop=!0;break}else{if(d=a.getSubtreeIterator(),h(d,b,c),d.detach(!0),c.stop)break}else for(d=l.createIterator(d);e=d.next();)if(!1===b(e)){c.stop=!0;return}}function k(a){for(var b;a.next();)a.isPartiallySelectedSubtree()?(b=a.getSubtreeIterator(),k(b),b.detach(!0)):a.remove()}function j(b){for(var c,d=a(b.range).createDocumentFragment(),h;c=b.next();){b.isPartiallySelectedSubtree()?(c=c.cloneNode(!1),h=b.getSubtreeIterator(),c.appendChild(j(h)),h.detach(!0)):b.remove();if(10==c.nodeType)throw new B("HIERARCHY_REQUEST_ERR"); | ||||
| d.appendChild(c)}return d}function n(a,b,c){var d=!(!b||!b.length),e,j=!!c;d&&(e=RegExp("^("+b.join("|")+")$"));var k=[];h(new q(a,!1),function(a){(!d||e.test(a.nodeType))&&(!j||c(a))&&k.push(a)});return k}function p(a){return"["+("undefined"==typeof a.getName?"Range":a.getName())+"("+l.inspectNode(a.startContainer)+":"+a.startOffset+", "+l.inspectNode(a.endContainer)+":"+a.endOffset+")]"}function q(a,b){this.range=a;this.clonePartiallySelectedTextNodes=b;if(!a.collapsed){this.sc=a.startContainer; | ||||
| this.so=a.startOffset;this.ec=a.endContainer;this.eo=a.endOffset;var c=a.commonAncestorContainer;this.sc===this.ec&&l.isCharacterDataNode(this.sc)?(this.isSingleCharacterDataNode=!0,this._first=this._last=this._next=this.sc):(this._first=this._next=this.sc===c&&!l.isCharacterDataNode(this.sc)?this.sc.childNodes[this.so]:l.getClosestAncestorIn(this.sc,c,!0),this._last=this.ec===c&&!l.isCharacterDataNode(this.ec)?this.ec.childNodes[this.eo-1]:l.getClosestAncestorIn(this.ec,c,!0))}}function r(a){this.code= | ||||
| this[a];this.codeName=a;this.message="RangeException: "+this.codeName}function m(a,b,c){this.nodes=n(a,b,c);this._next=this.nodes[0];this._position=0}function s(a){return function(b,c){for(var d,h=c?b:b.parentNode;h;){d=h.nodeType;if(l.arrayContains(a,d))return h;h=h.parentNode}return null}}function x(a,b){if($(a,b))throw new r("INVALID_NODE_TYPE_ERR");}function o(a){if(!a.startContainer)throw new B("INVALID_STATE_ERR");}function z(a,b){if(!l.arrayContains(b,a.nodeType))throw new r("INVALID_NODE_TYPE_ERR"); | ||||
| }function w(a,b){if(0>b||b>(l.isCharacterDataNode(a)?a.length:a.childNodes.length))throw new B("INDEX_SIZE_ERR");}function y(a,b){if(O(a,!0)!==O(b,!0))throw new B("WRONG_DOCUMENT_ERR");}function A(a){if(aa(a,!0))throw new B("NO_MODIFICATION_ALLOWED_ERR");}function t(a,b){if(!a)throw new B(b);}function v(a){o(a);if(!l.arrayContains(G,a.startContainer.nodeType)&&!O(a.startContainer,!0)||!l.arrayContains(G,a.endContainer.nodeType)&&!O(a.endContainer,!0)||!(a.startOffset<=(l.isCharacterDataNode(a.startContainer)? | ||||
| a.startContainer.length:a.startContainer.childNodes.length))||!(a.endOffset<=(l.isCharacterDataNode(a.endContainer)?a.endContainer.length:a.endContainer.childNodes.length)))throw Error("Range error: Range is no longer valid after DOM mutation ("+a.inspect()+")");}function D(){}function K(a){a.START_TO_START=Q;a.START_TO_END=U;a.END_TO_END=ba;a.END_TO_START=V;a.NODE_BEFORE=W;a.NODE_AFTER=X;a.NODE_BEFORE_AND_AFTER=Y;a.NODE_INSIDE=R}function F(a){K(a);K(a.prototype)}function E(a,b){return function(){v(this); | ||||
| var c=this.startContainer,d=this.startOffset,e=this.commonAncestorContainer,j=new q(this,!0);c!==e&&(c=l.getClosestAncestorIn(c,e,!0),d=f(c),c=d.node,d=d.offset);h(j,A);j.reset();e=a(j);j.detach();b(this,c,d,c,d);return e}}function I(a,d,h){function g(a,b){return function(c){o(this);z(c,L);z(M(c),G);c=(a?e:f)(c);(b?i:n)(this,c.node,c.offset)}}function i(a,b,c){var h=a.endContainer,e=a.endOffset;if(b!==a.startContainer||c!==a.startOffset){if(M(b)!=M(h)||1==l.comparePoints(b,c,h,e))h=b,e=c;d(a,b,c, | ||||
| h,e)}}function n(a,b,c){var h=a.startContainer,e=a.startOffset;if(b!==a.endContainer||c!==a.endOffset){if(M(b)!=M(h)||-1==l.comparePoints(b,c,h,e))h=b,e=c;d(a,h,e,b,c)}}a.prototype=new D;b.util.extend(a.prototype,{setStart:function(a,b){o(this);x(a,!0);w(a,b);i(this,a,b)},setEnd:function(a,b){o(this);x(a,!0);w(a,b);n(this,a,b)},setStartBefore:g(!0,!0),setStartAfter:g(!1,!0),setEndBefore:g(!0,!1),setEndAfter:g(!1,!1),collapse:function(a){v(this);a?d(this,this.startContainer,this.startOffset,this.startContainer, | ||||
| this.startOffset):d(this,this.endContainer,this.endOffset,this.endContainer,this.endOffset)},selectNodeContents:function(a){o(this);x(a,!0);d(this,a,0,a,l.getNodeLength(a))},selectNode:function(a){o(this);x(a,!1);z(a,L);var b=e(a),a=f(a);d(this,b.node,b.offset,a.node,a.offset)},extractContents:E(j,d),deleteContents:E(k,d),canSurroundContents:function(){v(this);A(this.startContainer);A(this.endContainer);var a=new q(this,!0),b=a._first&&c(a._first,this)||a._last&&c(a._last,this);a.detach();return!b}, | ||||
| detach:function(){h(this)},splitBoundaries:function(){v(this);var a=this.startContainer,b=this.startOffset,c=this.endContainer,h=this.endOffset,e=a===c;l.isCharacterDataNode(c)&&(0<h&&h<c.length)&&l.splitDataNode(c,h);l.isCharacterDataNode(a)&&(0<b&&b<a.length)&&(a=l.splitDataNode(a,b),e?(h-=b,c=a):c==a.parentNode&&h>=l.getNodeIndex(a)&&h++,b=0);d(this,a,b,c,h)},normalizeBoundaries:function(){v(this);var a=this.startContainer,b=this.startOffset,c=this.endContainer,h=this.endOffset,e=function(a){var b= | ||||
| a.nextSibling;b&&b.nodeType==a.nodeType&&(c=a,h=a.length,a.appendData(b.data),b.parentNode.removeChild(b))},j=function(d){var e=d.previousSibling;if(e&&e.nodeType==d.nodeType){a=d;var j=d.length;b=e.length;d.insertData(0,e.data);e.parentNode.removeChild(e);a==c?(h+=b,c=a):c==d.parentNode&&(e=l.getNodeIndex(d),h==e?(c=d,h=j):h>e&&h--)}},k=!0;l.isCharacterDataNode(c)?c.length==h&&e(c):(0<h&&(k=c.childNodes[h-1])&&l.isCharacterDataNode(k)&&e(k),k=!this.collapsed);k?l.isCharacterDataNode(a)?0==b&&j(a): | ||||
| b<a.childNodes.length&&(e=a.childNodes[b])&&l.isCharacterDataNode(e)&&j(e):(a=c,b=h);d(this,a,b,c,h)},collapseToPoint:function(a,b){o(this);x(a,!0);w(a,b);(a!==this.startContainer||b!==this.startOffset||a!==this.endContainer||b!==this.endOffset)&&d(this,a,b,a,b)}});F(a)}function N(a){a.collapsed=a.startContainer===a.endContainer&&a.startOffset===a.endOffset;a.commonAncestorContainer=a.collapsed?a.startContainer:l.getCommonAncestor(a.startContainer,a.endContainer)}function J(a,b,c,h,e){var j=a.startContainer!== | ||||
| b||a.startOffset!==c,k=a.endContainer!==h||a.endOffset!==e;a.startContainer=b;a.startOffset=c;a.endContainer=h;a.endOffset=e;N(a);d(a,"boundarychange",{startMoved:j,endMoved:k})}function C(a){this.startContainer=a;this.startOffset=0;this.endContainer=a;this.endOffset=0;this._listeners={boundarychange:[],detach:[]};N(this)}b.requireModules(["DomUtil"]);var l=b.dom,u=l.DomPosition,B=b.DOMException;q.prototype={_current:null,_next:null,_first:null,_last:null,isSingleCharacterDataNode:!1,reset:function(){this._current= | ||||
| null;this._next=this._first},hasNext:function(){return!!this._next},next:function(){var a=this._current=this._next;a&&(this._next=a!==this._last?a.nextSibling:null,l.isCharacterDataNode(a)&&this.clonePartiallySelectedTextNodes&&(a===this.ec&&(a=a.cloneNode(!0)).deleteData(this.eo,a.length-this.eo),this._current===this.sc&&(a=a.cloneNode(!0)).deleteData(0,this.so)));return a},remove:function(){var a=this._current,b,c;l.isCharacterDataNode(a)&&(a===this.sc||a===this.ec)?(b=a===this.sc?this.so:0,c=a=== | ||||
| this.ec?this.eo:a.length,b!=c&&a.deleteData(b,c-b)):a.parentNode&&a.parentNode.removeChild(a)},isPartiallySelectedSubtree:function(){return c(this._current,this.range)},getSubtreeIterator:function(){var b;if(this.isSingleCharacterDataNode)b=this.range.cloneRange(),b.collapse();else{b=new C(a(this.range));var c=this._current,d=c,h=0,e=c,j=l.getNodeLength(c);l.isAncestorOf(c,this.sc,!0)&&(d=this.sc,h=this.so);l.isAncestorOf(c,this.ec,!0)&&(e=this.ec,j=this.eo);J(b,d,h,e,j)}return new q(b,this.clonePartiallySelectedTextNodes)}, | ||||
| detach:function(a){a&&this.range.detach();this.range=this._current=this._next=this._first=this._last=this.sc=this.so=this.ec=this.eo=null}};r.prototype={BAD_BOUNDARYPOINTS_ERR:1,INVALID_NODE_TYPE_ERR:2};r.prototype.toString=function(){return this.message};m.prototype={_current:null,hasNext:function(){return!!this._next},next:function(){this._current=this._next;this._next=this.nodes[++this._position];return this._current},detach:function(){this._current=this._next=this.nodes=null}};var L=[1,3,4,5, | ||||
| 7,8,10],G=[2,9,11],P=[1,3,4,5,7,8,10,11],H=[1,3,4,5,7,8],M=l.getRootContainer,O=s([9,11]),aa=s([5,6,10,12]),$=s([6,10,12]),Z=document.createElement("style"),S=!1;try{Z.innerHTML="<b>x</b>",S=3==Z.firstChild.nodeType}catch(ca){}b.features.htmlParsingConforms=S;var T="startContainer startOffset endContainer endOffset collapsed commonAncestorContainer".split(" "),Q=0,U=1,ba=2,V=3,W=0,X=1,Y=2,R=3;D.prototype={attachListener:function(a,b){this._listeners[a].push(b)},compareBoundaryPoints:function(a,b){v(this); | ||||
| y(this.startContainer,b.startContainer);var c=a==V||a==Q?"start":"end",d=a==U||a==Q?"start":"end";return l.comparePoints(this[c+"Container"],this[c+"Offset"],b[d+"Container"],b[d+"Offset"])},insertNode:function(a){v(this);z(a,P);A(this.startContainer);if(l.isAncestorOf(a,this.startContainer,!0))throw new B("HIERARCHY_REQUEST_ERR");this.setStartBefore(g(a,this.startContainer,this.startOffset))},cloneContents:function(){v(this);var b,c;if(this.collapsed)return a(this).createDocumentFragment();if(this.startContainer=== | ||||
| this.endContainer&&l.isCharacterDataNode(this.startContainer))return b=this.startContainer.cloneNode(!0),b.data=b.data.slice(this.startOffset,this.endOffset),c=a(this).createDocumentFragment(),c.appendChild(b),c;c=new q(this,!0);b=i(c);c.detach();return b},canSurroundContents:function(){v(this);A(this.startContainer);A(this.endContainer);var a=new q(this,!0),b=a._first&&c(a._first,this)||a._last&&c(a._last,this);a.detach();return!b},surroundContents:function(a){z(a,H);if(!this.canSurroundContents())throw new r("BAD_BOUNDARYPOINTS_ERR"); | ||||
| var b=this.extractContents();if(a.hasChildNodes())for(;a.lastChild;)a.removeChild(a.lastChild);g(a,this.startContainer,this.startOffset);a.appendChild(b);this.selectNode(a)},cloneRange:function(){v(this);for(var b=new C(a(this)),c=T.length,d;c--;)d=T[c],b[d]=this[d];return b},toString:function(){v(this);var a=this.startContainer;if(a===this.endContainer&&l.isCharacterDataNode(a))return 3==a.nodeType||4==a.nodeType?a.data.slice(this.startOffset,this.endOffset):"";var b=[],a=new q(this,!0);h(a,function(a){(3== | ||||
| a.nodeType||4==a.nodeType)&&b.push(a.data)});a.detach();return b.join("")},compareNode:function(a){v(this);var b=a.parentNode,c=l.getNodeIndex(a);if(!b)throw new B("NOT_FOUND_ERR");a=this.comparePoint(b,c);b=this.comparePoint(b,c+1);return 0>a?0<b?Y:W:0<b?X:R},comparePoint:function(a,b){v(this);t(a,"HIERARCHY_REQUEST_ERR");y(a,this.startContainer);return 0>l.comparePoints(a,b,this.startContainer,this.startOffset)?-1:0<l.comparePoints(a,b,this.endContainer,this.endOffset)?1:0},createContextualFragment:S? | ||||
| function(a){var b=this.startContainer,c=l.getDocument(b);if(!b)throw new B("INVALID_STATE_ERR");var d=null;1==b.nodeType?d=b:l.isCharacterDataNode(b)&&(d=l.parentElement(b));d=null===d||"HTML"==d.nodeName&&l.isHtmlNamespace(l.getDocument(d).documentElement)&&l.isHtmlNamespace(d)?c.createElement("body"):d.cloneNode(!1);d.innerHTML=a;return l.fragmentFromNodeChildren(d)}:function(b){o(this);var c=a(this).createElement("body");c.innerHTML=b;return l.fragmentFromNodeChildren(c)},toHtml:function(){v(this); | ||||
| var b=a(this).createElement("div");b.appendChild(this.cloneContents());return b.innerHTML},intersectsNode:function(b,c){v(this);t(b,"NOT_FOUND_ERR");if(l.getDocument(b)!==a(this))return!1;var d=b.parentNode,h=l.getNodeIndex(b);t(d,"NOT_FOUND_ERR");var e=l.comparePoints(d,h,this.endContainer,this.endOffset),d=l.comparePoints(d,h+1,this.startContainer,this.startOffset);return c?0>=e&&0<=d:0>e&&0<d},isPointInRange:function(a,b){v(this);t(a,"HIERARCHY_REQUEST_ERR");y(a,this.startContainer);return 0<= | ||||
| l.comparePoints(a,b,this.startContainer,this.startOffset)&&0>=l.comparePoints(a,b,this.endContainer,this.endOffset)},intersectsRange:function(b,c){v(this);if(a(b)!=a(this))throw new B("WRONG_DOCUMENT_ERR");var d=l.comparePoints(this.startContainer,this.startOffset,b.endContainer,b.endOffset),h=l.comparePoints(this.endContainer,this.endOffset,b.startContainer,b.startOffset);return c?0>=d&&0<=h:0>d&&0<h},intersection:function(a){if(this.intersectsRange(a)){var b=l.comparePoints(this.startContainer, | ||||
| this.startOffset,a.startContainer,a.startOffset),c=l.comparePoints(this.endContainer,this.endOffset,a.endContainer,a.endOffset),d=this.cloneRange();-1==b&&d.setStart(a.startContainer,a.startOffset);1==c&&d.setEnd(a.endContainer,a.endOffset);return d}return null},union:function(a){if(this.intersectsRange(a,!0)){var b=this.cloneRange();-1==l.comparePoints(a.startContainer,a.startOffset,this.startContainer,this.startOffset)&&b.setStart(a.startContainer,a.startOffset);1==l.comparePoints(a.endContainer, | ||||
| a.endOffset,this.endContainer,this.endOffset)&&b.setEnd(a.endContainer,a.endOffset);return b}throw new r("Ranges do not intersect");},containsNode:function(a,b){return b?this.intersectsNode(a,!1):this.compareNode(a)==R},containsNodeContents:function(a){return 0<=this.comparePoint(a,0)&&0>=this.comparePoint(a,l.getNodeLength(a))},containsRange:function(a){return this.intersection(a).equals(a)},containsNodeText:function(a){var b=this.cloneRange();b.selectNode(a);var c=b.getNodes([3]);return 0<c.length? | ||||
| (b.setStart(c[0],0),a=c.pop(),b.setEnd(a,a.length),a=this.containsRange(b),b.detach(),a):this.containsNodeContents(a)},createNodeIterator:function(a,b){v(this);return new m(this,a,b)},getNodes:function(a,b){v(this);return n(this,a,b)},getDocument:function(){return a(this)},collapseBefore:function(a){o(this);this.setEndBefore(a);this.collapse(!1)},collapseAfter:function(a){o(this);this.setStartAfter(a);this.collapse(!0)},getName:function(){return"DomRange"},equals:function(a){return C.rangesEqual(this, | ||||
| a)},inspect:function(){return p(this)}};I(C,J,function(a){o(a);a.startContainer=a.startOffset=a.endContainer=a.endOffset=null;a.collapsed=a.commonAncestorContainer=null;d(a,"detach",null);a._listeners=null});b.rangePrototype=D.prototype;C.rangeProperties=T;C.RangeIterator=q;C.copyComparisonConstants=F;C.createPrototypeRange=I;C.inspect=p;C.getRangeDocument=a;C.rangesEqual=function(a,b){return a.startContainer===b.startContainer&&a.startOffset===b.startOffset&&a.endContainer===b.endContainer&&a.endOffset=== | ||||
| b.endOffset};b.DomRange=C;b.RangeException=r}); | ||||
| rangy.createModule("WrappedRange",function(b){function c(a,b,c,d){var g=a.duplicate();g.collapse(c);var i=g.parentElement();e.isAncestorOf(b,i,!0)||(i=b);if(!i.canHaveHTML)return new f(i.parentNode,e.getNodeIndex(i));var b=e.getDocument(i).createElement("span"),r,m=c?"StartToStart":"StartToEnd";do i.insertBefore(b,b.previousSibling),g.moveToElementText(b);while(0<(r=g.compareEndPoints(m,a))&&b.previousSibling);m=b.nextSibling;if(-1==r&&m&&e.isCharacterDataNode(m)){g.setEndPoint(c?"EndToStart":"EndToEnd", | ||||
| a);if(/[\r\n]/.test(m.data)){i=g.duplicate();c=i.text.replace(/\r\n/g,"\r").length;for(c=i.moveStart("character",c);-1==i.compareEndPoints("StartToEnd",i);)c++,i.moveStart("character",1)}else c=g.text.length;i=new f(m,c)}else m=(d||!c)&&b.previousSibling,i=(c=(d||c)&&b.nextSibling)&&e.isCharacterDataNode(c)?new f(c,0):m&&e.isCharacterDataNode(m)?new f(m,m.length):new f(i,e.getNodeIndex(b));b.parentNode.removeChild(b);return i}function a(a,b){var c,d,f=a.offset,g=e.getDocument(a.node),i=g.body.createTextRange(), | ||||
| m=e.isCharacterDataNode(a.node);m?(c=a.node,d=c.parentNode):(c=a.node.childNodes,c=f<c.length?c[f]:null,d=a.node);g=g.createElement("span");g.innerHTML="&#feff;";c?d.insertBefore(g,c):d.appendChild(g);i.moveToElementText(g);i.collapse(!b);d.removeChild(g);if(m)i[b?"moveStart":"moveEnd"]("character",f);return i}b.requireModules(["DomUtil","DomRange"]);var d,e=b.dom,f=e.DomPosition,g=b.DomRange;if(b.features.implementsDomRange&&(!b.features.implementsTextRange||!b.config.preferTextRange))(function(){function a(b){for(var c= | ||||
| j.length,d;c--;)d=j[c],b[d]=b.nativeRange[d]}var c,j=g.rangeProperties,f;d=function(b){if(!b)throw Error("Range must be specified");this.nativeRange=b;a(this)};g.createPrototypeRange(d,function(a,b,c,d,h){var e=a.endContainer!==d||a.endOffset!=h;if(a.startContainer!==b||a.startOffset!=c||e)a.setEnd(d,h),a.setStart(b,c)},function(a){a.nativeRange.detach();a.detached=!0;for(var b=j.length,c;b--;)c=j[b],a[c]=null});c=d.prototype;c.selectNode=function(b){this.nativeRange.selectNode(b);a(this)};c.deleteContents= | ||||
| function(){this.nativeRange.deleteContents();a(this)};c.extractContents=function(){var b=this.nativeRange.extractContents();a(this);return b};c.cloneContents=function(){return this.nativeRange.cloneContents()};c.surroundContents=function(b){this.nativeRange.surroundContents(b);a(this)};c.collapse=function(b){this.nativeRange.collapse(b);a(this)};c.cloneRange=function(){return new d(this.nativeRange.cloneRange())};c.refresh=function(){a(this)};c.toString=function(){return this.nativeRange.toString()}; | ||||
| var i=document.createTextNode("test");e.getBody(document).appendChild(i);var q=document.createRange();q.setStart(i,0);q.setEnd(i,0);try{q.setStart(i,1),c.setStart=function(b,c){this.nativeRange.setStart(b,c);a(this)},c.setEnd=function(b,c){this.nativeRange.setEnd(b,c);a(this)},f=function(b){return function(c){this.nativeRange[b](c);a(this)}}}catch(r){c.setStart=function(b,c){try{this.nativeRange.setStart(b,c)}catch(d){this.nativeRange.setEnd(b,c),this.nativeRange.setStart(b,c)}a(this)},c.setEnd=function(b, | ||||
| c){try{this.nativeRange.setEnd(b,c)}catch(d){this.nativeRange.setStart(b,c),this.nativeRange.setEnd(b,c)}a(this)},f=function(b,c){return function(d){try{this.nativeRange[b](d)}catch(e){this.nativeRange[c](d),this.nativeRange[b](d)}a(this)}}}c.setStartBefore=f("setStartBefore","setEndBefore");c.setStartAfter=f("setStartAfter","setEndAfter");c.setEndBefore=f("setEndBefore","setStartBefore");c.setEndAfter=f("setEndAfter","setStartAfter");q.selectNodeContents(i);c.selectNodeContents=q.startContainer== | ||||
| i&&q.endContainer==i&&0==q.startOffset&&q.endOffset==i.length?function(b){this.nativeRange.selectNodeContents(b);a(this)}:function(a){this.setStart(a,0);this.setEnd(a,g.getEndOffset(a))};q.selectNodeContents(i);q.setEnd(i,3);f=document.createRange();f.selectNodeContents(i);f.setEnd(i,4);f.setStart(i,2);c.compareBoundaryPoints=-1==q.compareBoundaryPoints(q.START_TO_END,f)&1==q.compareBoundaryPoints(q.END_TO_START,f)?function(a,b){b=b.nativeRange||b;a==b.START_TO_END?a=b.END_TO_START:a==b.END_TO_START&& | ||||
| (a=b.START_TO_END);return this.nativeRange.compareBoundaryPoints(a,b)}:function(a,b){return this.nativeRange.compareBoundaryPoints(a,b.nativeRange||b)};b.util.isHostMethod(q,"createContextualFragment")&&(c.createContextualFragment=function(a){return this.nativeRange.createContextualFragment(a)});e.getBody(document).removeChild(i);q.detach();f.detach()})(),b.createNativeRange=function(a){a=a||document;return a.createRange()};else if(b.features.implementsTextRange){d=function(a){this.textRange=a;this.refresh()}; | ||||
| d.prototype=new g(document);d.prototype.refresh=function(){var a,b,d=this.textRange;a=d.parentElement();var f=d.duplicate();f.collapse(!0);b=f.parentElement();f=d.duplicate();f.collapse(!1);d=f.parentElement();b=b==d?b:e.getCommonAncestor(b,d);b=b==a?b:e.getCommonAncestor(a,b);0==this.textRange.compareEndPoints("StartToEnd",this.textRange)?b=a=c(this.textRange,b,!0,!0):(a=c(this.textRange,b,!0,!1),b=c(this.textRange,b,!1,!1));this.setStart(a.node,a.offset);this.setEnd(b.node,b.offset)};g.copyComparisonConstants(d); | ||||
| var i=function(){return this}();"undefined"==typeof i.Range&&(i.Range=d);b.createNativeRange=function(a){a=a||document;return a.body.createTextRange()}}b.features.implementsTextRange&&(d.rangeToTextRange=function(b){if(b.collapsed)return a(new f(b.startContainer,b.startOffset),!0);var c=a(new f(b.startContainer,b.startOffset),!0),d=a(new f(b.endContainer,b.endOffset),!1),b=e.getDocument(b.startContainer).body.createTextRange();b.setEndPoint("StartToStart",c);b.setEndPoint("EndToEnd",d);return b}); | ||||
| d.prototype.getName=function(){return"WrappedRange"};b.WrappedRange=d;b.createRange=function(a){a=a||document;return new d(b.createNativeRange(a))};b.createRangyRange=function(a){a=a||document;return new g(a)};b.createIframeRange=function(a){return b.createRange(e.getIframeDocument(a))};b.createIframeRangyRange=function(a){return b.createRangyRange(e.getIframeDocument(a))};b.addCreateMissingNativeApiListener(function(a){a=a.document;if(typeof a.createRange=="undefined")a.createRange=function(){return b.createRange(this)}; | ||||
| a=a=null})}); | ||||
| rangy.createModule("WrappedSelection",function(b,c){function a(a){return(a||window).getSelection()}function d(a){return(a||window).document.selection}function e(a,b,c){var d=c?"end":"start",c=c?"start":"end";a.anchorNode=b[d+"Container"];a.anchorOffset=b[d+"Offset"];a.focusNode=b[c+"Container"];a.focusOffset=b[c+"Offset"]}function f(a){a.anchorNode=a.focusNode=null;a.anchorOffset=a.focusOffset=0;a.rangeCount=0;a.isCollapsed=!0;a._ranges.length=0}function g(a){var c;a instanceof x?(c=a._selectionNativeRange, | ||||
| c||(c=b.createNativeRange(m.getDocument(a.startContainer)),c.setEnd(a.endContainer,a.endOffset),c.setStart(a.startContainer,a.startOffset),a._selectionNativeRange=c,a.attachListener("detach",function(){this._selectionNativeRange=null}))):a instanceof o?c=a.nativeRange:b.features.implementsDomRange&&a instanceof m.getWindow(a.startContainer).Range&&(c=a);return c}function i(a){var b=a.getNodes(),c;a:if(!b.length||1!=b[0].nodeType)c=!1;else{c=1;for(var d=b.length;c<d;++c)if(!m.isAncestorOf(b[0],b[c])){c= | ||||
| !1;break a}c=!0}if(!c)throw Error("getSingleElementFromRange: range "+a.inspect()+" did not consist of a single element");return b[0]}function h(a,b){var c=new o(b);a._ranges=[c];e(a,c,!1);a.rangeCount=1;a.isCollapsed=c.collapsed}function k(a){a._ranges.length=0;if("None"==a.docSelection.type)f(a);else{var c=a.docSelection.createRange();if(c&&"undefined"!=typeof c.text)h(a,c);else{a.rangeCount=c.length;for(var d,j=m.getDocument(c.item(0)),k=0;k<a.rangeCount;++k)d=b.createRange(j),d.selectNode(c.item(k)), | ||||
| a._ranges.push(d);a.isCollapsed=1==a.rangeCount&&a._ranges[0].collapsed;e(a,a._ranges[a.rangeCount-1],!1)}}}function j(a,b){for(var c=a.docSelection.createRange(),d=i(b),e=m.getDocument(c.item(0)),e=m.getBody(e).createControlRange(),h=0,j=c.length;h<j;++h)e.add(c.item(h));try{e.add(d)}catch(f){throw Error("addRange(): Element within the specified Range could not be added to control selection (does it have layout?)");}e.select();k(a)}function n(a,b,c){this.nativeSelection=a;this.docSelection=b;this._ranges= | ||||
| [];this.win=c;this.refresh()}function p(a,b){for(var c=m.getDocument(b[0].startContainer),c=m.getBody(c).createControlRange(),d=0,e;d<rangeCount;++d){e=i(b[d]);try{c.add(e)}catch(h){throw Error("setRanges(): Element within the one of the specified Ranges could not be added to control selection (does it have layout?)");}}c.select();k(a)}function q(a,b){if(a.anchorNode&&m.getDocument(a.anchorNode)!==m.getDocument(b))throw new z("WRONG_DOCUMENT_ERR");}function r(a){var b=[],c=new w(a.anchorNode,a.anchorOffset), | ||||
| d=new w(a.focusNode,a.focusOffset),e="function"==typeof a.getName?a.getName():"Selection";if("undefined"!=typeof a.rangeCount)for(var h=0,j=a.rangeCount;h<j;++h)b[h]=x.inspect(a.getRangeAt(h));return"["+e+"(Ranges: "+b.join(", ")+")(anchor: "+c.inspect()+", focus: "+d.inspect()+"]"}b.requireModules(["DomUtil","DomRange","WrappedRange"]);b.config.checkSelectionRanges=!0;var m=b.dom,s=b.util,x=b.DomRange,o=b.WrappedRange,z=b.DOMException,w=m.DomPosition,y,A,t=b.util.isHostMethod(window,"getSelection"), | ||||
| v=b.util.isHostObject(document,"selection"),D=v&&(!t||b.config.preferTextRange);D?(y=d,b.isSelectionValid=function(a){var a=(a||window).document,b=a.selection;return"None"!=b.type||m.getDocument(b.createRange().parentElement())==a}):t?(y=a,b.isSelectionValid=function(){return!0}):c.fail("Neither document.selection or window.getSelection() detected.");b.getNativeSelection=y;var t=y(),K=b.createNativeRange(document),F=m.getBody(document),E=s.areHostObjects(t,s.areHostProperties(t,["anchorOffset","focusOffset"])); | ||||
| b.features.selectionHasAnchorAndFocus=E;var I=s.isHostMethod(t,"extend");b.features.selectionHasExtend=I;var N="number"==typeof t.rangeCount;b.features.selectionHasRangeCount=N;var J=!1,C=!0;s.areHostMethods(t,["addRange","getRangeAt","removeAllRanges"])&&("number"==typeof t.rangeCount&&b.features.implementsDomRange)&&function(){var a=document.createElement("iframe");F.appendChild(a);var b=m.getIframeDocument(a);b.open();b.write("<html><head></head><body>12</body></html>");b.close();var c=m.getIframeWindow(a).getSelection(), | ||||
| d=b.documentElement.lastChild.firstChild,b=b.createRange();b.setStart(d,1);b.collapse(true);c.addRange(b);C=c.rangeCount==1;c.removeAllRanges();var e=b.cloneRange();b.setStart(d,0);e.setEnd(d,2);c.addRange(b);c.addRange(e);J=c.rangeCount==2;b.detach();e.detach();F.removeChild(a)}();b.features.selectionSupportsMultipleRanges=J;b.features.collapsedNonEditableSelectionsSupported=C;var l=!1,u;F&&s.isHostMethod(F,"createControlRange")&&(u=F.createControlRange(),s.areHostProperties(u,["item","add"])&&(l= | ||||
| !0));b.features.implementsControlRange=l;A=E?function(a){return a.anchorNode===a.focusNode&&a.anchorOffset===a.focusOffset}:function(a){return a.rangeCount?a.getRangeAt(a.rangeCount-1).collapsed:false};var B;s.isHostMethod(t,"getRangeAt")?B=function(a,b){try{return a.getRangeAt(b)}catch(c){return null}}:E&&(B=function(a){var c=m.getDocument(a.anchorNode),c=b.createRange(c);c.setStart(a.anchorNode,a.anchorOffset);c.setEnd(a.focusNode,a.focusOffset);if(c.collapsed!==this.isCollapsed){c.setStart(a.focusNode, | ||||
| a.focusOffset);c.setEnd(a.anchorNode,a.anchorOffset)}return c});b.getSelection=function(a){var a=a||window,b=a._rangySelection,c=y(a),e=v?d(a):null;if(b){b.nativeSelection=c;b.docSelection=e;b.refresh(a)}else{b=new n(c,e,a);a._rangySelection=b}return b};b.getIframeSelection=function(a){return b.getSelection(m.getIframeWindow(a))};u=n.prototype;if(!D&&E&&s.areHostMethods(t,["removeAllRanges","addRange"])){u.removeAllRanges=function(){this.nativeSelection.removeAllRanges();f(this)};var L=function(a, | ||||
| c){var d=x.getRangeDocument(c),d=b.createRange(d);d.collapseToPoint(c.endContainer,c.endOffset);a.nativeSelection.addRange(g(d));a.nativeSelection.extend(c.startContainer,c.startOffset);a.refresh()};u.addRange=N?function(a,c){if(l&&v&&this.docSelection.type=="Control")j(this,a);else if(c&&I)L(this,a);else{var d;if(J)d=this.rangeCount;else{this.removeAllRanges();d=0}this.nativeSelection.addRange(g(a));this.rangeCount=this.nativeSelection.rangeCount;if(this.rangeCount==d+1){if(b.config.checkSelectionRanges)(d= | ||||
| B(this.nativeSelection,this.rangeCount-1))&&!x.rangesEqual(d,a)&&(a=new o(d));this._ranges[this.rangeCount-1]=a;e(this,a,H(this.nativeSelection));this.isCollapsed=A(this)}else this.refresh()}}:function(a,b){if(b&&I)L(this,a);else{this.nativeSelection.addRange(g(a));this.refresh()}};u.setRanges=function(a){if(l&&a.length>1)p(this,a);else{this.removeAllRanges();for(var b=0,c=a.length;b<c;++b)this.addRange(a[b])}}}else if(s.isHostMethod(t,"empty")&&s.isHostMethod(K,"select")&&l&&D)u.removeAllRanges= | ||||
| function(){try{this.docSelection.empty();if(this.docSelection.type!="None"){var a;if(this.anchorNode)a=m.getDocument(this.anchorNode);else if(this.docSelection.type=="Control"){var b=this.docSelection.createRange();b.length&&(a=m.getDocument(b.item(0)).body.createTextRange())}if(a){a.body.createTextRange().select();this.docSelection.empty()}}}catch(c){}f(this)},u.addRange=function(a){if(this.docSelection.type=="Control")j(this,a);else{o.rangeToTextRange(a).select();this._ranges[0]=a;this.rangeCount= | ||||
| 1;this.isCollapsed=this._ranges[0].collapsed;e(this,a,false)}},u.setRanges=function(a){this.removeAllRanges();var b=a.length;b>1?p(this,a):b&&this.addRange(a[0])};else return c.fail("No means of selecting a Range or TextRange was found"),!1;u.getRangeAt=function(a){if(a<0||a>=this.rangeCount)throw new z("INDEX_SIZE_ERR");return this._ranges[a]};var G;if(D)G=function(a){var c;if(b.isSelectionValid(a.win))c=a.docSelection.createRange();else{c=m.getBody(a.win.document).createTextRange();c.collapse(true)}a.docSelection.type== | ||||
| "Control"?k(a):c&&typeof c.text!="undefined"?h(a,c):f(a)};else if(s.isHostMethod(t,"getRangeAt")&&"number"==typeof t.rangeCount)G=function(a){if(l&&v&&a.docSelection.type=="Control")k(a);else{a._ranges.length=a.rangeCount=a.nativeSelection.rangeCount;if(a.rangeCount){for(var c=0,d=a.rangeCount;c<d;++c)a._ranges[c]=new b.WrappedRange(a.nativeSelection.getRangeAt(c));e(a,a._ranges[a.rangeCount-1],H(a.nativeSelection));a.isCollapsed=A(a)}else f(a)}};else if(E&&"boolean"==typeof t.isCollapsed&&"boolean"== | ||||
| typeof K.collapsed&&b.features.implementsDomRange)G=function(a){var b;b=a.nativeSelection;if(b.anchorNode){b=B(b,0);a._ranges=[b];a.rangeCount=1;b=a.nativeSelection;a.anchorNode=b.anchorNode;a.anchorOffset=b.anchorOffset;a.focusNode=b.focusNode;a.focusOffset=b.focusOffset;a.isCollapsed=A(a)}else f(a)};else return c.fail("No means of obtaining a Range or TextRange from the user's selection was found"),!1;u.refresh=function(a){var b=a?this._ranges.slice(0):null;G(this);if(a){a=b.length;if(a!=this._ranges.length)return false; | ||||
| for(;a--;)if(!x.rangesEqual(b[a],this._ranges[a]))return false;return true}};var P=function(a,b){var c=a.getAllRanges(),d=false;a.removeAllRanges();for(var e=0,h=c.length;e<h;++e)d||b!==c[e]?a.addRange(c[e]):d=true;a.rangeCount||f(a)};u.removeRange=l?function(a){if(this.docSelection.type=="Control"){for(var b=this.docSelection.createRange(),a=i(a),c=m.getDocument(b.item(0)),c=m.getBody(c).createControlRange(),d,e=false,h=0,j=b.length;h<j;++h){d=b.item(h);d!==a||e?c.add(b.item(h)):e=true}c.select(); | ||||
| k(this)}else P(this,a)}:function(a){P(this,a)};var H;!D&&E&&b.features.implementsDomRange?(H=function(a){var b=false;a.anchorNode&&(b=m.comparePoints(a.anchorNode,a.anchorOffset,a.focusNode,a.focusOffset)==1);return b},u.isBackwards=function(){return H(this)}):H=u.isBackwards=function(){return false};u.toString=function(){for(var a=[],b=0,c=this.rangeCount;b<c;++b)a[b]=""+this._ranges[b];return a.join("")};u.collapse=function(a,c){q(this,a);var d=b.createRange(m.getDocument(a));d.collapseToPoint(a, | ||||
| c);this.removeAllRanges();this.addRange(d);this.isCollapsed=true};u.collapseToStart=function(){if(this.rangeCount){var a=this._ranges[0];this.collapse(a.startContainer,a.startOffset)}else throw new z("INVALID_STATE_ERR");};u.collapseToEnd=function(){if(this.rangeCount){var a=this._ranges[this.rangeCount-1];this.collapse(a.endContainer,a.endOffset)}else throw new z("INVALID_STATE_ERR");};u.selectAllChildren=function(a){q(this,a);var c=b.createRange(m.getDocument(a));c.selectNodeContents(a);this.removeAllRanges(); | ||||
| this.addRange(c)};u.deleteFromDocument=function(){if(l&&v&&this.docSelection.type=="Control"){for(var a=this.docSelection.createRange(),b;a.length;){b=a.item(0);a.remove(b);b.parentNode.removeChild(b)}this.refresh()}else if(this.rangeCount){a=this.getAllRanges();this.removeAllRanges();b=0;for(var c=a.length;b<c;++b)a[b].deleteContents();this.addRange(a[c-1])}};u.getAllRanges=function(){return this._ranges.slice(0)};u.setSingleRange=function(a){this.setRanges([a])};u.containsNode=function(a,b){for(var c= | ||||
| 0,d=this._ranges.length;c<d;++c)if(this._ranges[c].containsNode(a,b))return true;return false};u.toHtml=function(){var a="";if(this.rangeCount){for(var a=x.getRangeDocument(this._ranges[0]).createElement("div"),b=0,c=this._ranges.length;b<c;++b)a.appendChild(this._ranges[b].cloneContents());a=a.innerHTML}return a};u.getName=function(){return"WrappedSelection"};u.inspect=function(){return r(this)};u.detach=function(){this.win=this.anchorNode=this.focusNode=this.win._rangySelection=null};n.inspect= | ||||
| r;b.Selection=n;b.selectionPrototype=u;b.addCreateMissingNativeApiListener(function(a){if(typeof a.getSelection=="undefined")a.getSelection=function(){return b.getSelection(this)};a=null})});var Base=function(){}; | ||||
| Base.extend=function(b,c){var a=Base.prototype.extend;Base._prototyping=!0;var d=new this;a.call(d,b);d.base=function(){};delete Base._prototyping;var e=d.constructor,f=d.constructor=function(){if(!Base._prototyping)if(this._constructing||this.constructor==f)this._constructing=!0,e.apply(this,arguments),delete this._constructing;else if(null!=arguments[0])return(arguments[0].extend||a).call(arguments[0],d)};f.ancestor=this;f.extend=this.extend;f.forEach=this.forEach;f.implement=this.implement;f.prototype= | ||||
| d;f.toString=this.toString;f.valueOf=function(a){return"object"==a?f:e.valueOf()};a.call(f,c);"function"==typeof f.init&&f.init();return f}; | ||||
| Base.prototype={extend:function(b,c){if(1<arguments.length){var a=this[b];if(a&&"function"==typeof c&&(!a.valueOf||a.valueOf()!=c.valueOf())&&/\bbase\b/.test(c)){var d=c.valueOf(),c=function(){var b=this.base||Base.prototype.base;this.base=a;var c=d.apply(this,arguments);this.base=b;return c};c.valueOf=function(a){return"object"==a?c:d};c.toString=Base.toString}this[b]=c}else if(b){var e=Base.prototype.extend;!Base._prototyping&&"function"!=typeof this&&(e=this.extend||e);for(var f={toSource:null}, | ||||
| g=["constructor","toString","valueOf"],i=Base._prototyping?0:1;h=g[i++];)b[h]!=f[h]&&e.call(this,h,b[h]);for(var h in b)f[h]||e.call(this,h,b[h])}return this}}; | ||||
| Base=Base.extend({constructor:function(b){this.extend(b)}},{ancestor:Object,version:"1.1",forEach:function(b,c,a){for(var d in b)void 0===this.prototype[d]&&c.call(a,b[d],d,b)},implement:function(){for(var b=0;b<arguments.length;b++)if("function"==typeof arguments[b])arguments[b](this.prototype);else this.prototype.extend(arguments[b]);return this},toString:function(){return""+this.valueOf()}}); | ||||
| wysihtml5.browser=function(){var b=navigator.userAgent,c=document.createElement("div"),a=-1!==b.indexOf("MSIE")&&-1===b.indexOf("Opera"),d=-1!==b.indexOf("Gecko")&&-1===b.indexOf("KHTML"),e=-1!==b.indexOf("AppleWebKit/"),f=-1!==b.indexOf("Chrome/"),g=-1!==b.indexOf("Opera/");return{USER_AGENT:b,supported:function(){var a=this.USER_AGENT.toLowerCase(),b="contentEditable"in c,d=document.execCommand&&document.queryCommandSupported&&document.queryCommandState,e=document.querySelector&&document.querySelectorAll, | ||||
| a=this.isIos()&&5>(/ipad|iphone|ipod/.test(a)&&a.match(/ os (\d+).+? like mac os x/)||[,0])[1]||-1!==a.indexOf("opera mobi")||-1!==a.indexOf("hpwos/");return b&&d&&e&&!a},isTouchDevice:function(){return this.supportsEvent("touchmove")},isIos:function(){var a=this.USER_AGENT.toLowerCase();return-1!==a.indexOf("webkit")&&-1!==a.indexOf("mobile")},supportsSandboxedIframes:function(){return a},throwsMixedContentWarningWhenIframeSrcIsEmpty:function(){return!("querySelector"in document)},displaysCaretInEmptyContentEditableCorrectly:function(){return!d}, | ||||
| hasCurrentStyleProperty:function(){return"currentStyle"in c},insertsLineBreaksOnReturn:function(){return d},supportsPlaceholderAttributeOn:function(a){return"placeholder"in a},supportsEvent:function(a){var b;if(!(b="on"+a in c))c.setAttribute("on"+a,"return;"),b="function"===typeof c["on"+a];return b},supportsEventsInIframeCorrectly:function(){return!g},firesOnDropOnlyWhenOnDragOverIsCancelled:function(){return e||d},supportsDataTransfer:function(){try{return e&&(window.Clipboard||window.DataTransfer).prototype.getData}catch(a){return!1}}, | ||||
| supportsHTML5Tags:function(a){a=a.createElement("div");a.innerHTML="<article>foo</article>";return"<article>foo</article>"===a.innerHTML.toLowerCase()},supportsCommand:function(){var b={formatBlock:a,insertUnorderedList:a||g||e,insertOrderedList:a||g||e},c={insertHTML:d};return function(a,d){if(!b[d]){try{return a.queryCommandSupported(d)}catch(e){}try{return a.queryCommandEnabled(d)}catch(f){return!!c[d]}}return!1}}(),doesAutoLinkingInContentEditable:function(){return a},canDisableAutoLinking:function(){return this.supportsCommand(document, | ||||
| "AutoUrlDetect")},clearsContentEditableCorrectly:function(){return d||g||e},supportsGetAttributeCorrectly:function(){return"1"!=document.createElement("td").getAttribute("rowspan")},canSelectImagesInContentEditable:function(){return d||a||g},clearsListsInContentEditableCorrectly:function(){return d||a||e},autoScrollsToCaret:function(){return!e},autoClosesUnclosedTags:function(){var a=c.cloneNode(!1),b;a.innerHTML="<p><div></div>";a=a.innerHTML.toLowerCase();b="<p></p><div></div>"===a||"<p><div></div></p>"=== | ||||
| a;this.autoClosesUnclosedTags=function(){return b};return b},supportsNativeGetElementsByClassName:function(){return-1!==(""+document.getElementsByClassName).indexOf("[native code]")},supportsSelectionModify:function(){return"getSelection"in window&&"modify"in window.getSelection()},supportsClassList:function(){return"classList"in c},needsSpaceAfterLineBreak:function(){return g},supportsSpeechApiOn:function(a){return 11<=(b.match(/Chrome\/(\d+)/)||[,0])[1]&&("onwebkitspeechchange"in a||"speech"in a)}, | ||||
| crashesWhenDefineProperty:function(b){return a&&("XMLHttpRequest"===b||"XDomainRequest"===b)},doesAsyncFocus:function(){return a},hasProblemsSettingCaretAfterImg:function(){return a},hasUndoInContextMenu:function(){return d||f||g}}}(); | ||||
| wysihtml5.lang.array=function(b){return{contains:function(c){if(b.indexOf)return-1!==b.indexOf(c);for(var a=0,d=b.length;a<d;a++)if(b[a]===c)return!0;return!1},without:function(c){for(var c=wysihtml5.lang.array(c),a=[],d=0,e=b.length;d<e;d++)c.contains(b[d])||a.push(b[d]);return a},get:function(){for(var c=0,a=b.length,d=[];c<a;c++)d.push(b[c]);return d}}}; | ||||
| wysihtml5.lang.Dispatcher=Base.extend({observe:function(b,c){this.events=this.events||{};this.events[b]=this.events[b]||[];this.events[b].push(c);return this},on:function(){return this.observe.apply(this,wysihtml5.lang.array(arguments).get())},fire:function(b,c){this.events=this.events||{};for(var a=this.events[b]||[],d=0;d<a.length;d++)a[d].call(this,c);return this},stopObserving:function(b,c){this.events=this.events||{};var a=0,d,e;if(b){d=this.events[b]||[];for(e=[];a<d.length;a++)d[a]!==c&&c&& | ||||
| e.push(d[a]);this.events[b]=e}else this.events={};return this}});wysihtml5.lang.object=function(b){return{merge:function(c){for(var a in c)b[a]=c[a];return this},get:function(){return b},clone:function(){var c={},a;for(a in b)c[a]=b[a];return c},isArray:function(){return"[object Array]"===Object.prototype.toString.call(b)}}}; | ||||
| (function(){var b=/^\s+/,c=/\s+$/;wysihtml5.lang.string=function(a){a=""+a;return{trim:function(){return a.replace(b,"").replace(c,"")},interpolate:function(b){for(var c in b)a=this.replace("#{"+c+"}").by(b[c]);return a},replace:function(b){return{by:function(c){return a.split(b).join(c)}}}}}})(); | ||||
| (function(b){function c(a){return a.replace(e,function(a,b){var c=(b.match(f)||[])[1]||"",d=i[c],b=b.replace(f,"");b.split(d).length>b.split(c).length&&(b+=c,c="");var e=d=b;b.length>g&&(e=e.substr(0,g)+"...");"www."===d.substr(0,4)&&(d="http://"+d);return'<a href="'+d+'">'+e+"</a>"+c})}function a(h){if(!d.contains(h.nodeName))if(h.nodeType===b.TEXT_NODE&&h.data.match(e)){var f=h.parentNode,j;j=f.ownerDocument;var g=j._wysihtml5_tempElement;g||(g=j._wysihtml5_tempElement=j.createElement("div"));j= | ||||
| g;j.innerHTML="<span></span>"+c(h.data);for(j.removeChild(j.firstChild);j.firstChild;)f.insertBefore(j.firstChild,h);f.removeChild(h)}else{f=b.lang.array(h.childNodes).get();j=f.length;for(g=0;g<j;g++)a(f[g]);return h}}var d=b.lang.array("CODE PRE A SCRIPT HEAD TITLE STYLE".split(" ")),e=/((https?:\/\/|www\.)[^\s<]{3,})/gi,f=/([^\w\/\-](,?))$/i,g=100,i={")":"(","]":"[","}":"{"};b.dom.autoLink=function(b){var c;a:{c=b;for(var e;c.parentNode;){c=c.parentNode;e=c.nodeName;if(d.contains(e)){c=!0;break a}if("body"=== | ||||
| e)break}c=!1}if(c)return b;b===b.ownerDocument.documentElement&&(b=b.ownerDocument.body);return a(b)};b.dom.autoLink.URL_REG_EXP=e})(wysihtml5); | ||||
| (function(b){var c=b.browser.supportsClassList(),a=b.dom;a.addClass=function(b,e){if(c)return b.classList.add(e);a.hasClass(b,e)||(b.className+=" "+e)};a.removeClass=function(a,b){if(c)return a.classList.remove(b);a.className=a.className.replace(RegExp("(^|\\s+)"+b+"(\\s+|$)")," ")};a.hasClass=function(a,b){if(c)return a.classList.contains(b);var f=a.className;return 0<f.length&&(f==b||RegExp("(^|\\s)"+b+"(\\s|$)").test(f))}})(wysihtml5); | ||||
| wysihtml5.dom.contains=function(){var b=document.documentElement;if(b.contains)return function(b,a){a.nodeType!==wysihtml5.ELEMENT_NODE&&(a=a.parentNode);return b!==a&&b.contains(a)};if(b.compareDocumentPosition)return function(b,a){return!!(b.compareDocumentPosition(a)&16)}}(); | ||||
| wysihtml5.dom.convertToList=function(){function b(b,a){var d=b.createElement("li");a.appendChild(d);return d}return function(c,a){if("UL"===c.nodeName||"OL"===c.nodeName||"MENU"===c.nodeName)return c;var d=c.ownerDocument,e=d.createElement(a),f=c.querySelectorAll("br"),g=f.length,i,h,k,j,n;for(n=0;n<g;n++)for(i=f[n];(h=i.parentNode)&&h!==c&&h.lastChild===i;){if("block"===wysihtml5.dom.getStyle("display").from(h)){h.removeChild(i);break}wysihtml5.dom.insert(i).after(i.parentNode)}f=wysihtml5.lang.array(c.childNodes).get(); | ||||
| g=f.length;for(n=0;n<g;n++)j=j||b(d,e),i=f[n],h="block"===wysihtml5.dom.getStyle("display").from(i),k="BR"===i.nodeName,h?(j=j.firstChild?b(d,e):j,j.appendChild(i),j=null):k?j=j.firstChild?null:j:j.appendChild(i);c.parentNode.replaceChild(e,c);return e}}();wysihtml5.dom.copyAttributes=function(b){return{from:function(c){return{to:function(a){for(var d,e=0,f=b.length;e<f;e++)d=b[e],"undefined"!==typeof c[d]&&""!==c[d]&&(a[d]=c[d]);return{andTo:arguments.callee}}}}}}; | ||||
| (function(b){var c=["-webkit-box-sizing","-moz-box-sizing","-ms-box-sizing","box-sizing"],a=function(a){var e;a:for(var f=0,g=c.length;f<g;f++)if("border-box"===b.getStyle(c[f]).from(a)){e=c[f];break a}return e?parseInt(b.getStyle("width").from(a),10)<a.offsetWidth:!1};b.copyStyles=function(d){return{from:function(e){a(e)&&(d=wysihtml5.lang.array(d).without(c));for(var f="",g=d.length,i=0,h;i<g;i++)h=d[i],f+=h+":"+b.getStyle(h).from(e)+";";return{to:function(a){b.setStyles(f).on(a);return{andTo:arguments.callee}}}}}}})(wysihtml5.dom); | ||||
| (function(b){b.dom.delegate=function(c,a,d,e){return b.dom.observe(c,d,function(d){for(var g=d.target,i=b.lang.array(c.querySelectorAll(a));g&&g!==c;){if(i.contains(g)){e.call(g,d);break}g=g.parentNode}})}})(wysihtml5); | ||||
| wysihtml5.dom.getAsDom=function(){var b="abbr article aside audio bdi canvas command datalist details figcaption figure footer header hgroup keygen mark meter nav output progress rp rt ruby svg section source summary time track video wbr".split(" ");return function(c,a){var a=a||document,d;if("object"===typeof c&&c.nodeType)d=a.createElement("div"),d.appendChild(c);else if(wysihtml5.browser.supportsHTML5Tags(a))d=a.createElement("div"),d.innerHTML=c;else{d=a;if(!d._wysihtml5_supportsHTML5Tags){for(var e= | ||||
| 0,f=b.length;e<f;e++)d.createElement(b[e]);d._wysihtml5_supportsHTML5Tags=!0}d=a;e=d.createElement("div");e.style.display="none";d.body.appendChild(e);try{e.innerHTML=c}catch(g){}d.body.removeChild(e);d=e}return d}}(); | ||||
| wysihtml5.dom.getParentElement=function(){function b(b,a){return!a||!a.length?!0:"string"===typeof a?b===a:wysihtml5.lang.array(a).contains(b)}return function(c,a,d){d=d||50;if(a.className||a.classRegExp){a:{for(var e=a.nodeName,f=a.className,a=a.classRegExp;d--&&c&&"BODY"!==c.nodeName;){var g;if(g=c.nodeType===wysihtml5.ELEMENT_NODE)if(g=b(c.nodeName,e)){g=f;var i=(c.className||"").match(a)||[];g=!g?!!i.length:i[i.length-1]===g}if(g)break a;c=c.parentNode}c=null}return c}a:{e=a.nodeName;for(f=d;f--&& | ||||
| c&&"BODY"!==c.nodeName;){if(b(c.nodeName,e))break a;c=c.parentNode}c=null}return c}}(); | ||||
| wysihtml5.dom.getStyle=function(){function b(b){return b.replace(a,function(a){return a.charAt(1).toUpperCase()})}var c={"float":"styleFloat"in document.createElement("div").style?"styleFloat":"cssFloat"},a=/\-[a-z]/g;return function(a){return{from:function(e){if(e.nodeType===wysihtml5.ELEMENT_NODE){var f=e.ownerDocument,g=c[a]||b(a),i=e.style,h=e.currentStyle,k=i[g];if(k)return k;if(h)try{return h[g]}catch(j){}var g=f.defaultView||f.parentWindow,f=("height"===a||"width"===a)&&"TEXTAREA"===e.nodeName, | ||||
| n;if(g.getComputedStyle)return f&&(n=i.overflow,i.overflow="hidden"),e=g.getComputedStyle(e,null).getPropertyValue(a),f&&(i.overflow=n||""),e}}}}}();wysihtml5.dom.hasElementWithTagName=function(){var b={},c=1;return function(a,d){var e=(a._wysihtml5_identifier||(a._wysihtml5_identifier=c++))+":"+d,f=b[e];f||(f=b[e]=a.getElementsByTagName(d));return 0<f.length}}(); | ||||
| (function(b){var c={},a=1;b.dom.hasElementWithClassName=function(d,e){if(!b.browser.supportsNativeGetElementsByClassName())return!!d.querySelector("."+e);var f=(d._wysihtml5_identifier||(d._wysihtml5_identifier=a++))+":"+e,g=c[f];g||(g=c[f]=d.getElementsByClassName(e));return 0<g.length}})(wysihtml5);wysihtml5.dom.insert=function(b){return{after:function(c){c.parentNode.insertBefore(b,c.nextSibling)},before:function(c){c.parentNode.insertBefore(b,c)},into:function(c){c.appendChild(b)}}}; | ||||
| wysihtml5.dom.insertCSS=function(b){b=b.join("\n");return{into:function(c){var a=c.head||c.getElementsByTagName("head")[0],d=c.createElement("style");d.type="text/css";d.styleSheet?d.styleSheet.cssText=b:d.appendChild(c.createTextNode(b));a&&a.appendChild(d)}}}; | ||||
| wysihtml5.dom.observe=function(b,c,a){for(var c="string"===typeof c?[c]:c,d,e,f=0,g=c.length;f<g;f++)e=c[f],b.addEventListener?b.addEventListener(e,a,!1):(d=function(c){"target"in c||(c.target=c.srcElement);c.preventDefault=c.preventDefault||function(){this.returnValue=false};c.stopPropagation=c.stopPropagation||function(){this.cancelBubble=true};a.call(b,c)},b.attachEvent("on"+e,d));return{stop:function(){for(var e,h=0,f=c.length;h<f;h++)e=c[h],b.removeEventListener?b.removeEventListener(e,a,!1): | ||||
| b.detachEvent("on"+e,d)}}}; | ||||
| wysihtml5.dom.parse=function(){function b(c,e){var h=c.childNodes,f=h.length,g;g=a[c.nodeType];var k=0;g=g&&g(c);if(!g)return null;for(k=0;k<f;k++)(newChild=b(h[k],e))&&g.appendChild(newChild);return e&&1>=g.childNodes.length&&g.nodeName.toLowerCase()===d&&!g.attributes.length?g.firstChild:g}function c(a,b){var b=b.toLowerCase(),c;if(c="IMG"==a.nodeName)if(c="src"==b){var d;try{d=a.complete&&!a.mozMatchesSelector(":-moz-broken")}catch(e){a.complete&&"complete"===a.readyState&&(d=!0)}c=!0===d}return c? | ||||
| a.src:i&&"outerHTML"in a?-1!=a.outerHTML.toLowerCase().indexOf(" "+b+"=")?a.getAttribute(b):null:a.getAttribute(b)}var a={1:function(a){var b,f,i=g.tags;f=a.nodeName.toLowerCase();b=a.scopeName;if(a._wysihtml5)return null;a._wysihtml5=1;if("wysihtml5-temp"===a.className)return null;b&&"HTML"!=b&&(f=b+":"+f);"outerHTML"in a&&!wysihtml5.browser.autoClosesUnclosedTags()&&("P"===a.nodeName&&"</p>"!==a.outerHTML.slice(-4).toLowerCase())&&(f="div");if(f in i){b=i[f];if(!b||b.remove)return null;b="string"=== | ||||
| typeof b?{rename_tag:b}:b}else if(a.firstChild)b={rename_tag:d};else return null;f=a.ownerDocument.createElement(b.rename_tag||f);var i={},r=b.set_class,m=b.add_class,s=b.set_attributes,x=b.check_attributes,o=g.classes,z=0,w=[];b=[];var y=[],A=[],t;s&&(i=wysihtml5.lang.object(s).clone());if(x)for(t in x)if(s=h[x[t]])s=s(c(a,t)),"string"===typeof s&&(i[t]=s);r&&w.push(r);if(m)for(t in m)if(s=k[m[t]])r=s(c(a,t)),"string"===typeof r&&w.push(r);o["_wysihtml5-temp-placeholder"]=1;(A=a.getAttribute("class"))&& | ||||
| (w=w.concat(A.split(e)));for(m=w.length;z<m;z++)a=w[z],o[a]&&b.push(a);for(o=b.length;o--;)a=b[o],wysihtml5.lang.array(y).contains(a)||y.unshift(a);y.length&&(i["class"]=y.join(" "));for(t in i)try{f.setAttribute(t,i[t])}catch(v){}i.src&&("undefined"!==typeof i.width&&f.setAttribute("width",i.width),"undefined"!==typeof i.height&&f.setAttribute("height",i.height));return f},3:function(a){return a.ownerDocument.createTextNode(a.data)}},d="span",e=/\s+/,f={tags:{},classes:{}},g={},i=!wysihtml5.browser.supportsGetAttributeCorrectly(), | ||||
| h={url:function(){var a=/^https?:\/\//i;return function(b){return!b||!b.match(a)?null:b.replace(a,function(a){return a.toLowerCase()})}}(),alt:function(){var a=/[^ a-z0-9_\-]/gi;return function(b){return!b?"":b.replace(a,"")}}(),numbers:function(){var a=/\D/g;return function(b){return(b=(b||"").replace(a,""))||null}}()},k={align_img:function(){var a={left:"wysiwyg-float-left",right:"wysiwyg-float-right"};return function(b){return a[(""+b).toLowerCase()]}}(),align_text:function(){var a={left:"wysiwyg-text-align-left", | ||||
| right:"wysiwyg-text-align-right",center:"wysiwyg-text-align-center",justify:"wysiwyg-text-align-justify"};return function(b){return a[(""+b).toLowerCase()]}}(),clear_br:function(){var a={left:"wysiwyg-clear-left",right:"wysiwyg-clear-right",both:"wysiwyg-clear-both",all:"wysiwyg-clear-both"};return function(b){return a[(""+b).toLowerCase()]}}(),size_font:function(){var a={1:"wysiwyg-font-size-xx-small",2:"wysiwyg-font-size-small",3:"wysiwyg-font-size-medium",4:"wysiwyg-font-size-large",5:"wysiwyg-font-size-x-large", | ||||
| 6:"wysiwyg-font-size-xx-large",7:"wysiwyg-font-size-xx-large","-":"wysiwyg-font-size-smaller","+":"wysiwyg-font-size-larger"};return function(b){return a[(""+b).charAt(0)]}}()};return function(a,c,d,e){wysihtml5.lang.object(g).merge(f).merge(c).get();for(var d=d||a.ownerDocument||document,c=d.createDocumentFragment(),h="string"===typeof a,a=h?wysihtml5.dom.getAsDom(a,d):a;a.firstChild;)d=a.firstChild,a.removeChild(d),(d=b(d,e))&&c.appendChild(d);a.innerHTML="";a.appendChild(c);return h?wysihtml5.quirks.getCorrectInnerHTML(a): | ||||
| a}}();wysihtml5.dom.removeEmptyTextNodes=function(b){for(var c=wysihtml5.lang.array(b.childNodes).get(),a=c.length,d=0;d<a;d++)b=c[d],b.nodeType===wysihtml5.TEXT_NODE&&""===b.data&&b.parentNode.removeChild(b)};wysihtml5.dom.renameElement=function(b,c){for(var a=b.ownerDocument.createElement(c),d;d=b.firstChild;)a.appendChild(d);wysihtml5.dom.copyAttributes(["align","className"]).from(b).to(a);b.parentNode.replaceChild(a,b);return a}; | ||||
| wysihtml5.dom.replaceWithChildNodes=function(b){if(b.parentNode)if(b.firstChild){for(var c=b.ownerDocument.createDocumentFragment();b.firstChild;)c.appendChild(b.firstChild);b.parentNode.replaceChild(c,b)}else b.parentNode.removeChild(b)}; | ||||
| (function(b){function c(a){var b=a.ownerDocument.createElement("br");a.appendChild(b)}b.resolveList=function(a){if(!("MENU"!==a.nodeName&&"UL"!==a.nodeName&&"OL"!==a.nodeName)){var d=a.ownerDocument.createDocumentFragment(),e=a.previousElementSibling||a.previousSibling,f,g,i;for(e&&"block"!==b.getStyle("display").from(e)&&c(d);i=a.firstChild;){for(f=i.lastChild;e=i.firstChild;)g=(g=e===f)&&"block"!==b.getStyle("display").from(e)&&"BR"!==e.nodeName,d.appendChild(e),g&&c(d);i.parentNode.removeChild(i)}a.parentNode.replaceChild(d, | ||||
| a)}}})(wysihtml5.dom); | ||||
| (function(b){var c=document,a="parent top opener frameElement frames localStorage globalStorage sessionStorage indexedDB".split(" "),d="open close openDialog showModalDialog alert confirm prompt openDatabase postMessage XMLHttpRequest XDomainRequest".split(" "),e=["referrer","write","open","close"];b.dom.Sandbox=Base.extend({constructor:function(a,c){this.callback=a||b.EMPTY_FUNCTION;this.config=b.lang.object({}).merge(c).get();this.iframe=this._createIframe()},insertInto:function(a){"string"===typeof a&& | ||||
| (a=c.getElementById(a));a.appendChild(this.iframe)},getIframe:function(){return this.iframe},getWindow:function(){this._readyError()},getDocument:function(){this._readyError()},destroy:function(){var a=this.getIframe();a.parentNode.removeChild(a)},_readyError:function(){throw Error("wysihtml5.Sandbox: Sandbox iframe isn't loaded yet");},_createIframe:function(){var a=this,d=c.createElement("iframe");d.className="wysihtml5-sandbox";b.dom.setAttributes({security:"restricted",allowtransparency:"true", | ||||
| frameborder:0,width:0,height:0,marginwidth:0,marginheight:0}).on(d);b.browser.throwsMixedContentWarningWhenIframeSrcIsEmpty()&&(d.src="javascript:'<html></html>'");d.onload=function(){d.onreadystatechange=d.onload=null;a._onLoadIframe(d)};d.onreadystatechange=function(){if(/loaded|complete/.test(d.readyState)){d.onreadystatechange=d.onload=null;a._onLoadIframe(d)}};return d},_onLoadIframe:function(f){if(b.dom.contains(c.documentElement,f)){var g=this,i=f.contentWindow,h=f.contentWindow.document,k= | ||||
| this._getHtml({charset:c.characterSet||c.charset||"utf-8",stylesheets:this.config.stylesheets});h.open("text/html","replace");h.write(k);h.close();this.getWindow=function(){return f.contentWindow};this.getDocument=function(){return f.contentWindow.document};i.onerror=function(a,b,c){throw Error("wysihtml5.Sandbox: "+a,b,c);};if(!b.browser.supportsSandboxedIframes()){var j,k=0;for(j=a.length;k<j;k++)this._unset(i,a[k]);k=0;for(j=d.length;k<j;k++)this._unset(i,d[k],b.EMPTY_FUNCTION);k=0;for(j=e.length;k< | ||||
| j;k++)this._unset(h,e[k]);this._unset(h,"cookie","",!0)}this.loaded=!0;setTimeout(function(){g.callback(g)},0)}},_getHtml:function(a){var c=a.stylesheets,d="",e=0,k;if(c="string"===typeof c?[c]:c)for(k=c.length;e<k;e++)d+='<link rel="stylesheet" href="'+c[e]+'">';a.stylesheets=d;return b.lang.string('<!DOCTYPE html><html><head><meta charset="#{charset}">#{stylesheets}</head><body></body></html>').interpolate(a)},_unset:function(a,c,d,e){try{a[c]=d}catch(k){}try{a.__defineGetter__(c,function(){return d})}catch(j){}if(e)try{a.__defineSetter__(c, | ||||
| function(){})}catch(n){}if(!b.browser.crashesWhenDefineProperty(c))try{var p={get:function(){return d}};e&&(p.set=function(){});Object.defineProperty(a,c,p)}catch(q){}}})})(wysihtml5);(function(){var b={className:"class"};wysihtml5.dom.setAttributes=function(c){return{on:function(a){for(var d in c)a.setAttribute(b[d]||d,c[d])}}}})(); | ||||
| wysihtml5.dom.setStyles=function(b){return{on:function(c){c=c.style;if("string"===typeof b)c.cssText+=";"+b;else for(var a in b)"float"===a?(c.cssFloat=b[a],c.styleFloat=b[a]):c[a]=b[a]}}}; | ||||
| (function(b){b.simulatePlaceholder=function(c,a,d){var e=function(){a.hasPlaceholderSet()&&a.clear();b.removeClass(a.element,"placeholder")},f=function(){a.isEmpty()&&(a.setValue(d),b.addClass(a.element,"placeholder"))};c.observe("set_placeholder",f).observe("unset_placeholder",e).observe("focus:composer",e).observe("paste:composer",e).observe("blur:composer",f);f()}})(wysihtml5.dom); | ||||
| (function(b){var c=document.documentElement;"textContent"in c?(b.setTextContent=function(a,b){a.textContent=b},b.getTextContent=function(a){return a.textContent}):"innerText"in c?(b.setTextContent=function(a,b){a.innerText=b},b.getTextContent=function(a){return a.innerText}):(b.setTextContent=function(a,b){a.nodeValue=b},b.getTextContent=function(a){return a.nodeValue})})(wysihtml5.dom); | ||||
| wysihtml5.quirks.cleanPastedHTML=function(){var b={"a u":wysihtml5.dom.replaceWithChildNodes};return function(c,a,d){var a=a||b,d=d||c.ownerDocument||document,e="string"===typeof c,f,g,i,h=0,c=e?wysihtml5.dom.getAsDom(c,d):c;for(i in a){f=c.querySelectorAll(i);d=a[i];for(g=f.length;h<g;h++)d(f[h])}return e?c.innerHTML:c}}(); | ||||
| (function(b){var c=b.dom;b.quirks.ensureProperClearing=function(){var a=function(){var a=this;setTimeout(function(){var b=a.innerHTML.toLowerCase();if("<p> </p>"==b||"<p> </p><p> </p>"==b)a.innerHTML=""},0)};return function(b){c.observe(b.element,["cut","keydown"],a)}}();b.quirks.ensureProperClearingOfLists=function(){var a=["OL","UL","MENU"];return function(d){c.observe(d.element,"keydown",function(e){if(e.keyCode===b.BACKSPACE_KEY){var f=d.selection.getSelectedNode(),e=d.element; | ||||
| e.firstChild&&b.lang.array(a).contains(e.firstChild.nodeName)&&(f=c.getParentElement(f,{nodeName:a}))&&f==e.firstChild&&1>=f.childNodes.length&&(f.firstChild?""===f.firstChild.innerHTML:1)&&f.parentNode.removeChild(f)}})}}()})(wysihtml5); | ||||
| (function(b){b.quirks.getCorrectInnerHTML=function(c){var a=c.innerHTML;if(-1===a.indexOf("%7E"))return a;var c=c.querySelectorAll("[href*='~'], [src*='~']"),d,e,f,g;g=0;for(f=c.length;g<f;g++)d=c[g].href||c[g].src,e=b.lang.string(d).replace("~").by("%7E"),a=b.lang.string(a).replace(e).by(d);return a}})(wysihtml5); | ||||
| (function(b){var c=b.dom,a="LI P H1 H2 H3 H4 H5 H6".split(" "),d=["UL","OL","MENU"];b.quirks.insertLineBreakOnReturn=function(e){function f(a){if(a=c.getParentElement(a,{nodeName:["P","DIV"]},2)){var d=document.createTextNode(b.INVISIBLE_SPACE);c.insert(d).before(a);c.replaceWithChildNodes(a);e.selection.selectNode(d)}}c.observe(e.element.ownerDocument,"keydown",function(g){var i=g.keyCode;if(!(g.shiftKey||i!==b.ENTER_KEY&&i!==b.BACKSPACE_KEY)){var h=e.selection.getSelectedNode();(h=c.getParentElement(h, | ||||
| {nodeName:a},4))?"LI"===h.nodeName&&(i===b.ENTER_KEY||i===b.BACKSPACE_KEY)?setTimeout(function(){var a=e.selection.getSelectedNode(),b;a&&((b=c.getParentElement(a,{nodeName:d},2))||f(a))},0):h.nodeName.match(/H[1-6]/)&&i===b.ENTER_KEY&&setTimeout(function(){f(e.selection.getSelectedNode())},0):i===b.ENTER_KEY&&!b.browser.insertsLineBreaksOnReturn()&&(e.commands.exec("insertLineBreak"),g.preventDefault())}})}})(wysihtml5); | ||||
| (function(b){b.quirks.redraw=function(c){b.dom.addClass(c,"wysihtml5-quirks-redraw");b.dom.removeClass(c,"wysihtml5-quirks-redraw");try{var a=c.ownerDocument;a.execCommand("italic",!1,null);a.execCommand("italic",!1,null)}catch(d){}}})(wysihtml5); | ||||
| (function(b){var c=b.dom;b.Selection=Base.extend({constructor:function(a){window.rangy.init();this.editor=a;this.composer=a.composer;this.doc=this.composer.doc},getBookmark:function(){var a=this.getRange();return a&&a.cloneRange()},setBookmark:function(a){a&&this.setSelection(a)},setBefore:function(a){var b=rangy.createRange(this.doc);b.setStartBefore(a);b.setEndBefore(a);return this.setSelection(b)},setAfter:function(a){var b=rangy.createRange(this.doc);b.setStartAfter(a);b.setEndAfter(a);return this.setSelection(b)}, | ||||
| selectNode:function(a){var d=rangy.createRange(this.doc),e=a.nodeType===b.ELEMENT_NODE,f="canHaveHTML"in a?a.canHaveHTML:"IMG"!==a.nodeName,g=e?a.innerHTML:a.data,g=""===g||g===b.INVISIBLE_SPACE,i=c.getStyle("display").from(a),i="block"===i||"list-item"===i;if(g&&e&&f)try{a.innerHTML=b.INVISIBLE_SPACE}catch(h){}f?d.selectNodeContents(a):d.selectNode(a);f&&g&&e?d.collapse(i):f&&g&&(d.setStartAfter(a),d.setEndAfter(a));this.setSelection(d)},getSelectedNode:function(a){if(a&&this.doc.selection&&"Control"=== | ||||
| this.doc.selection.type&&(a=this.doc.selection.createRange())&&a.length)return a.item(0);a=this.getSelection(this.doc);return a.focusNode===a.anchorNode?a.focusNode:(a=this.getRange(this.doc))?a.commonAncestorContainer:this.doc.body},executeAndRestore:function(a,c){var e=this.doc.body,f=c&&e.scrollTop,g=c&&e.scrollLeft,i='<span class="_wysihtml5-temp-placeholder">'+b.INVISIBLE_SPACE+"</span>",h=this.getRange(this.doc);if(h){i=h.createContextualFragment(i);h.insertNode(i);try{a(h.startContainer,h.endContainer)}catch(k){setTimeout(function(){throw k; | ||||
| },0)}(caretPlaceholder=this.doc.querySelector("._wysihtml5-temp-placeholder"))?(h=rangy.createRange(this.doc),h.selectNode(caretPlaceholder),h.deleteContents(),this.setSelection(h)):e.focus();c&&(e.scrollTop=f,e.scrollLeft=g);try{caretPlaceholder.parentNode.removeChild(caretPlaceholder)}catch(j){}}else a(e,e)},executeAndRestoreSimple:function(a){var b,c,f=this.getRange(),g=this.doc.body,i;if(f){b=f.getNodes([3]);g=b[0]||f.startContainer;i=b[b.length-1]||f.endContainer;b=g===f.startContainer?f.startOffset: | ||||
| 0;c=i===f.endContainer?f.endOffset:i.length;try{a(f.startContainer,f.endContainer)}catch(h){setTimeout(function(){throw h;},0)}a=rangy.createRange(this.doc);try{a.setStart(g,b)}catch(k){}try{a.setEnd(i,c)}catch(j){}try{this.setSelection(a)}catch(n){}}else a(g,g)},insertHTML:function(a){var a=rangy.createRange(this.doc).createContextualFragment(a),b=a.lastChild;this.insertNode(a);b&&this.setAfter(b)},insertNode:function(a){var b=this.getRange();b&&b.insertNode(a)},surround:function(a){var b=this.getRange(); | ||||
| if(b)try{b.surroundContents(a),this.selectNode(a)}catch(c){a.appendChild(b.extractContents()),b.insertNode(a)}},scrollIntoView:function(){var a=this.doc,c=a.documentElement.scrollHeight>a.documentElement.offsetHeight,e;if(!(e=a._wysihtml5ScrollIntoViewElement))e=a.createElement("span"),e.innerHTML=b.INVISIBLE_SPACE;e=a._wysihtml5ScrollIntoViewElement=e;if(c){this.insertNode(e);var c=e,f=0;if(c.parentNode){do f+=c.offsetTop||0,c=c.offsetParent;while(c)}c=f;e.parentNode.removeChild(e);c>a.body.scrollTop&& | ||||
| (a.body.scrollTop=c)}},selectLine:function(){b.browser.supportsSelectionModify()?this._selectLine_W3C():this.doc.selection&&this._selectLine_MSIE()},_selectLine_W3C:function(){var a=this.doc.defaultView.getSelection();a.modify("extend","left","lineboundary");a.modify("extend","right","lineboundary")},_selectLine_MSIE:function(){var a=this.doc.selection.createRange(),b=a.boundingTop,c=this.doc.body.scrollWidth,f;if(a.moveToPoint){0===b&&(f=this.doc.createElement("span"),this.insertNode(f),b=f.offsetTop, | ||||
| f.parentNode.removeChild(f));b+=1;for(f=-10;f<c;f+=2)try{a.moveToPoint(f,b);break}catch(g){}for(f=this.doc.selection.createRange();0<=c;c--)try{f.moveToPoint(c,b);break}catch(i){}a.setEndPoint("EndToEnd",f);a.select()}},getText:function(){var a=this.getSelection();return a?a.toString():""},getNodes:function(a,b){var c=this.getRange();return c?c.getNodes([a],b):[]},getRange:function(){var a=this.getSelection();return a&&a.rangeCount&&a.getRangeAt(0)},getSelection:function(){return rangy.getSelection(this.doc.defaultView|| | ||||
| this.doc.parentWindow)},setSelection:function(a){return rangy.getSelection(this.doc.defaultView||this.doc.parentWindow).setSingleRange(a)}})})(wysihtml5); | ||||
| (function(b,c){function a(a,b){return c.dom.isCharacterDataNode(a)?0==b?!!a.previousSibling:b==a.length?!!a.nextSibling:!0:0<b&&b<a.childNodes.length}function d(a,b,e){var f;c.dom.isCharacterDataNode(b)&&(0==e?(e=c.dom.getNodeIndex(b),b=b.parentNode):e==b.length?(e=c.dom.getNodeIndex(b)+1,b=b.parentNode):f=c.dom.splitDataNode(b,e));if(!f){f=b.cloneNode(!1);f.id&&f.removeAttribute("id");for(var g;g=b.childNodes[e];)f.appendChild(g);c.dom.insertAfter(f,b)}return b==a?f:d(a,f.parentNode,c.dom.getNodeIndex(f))} | ||||
| function e(a){this.firstTextNode=(this.isElementMerge=a.nodeType==b.ELEMENT_NODE)?a.lastChild:a;this.textNodes=[this.firstTextNode]}function f(a,b,c,d){this.tagNames=a||[g];this.cssClass=b||"";this.similarClassRegExp=c;this.normalize=d;this.applyToAnyTagName=!1}var g="span",i=/\s+/g;e.prototype={doMerge:function(){for(var a=[],b,c,d=0,e=this.textNodes.length;d<e;++d)b=this.textNodes[d],c=b.parentNode,a[d]=b.data,d&&(c.removeChild(b),c.hasChildNodes()||c.parentNode.removeChild(c));return this.firstTextNode.data= | ||||
| a=a.join("")},getLength:function(){for(var a=this.textNodes.length,b=0;a--;)b+=this.textNodes[a].length;return b},toString:function(){for(var a=[],b=0,c=this.textNodes.length;b<c;++b)a[b]="'"+this.textNodes[b].data+"'";return"[Merge("+a.join(",")+")]"}};f.prototype={getAncestorWithClass:function(a){for(var d;a;){if(this.cssClass)if(d=this.cssClass,a.className){var e=a.className.match(this.similarClassRegExp)||[];d=e[e.length-1]===d}else d=!1;else d=!0;if(a.nodeType==b.ELEMENT_NODE&&c.dom.arrayContains(this.tagNames, | ||||
| a.tagName.toLowerCase())&&d)return a;a=a.parentNode}return!1},postApply:function(a,b){for(var c=a[0],d=a[a.length-1],f=[],g,i=c,m=d,s=0,x=d.length,o,z,w=0,y=a.length;w<y;++w)if(o=a[w],z=this.getAdjacentMergeableTextNode(o.parentNode,!1)){if(g||(g=new e(z),f.push(g)),g.textNodes.push(o),o===c&&(i=g.firstTextNode,s=i.length),o===d)m=g.firstTextNode,x=g.getLength()}else g=null;if(c=this.getAdjacentMergeableTextNode(d.parentNode,!0))g||(g=new e(d),f.push(g)),g.textNodes.push(c);if(f.length){w=0;for(y= | ||||
| f.length;w<y;++w)f[w].doMerge();b.setStart(i,s);b.setEnd(m,x)}},getAdjacentMergeableTextNode:function(a,c){var d=a.nodeType==b.TEXT_NODE,e=d?a.parentNode:a,f=c?"nextSibling":"previousSibling";if(d){if((d=a[f])&&d.nodeType==b.TEXT_NODE)return d}else if((d=e[f])&&this.areElementsMergeable(a,d))return d[c?"firstChild":"lastChild"];return null},areElementsMergeable:function(a,b){var d;if(d=c.dom.arrayContains(this.tagNames,(a.tagName||"").toLowerCase()))if(d=c.dom.arrayContains(this.tagNames,(b.tagName|| | ||||
| "").toLowerCase()))if(d=a.className.replace(i," ")==b.className.replace(i," "))a:if(a.attributes.length!=b.attributes.length)d=!1;else{d=0;for(var e=a.attributes.length,f,g;d<e;++d)if(f=a.attributes[d],g=f.name,"class"!=g&&(g=b.attributes.getNamedItem(g),f.specified!=g.specified||f.specified&&f.nodeValue!==g.nodeValue)){d=!1;break a}d=!0}return d},createContainer:function(a){a=a.createElement(this.tagNames[0]);this.cssClass&&(a.className=this.cssClass);return a},applyToTextNode:function(a){var b= | ||||
| a.parentNode;1==b.childNodes.length&&c.dom.arrayContains(this.tagNames,b.tagName.toLowerCase())?this.cssClass&&(a=this.cssClass,b.className?(b.className&&(b.className=b.className.replace(this.similarClassRegExp,"")),b.className+=" "+a):b.className=a):(b=this.createContainer(c.dom.getDocument(a)),a.parentNode.insertBefore(b,a),b.appendChild(a))},isRemovable:function(a){return c.dom.arrayContains(this.tagNames,a.tagName.toLowerCase())&&b.lang.string(a.className).trim()==this.cssClass},undoToTextNode:function(b, | ||||
| c,e){c.containsNode(e)||(b=c.cloneRange(),b.selectNode(e),b.isPointInRange(c.endContainer,c.endOffset)&&a(c.endContainer,c.endOffset)&&(d(e,c.endContainer,c.endOffset),c.setEndAfter(e)),b.isPointInRange(c.startContainer,c.startOffset)&&a(c.startContainer,c.startOffset)&&(e=d(e,c.startContainer,c.startOffset)));this.similarClassRegExp&&e.className&&(e.className=e.className.replace(this.similarClassRegExp,""));if(this.isRemovable(e)){c=e;for(e=c.parentNode;c.firstChild;)e.insertBefore(c.firstChild, | ||||
| c);e.removeChild(c)}},applyToRange:function(a){var c=a.getNodes([b.TEXT_NODE]);if(!c.length)try{var d=this.createContainer(a.endContainer.ownerDocument);a.surroundContents(d);this.selectNode(a,d);return}catch(e){}a.splitBoundaries();c=a.getNodes([b.TEXT_NODE]);if(c.length){for(var f=0,g=c.length;f<g;++f)d=c[f],this.getAncestorWithClass(d)||this.applyToTextNode(d);a.setStart(c[0],0);d=c[c.length-1];a.setEnd(d,d.length);this.normalize&&this.postApply(c,a)}},undoToRange:function(a){var c=a.getNodes([b.TEXT_NODE]), | ||||
| d,e;c.length?(a.splitBoundaries(),c=a.getNodes([b.TEXT_NODE])):(c=a.endContainer.ownerDocument.createTextNode(b.INVISIBLE_SPACE),a.insertNode(c),a.selectNode(c),c=[c]);for(var f=0,g=c.length;f<g;++f)d=c[f],(e=this.getAncestorWithClass(d))&&this.undoToTextNode(d,a,e);1==g?this.selectNode(a,c[0]):(a.setStart(c[0],0),d=c[c.length-1],a.setEnd(d,d.length),this.normalize&&this.postApply(c,a))},selectNode:function(a,c){var d=c.nodeType===b.ELEMENT_NODE,e="canHaveHTML"in c?c.canHaveHTML:!0,f=d?c.innerHTML: | ||||
| c.data;if((f=""===f||f===b.INVISIBLE_SPACE)&&d&&e)try{c.innerHTML=b.INVISIBLE_SPACE}catch(g){}a.selectNodeContents(c);f&&d?a.collapse(!1):f&&(a.setStartAfter(c),a.setEndAfter(c))},getTextSelectedByRange:function(a,b){var c=b.cloneRange();c.selectNodeContents(a);var d=c.intersection(b),d=d?d.toString():"";c.detach();return d},isAppliedToRange:function(a){var c=[],d,e=a.getNodes([b.TEXT_NODE]);if(!e.length)return(d=this.getAncestorWithClass(a.startContainer))?[d]:!1;for(var f=0,g=e.length,i;f<g;++f){i= | ||||
| this.getTextSelectedByRange(e[f],a);d=this.getAncestorWithClass(e[f]);if(""!=i&&!d)return!1;c.push(d)}return c},toggleRange:function(a){this.isAppliedToRange(a)?this.undoToRange(a):this.applyToRange(a)}};b.selection.HTMLApplier=f})(wysihtml5,rangy); | ||||
| wysihtml5.Commands=Base.extend({constructor:function(b){this.editor=b;this.composer=b.composer;this.doc=this.composer.doc},support:function(b){return wysihtml5.browser.supportsCommand(this.doc,b)},exec:function(b,c){var a=wysihtml5.commands[b],d=wysihtml5.lang.array(arguments).get(),e=a&&a.exec,f=null;this.editor.fire("beforecommand:composer");if(e)d.unshift(this.composer),f=e.apply(a,d);else try{f=this.doc.execCommand(b,!1,c)}catch(g){}this.editor.fire("aftercommand:composer");return f},state:function(b, | ||||
| c){var a=wysihtml5.commands[b],d=wysihtml5.lang.array(arguments).get(),e=a&&a.state;if(e)return d.unshift(this.composer),e.apply(a,d);try{return this.doc.queryCommandState(b)}catch(f){return!1}},value:function(b){var c=wysihtml5.commands[b],a=c&&c.value;if(a)return a.call(c,this.composer,b);try{return this.doc.queryCommandValue(b)}catch(d){return null}}}); | ||||
| (function(b){b.commands.bold={exec:function(c,a){return b.commands.formatInline.exec(c,a,"b")},state:function(c,a){return b.commands.formatInline.state(c,a,"b")},value:function(){}}})(wysihtml5); | ||||
| (function(b){function c(c,g){var i=c.doc,h="_wysihtml5-temp-"+ +new Date,k=0,j,n,p;b.commands.formatInline.exec(c,a,d,h,/non-matching-class/g);j=i.querySelectorAll(d+"."+h);for(h=j.length;k<h;k++)for(p in n=j[k],n.removeAttribute("class"),g)n.setAttribute(p,g[p]);k=n;1===h&&(p=e.getTextContent(n),h=!!n.querySelector("*"),p=""===p||p===b.INVISIBLE_SPACE,!h&&p&&(e.setTextContent(n,g.text||n.href),i=i.createTextNode(" "),c.selection.setAfter(n),c.selection.insertNode(i),k=i));c.selection.setAfter(k)} | ||||
| var a,d="A",e=b.dom;b.commands.createLink={exec:function(a,b,d){var h=this.state(a,b);h?a.selection.executeAndRestore(function(){for(var a=h.length,b=0,c,d,f;b<a;b++)c=h[b],d=e.getParentElement(c,{nodeName:"code"}),f=e.getTextContent(c),f.match(e.autoLink.URL_REG_EXP)&&!d?e.renameElement(c,"code"):e.replaceWithChildNodes(c)}):(d="object"===typeof d?d:{href:d},c(a,d))},state:function(a,c){return b.commands.formatInline.state(a,c,"A")},value:function(){return a}}})(wysihtml5); | ||||
| (function(b){var c=/wysiwyg-font-size-[a-z\-]+/g;b.commands.fontSize={exec:function(a,d,e){return b.commands.formatInline.exec(a,d,"span","wysiwyg-font-size-"+e,c)},state:function(a,d,e){return b.commands.formatInline.state(a,d,"span","wysiwyg-font-size-"+e,c)},value:function(){}}})(wysihtml5); | ||||
| (function(b){var c=/wysiwyg-color-[a-z]+/g;b.commands.foreColor={exec:function(a,d,e){return b.commands.formatInline.exec(a,d,"span","wysiwyg-color-"+e,c)},state:function(a,d,e){return b.commands.formatInline.state(a,d,"span","wysiwyg-color-"+e,c)},value:function(){}}})(wysihtml5); | ||||
| (function(b){function c(a){for(a=a.previousSibling;a&&a.nodeType===b.TEXT_NODE&&!b.lang.string(a.data).trim();)a=a.previousSibling;return a}function a(a){for(a=a.nextSibling;a&&a.nodeType===b.TEXT_NODE&&!b.lang.string(a.data).trim();)a=a.nextSibling;return a}function d(a){return"BR"===a.nodeName||"block"===g.getStyle("display").from(a)?!0:!1}function e(a,c,d,e){if(e)var f=g.observe(a,"DOMNodeInserted",function(a){var a=a.target,c;a.nodeType===b.ELEMENT_NODE&&(c=g.getStyle("display").from(a),"inline"!== | ||||
| c.substr(0,6)&&(a.className+=" "+e))});a.execCommand(c,!1,d);f&&f.stop()}function f(b,d){b.selection.selectLine();b.selection.surround(d);var e=a(d),f=c(d);e&&"BR"===e.nodeName&&e.parentNode.removeChild(e);f&&"BR"===f.nodeName&&f.parentNode.removeChild(f);(e=d.lastChild)&&"BR"===e.nodeName&&e.parentNode.removeChild(e);b.selection.selectNode(d)}var g=b.dom,i="H1 H2 H3 H4 H5 H6 P BLOCKQUOTE DIV".split(" ");b.commands.formatBlock={exec:function(h,k,j,n,p){var q=h.doc,r=this.state(h,k,j,n,p),m,j="string"=== | ||||
| typeof j?j.toUpperCase():j;if(r)h.selection.executeAndRestoreSimple(function(){p&&(r.className=r.className.replace(p,""));var e=!!b.lang.string(r.className).trim();if(!e&&r.nodeName===(j||"DIV")){var e=r,f=e.ownerDocument,h=a(e),i=c(e);h&&!d(h)&&e.parentNode.insertBefore(f.createElement("br"),h);i&&!d(i)&&e.parentNode.insertBefore(f.createElement("br"),e);g.replaceWithChildNodes(r)}else e&&g.renameElement(r,"DIV")});else{if(null===j||b.lang.array(i).contains(j))if(m=h.selection.getSelectedNode(), | ||||
| r=g.getParentElement(m,{nodeName:i})){h.selection.executeAndRestoreSimple(function(){j&&(r=g.renameElement(r,j));if(n){var a=r;a.className?(a.className=a.className.replace(p,""),a.className+=" "+n):a.className=n}});return}h.commands.support(k)?e(q,k,j||"DIV",n):(r=q.createElement(j||"DIV"),n&&(r.className=n),f(h,r))}},state:function(a,b,c,d,e){c="string"===typeof c?c.toUpperCase():c;a=a.selection.getSelectedNode();return g.getParentElement(a,{nodeName:c,className:d,classRegExp:e})},value:function(){}}})(wysihtml5); | ||||
| (function(b){function c(c,f,g){var i=c+":"+f;if(!d[i]){var h=d,k=b.selection.HTMLApplier,j=a[c],c=j?[c.toLowerCase(),j.toLowerCase()]:[c.toLowerCase()];h[i]=new k(c,f,g,!0)}return d[i]}var a={strong:"b",em:"i",b:"strong",i:"em"},d={};b.commands.formatInline={exec:function(a,b,d,i,h){b=a.selection.getRange();if(!b)return!1;c(d,i,h).toggleRange(b);a.selection.setSelection(b)},state:function(d,f,g,i,h){var f=d.doc,k=a[g]||g;if(!b.dom.hasElementWithTagName(f,g)&&!b.dom.hasElementWithTagName(f,k)||i&& | ||||
| !b.dom.hasElementWithClassName(f,i))return!1;d=d.selection.getRange();return!d?!1:c(g,i,h).isAppliedToRange(d)},value:function(){}}})(wysihtml5);(function(b){b.commands.insertHTML={exec:function(b,a,d){b.commands.support(a)?b.doc.execCommand(a,!1,d):b.selection.insertHTML(d)},state:function(){return!1},value:function(){}}})(wysihtml5); | ||||
| (function(b){b.commands.insertImage={exec:function(c,a,d){var d="object"===typeof d?d:{src:d},e=c.doc,a=this.state(c),f;if(a)c.selection.setBefore(a),d=a.parentNode,d.removeChild(a),b.dom.removeEmptyTextNodes(d),"A"===d.nodeName&&!d.firstChild&&(c.selection.setAfter(d),d.parentNode.removeChild(d)),b.quirks.redraw(c.element);else{a=e.createElement("IMG");for(f in d)a[f]=d[f];c.selection.insertNode(a);b.browser.hasProblemsSettingCaretAfterImg()?(d=e.createTextNode(b.INVISIBLE_SPACE),c.selection.insertNode(d), | ||||
| c.selection.setAfter(d)):c.selection.setAfter(a)}},state:function(c){var a;if(!b.dom.hasElementWithTagName(c.doc,"IMG"))return!1;a=c.selection.getSelectedNode();if(!a)return!1;if("IMG"===a.nodeName)return a;if(a.nodeType!==b.ELEMENT_NODE)return!1;a=c.selection.getText();if(a=b.lang.string(a).trim())return!1;c=c.selection.getNodes(b.ELEMENT_NODE,function(a){return"IMG"===a.nodeName});return 1!==c.length?!1:c[0]},value:function(b){return(b=this.state(b))&&b.src}}})(wysihtml5); | ||||
| (function(b){var c="<br>"+(b.browser.needsSpaceAfterLineBreak()?" ":"");b.commands.insertLineBreak={exec:function(a,d){a.commands.support(d)?(a.doc.execCommand(d,!1,null),b.browser.autoScrollsToCaret()||a.selection.scrollIntoView()):a.commands.exec("insertHTML",c)},state:function(){return!1},value:function(){}}})(wysihtml5); | ||||
| (function(b){b.commands.insertOrderedList={exec:function(c,a){var d=c.doc,e=c.selection.getSelectedNode(),f=b.dom.getParentElement(e,{nodeName:"OL"}),g=b.dom.getParentElement(e,{nodeName:"UL"}),e="_wysihtml5-temp-"+(new Date).getTime(),i;c.commands.support(a)?d.execCommand(a,!1,null):f?c.selection.executeAndRestoreSimple(function(){b.dom.resolveList(f)}):g?c.selection.executeAndRestoreSimple(function(){b.dom.renameElement(g,"ol")}):(c.commands.exec("formatBlock","div",e),i=d.querySelector("."+e), | ||||
| d=""===i.innerHTML||i.innerHTML===b.INVISIBLE_SPACE,c.selection.executeAndRestoreSimple(function(){f=b.dom.convertToList(i,"ol")}),d&&c.selection.selectNode(f.querySelector("li")))},state:function(c){c=c.selection.getSelectedNode();return b.dom.getParentElement(c,{nodeName:"OL"})},value:function(){}}})(wysihtml5); | ||||
| (function(b){b.commands.insertUnorderedList={exec:function(c,a){var d=c.doc,e=c.selection.getSelectedNode(),f=b.dom.getParentElement(e,{nodeName:"UL"}),g=b.dom.getParentElement(e,{nodeName:"OL"}),e="_wysihtml5-temp-"+(new Date).getTime(),i;c.commands.support(a)?d.execCommand(a,!1,null):f?c.selection.executeAndRestoreSimple(function(){b.dom.resolveList(f)}):g?c.selection.executeAndRestoreSimple(function(){b.dom.renameElement(g,"ul")}):(c.commands.exec("formatBlock","div",e),i=d.querySelector("."+e), | ||||
| d=""===i.innerHTML||i.innerHTML===b.INVISIBLE_SPACE,c.selection.executeAndRestoreSimple(function(){f=b.dom.convertToList(i,"ul")}),d&&c.selection.selectNode(f.querySelector("li")))},state:function(c){c=c.selection.getSelectedNode();return b.dom.getParentElement(c,{nodeName:"UL"})},value:function(){}}})(wysihtml5);(function(b){b.commands.italic={exec:function(c,a){return b.commands.formatInline.exec(c,a,"i")},state:function(c,a){return b.commands.formatInline.state(c,a,"i")},value:function(){}}})(wysihtml5); | ||||
| (function(b){var c=/wysiwyg-text-align-[a-z]+/g;b.commands.justifyCenter={exec:function(a){return b.commands.formatBlock.exec(a,"formatBlock",null,"wysiwyg-text-align-center",c)},state:function(a){return b.commands.formatBlock.state(a,"formatBlock",null,"wysiwyg-text-align-center",c)},value:function(){}}})(wysihtml5); | ||||
| (function(b){var c=/wysiwyg-text-align-[a-z]+/g;b.commands.justifyLeft={exec:function(a){return b.commands.formatBlock.exec(a,"formatBlock",null,"wysiwyg-text-align-left",c)},state:function(a){return b.commands.formatBlock.state(a,"formatBlock",null,"wysiwyg-text-align-left",c)},value:function(){}}})(wysihtml5); | ||||
| (function(b){var c=/wysiwyg-text-align-[a-z]+/g;b.commands.justifyRight={exec:function(a){return b.commands.formatBlock.exec(a,"formatBlock",null,"wysiwyg-text-align-right",c)},state:function(a){return b.commands.formatBlock.state(a,"formatBlock",null,"wysiwyg-text-align-right",c)},value:function(){}}})(wysihtml5);(function(b){b.commands.underline={exec:function(c,a){return b.commands.formatInline.exec(c,a,"u")},state:function(c,a){return b.commands.formatInline.state(c,a,"u")},value:function(){}}})(wysihtml5); | ||||
| (function(b){var c='<span id="_wysihtml5-undo" class="_wysihtml5-temp">'+b.INVISIBLE_SPACE+"</span>",a='<span id="_wysihtml5-redo" class="_wysihtml5-temp">'+b.INVISIBLE_SPACE+"</span>",d=b.dom;b.UndoManager=b.lang.Dispatcher.extend({constructor:function(a){this.editor=a;this.composer=a.composer;this.element=this.composer.element;this.history=[this.composer.getValue()];this.position=1;this.composer.commands.support("insertHTML")&&this._observe()},_observe:function(){var e=this,f=this.composer.sandbox.getDocument(), | ||||
| g;d.observe(this.element,"keydown",function(a){if(!(a.altKey||!a.ctrlKey&&!a.metaKey)){var b=a.keyCode,c=90===b&&a.shiftKey||89===b;90===b&&!a.shiftKey?(e.undo(),a.preventDefault()):c&&(e.redo(),a.preventDefault())}});d.observe(this.element,"keydown",function(a){a=a.keyCode;a!==g&&(g=a,(8===a||46===a)&&e.transact())});if(b.browser.hasUndoInContextMenu()){var i,h,k=function(){for(var a;a=f.querySelector("._wysihtml5-temp");)a.parentNode.removeChild(a);clearInterval(i)};d.observe(this.element,"contextmenu", | ||||
| function(){k();e.composer.selection.executeAndRestoreSimple(function(){e.element.lastChild&&e.composer.selection.setAfter(e.element.lastChild);f.execCommand("insertHTML",!1,c);f.execCommand("insertHTML",!1,a);f.execCommand("undo",!1,null)});i=setInterval(function(){f.getElementById("_wysihtml5-redo")?(k(),e.redo()):f.getElementById("_wysihtml5-undo")||(k(),e.undo())},400);h||(h=!0,d.observe(document,"mousedown",k),d.observe(f,["mousedown","paste","cut","copy"],k))})}this.editor.observe("newword:composer", | ||||
| function(){e.transact()}).observe("beforecommand:composer",function(){e.transact()})},transact:function(){var a=this.history[this.position-1],b=this.composer.getValue();if(b!=a){if(40<(this.history.length=this.position))this.history.shift(),this.position--;this.position++;this.history.push(b)}},undo:function(){this.transact();1>=this.position||(this.set(this.history[--this.position-1]),this.editor.fire("undo:composer"))},redo:function(){this.position>=this.history.length||(this.set(this.history[++this.position- | ||||
| 1]),this.editor.fire("redo:composer"))},set:function(a){this.composer.setValue(a);this.editor.focus(!0)}})})(wysihtml5); | ||||
| wysihtml5.views.View=Base.extend({constructor:function(b,c,a){this.parent=b;this.element=c;this.config=a;this._observeViewChange()},_observeViewChange:function(){var b=this;this.parent.observe("beforeload",function(){b.parent.observe("change_view",function(c){c===b.name?(b.parent.currentView=b,b.show(),setTimeout(function(){b.focus()},0)):b.hide()})})},focus:function(){if(this.element.ownerDocument.querySelector(":focus")!==this.element)try{this.element.focus()}catch(b){}},hide:function(){this.element.style.display= | ||||
| "none"},show:function(){this.element.style.display=""},disable:function(){this.element.setAttribute("disabled","disabled")},enable:function(){this.element.removeAttribute("disabled")}}); | ||||
| (function(b){var c=b.dom,a=b.browser;b.views.Composer=b.views.View.extend({name:"composer",CARET_HACK:"<br>",constructor:function(a,b,c){this.base(a,b,c);this.textarea=this.parent.textarea;this._initSandbox()},clear:function(){this.element.innerHTML=a.displaysCaretInEmptyContentEditableCorrectly()?"":this.CARET_HACK},getValue:function(a){var c=this.isEmpty()?"":b.quirks.getCorrectInnerHTML(this.element);a&&(c=this.parent.parse(c));return c=b.lang.string(c).replace(b.INVISIBLE_SPACE).by("")},setValue:function(a, | ||||
| b){b&&(a=this.parent.parse(a));this.element.innerHTML=a},show:function(){this.iframe.style.display=this._displayStyle||"";this.disable();this.enable()},hide:function(){this._displayStyle=c.getStyle("display").from(this.iframe);"none"===this._displayStyle&&(this._displayStyle=null);this.iframe.style.display="none"},disable:function(){this.element.removeAttribute("contentEditable");this.base()},enable:function(){this.element.setAttribute("contentEditable","true");this.base()},focus:function(a){b.browser.doesAsyncFocus()&& | ||||
| this.hasPlaceholderSet()&&this.clear();this.base();var c=this.element.lastChild;a&&c&&("BR"===c.nodeName?this.selection.setBefore(this.element.lastChild):this.selection.setAfter(this.element.lastChild))},getTextContent:function(){return c.getTextContent(this.element)},hasPlaceholderSet:function(){return this.getTextContent()==this.textarea.element.getAttribute("placeholder")},isEmpty:function(){var a=this.element.innerHTML;return""===a||a===this.CARET_HACK||this.hasPlaceholderSet()||""===this.getTextContent()&& | ||||
| !this.element.querySelector("blockquote, ul, ol, img, embed, object, table, iframe, svg, video, audio, button, input, select, textarea")},_initSandbox:function(){var a=this;this.sandbox=new c.Sandbox(function(){a._create()},{stylesheets:this.config.stylesheets});this.iframe=this.sandbox.getIframe();var b=document.createElement("input");b.type="hidden";b.name="_wysihtml5_mode";b.value=1;var f=this.textarea.element;c.insert(this.iframe).after(f);c.insert(b).after(f)},_create:function(){var d=this;this.doc= | ||||
| this.sandbox.getDocument();this.element=this.doc.body;this.textarea=this.parent.textarea;this.element.innerHTML=this.textarea.getValue(!0);this.enable();this.selection=new b.Selection(this.parent);this.commands=new b.Commands(this.parent);c.copyAttributes("className spellcheck title lang dir accessKey".split(" ")).from(this.textarea.element).to(this.element);c.addClass(this.element,this.config.composerClassName);this.config.style&&this.style();this.observe();var e=this.config.name;e&&(c.addClass(this.element, | ||||
| e),c.addClass(this.iframe,e));(e="string"===typeof this.config.placeholder?this.config.placeholder:this.textarea.element.getAttribute("placeholder"))&&c.simulatePlaceholder(this.parent,this,e);this.commands.exec("styleWithCSS",!1);this._initAutoLinking();this._initObjectResizing();this._initUndoManager();(this.textarea.element.hasAttribute("autofocus")||document.querySelector(":focus")==this.textarea.element)&&setTimeout(function(){d.focus()},100);b.quirks.insertLineBreakOnReturn(this);a.clearsContentEditableCorrectly()|| | ||||
| b.quirks.ensureProperClearing(this);a.clearsListsInContentEditableCorrectly()||b.quirks.ensureProperClearingOfLists(this);this.initSync&&this.config.sync&&this.initSync();this.textarea.hide();this.parent.fire("beforeload").fire("load")},_initAutoLinking:function(){var d=this,e=a.canDisableAutoLinking(),f=a.doesAutoLinkingInContentEditable();e&&this.commands.exec("autoUrlDetect",!1);if(this.config.autoLink){(!f||f&&e)&&this.parent.observe("newword:composer",function(){d.selection.executeAndRestore(function(a, | ||||
| b){c.autoLink(b.parentNode)})});var g=this.sandbox.getDocument().getElementsByTagName("a"),i=c.autoLink.URL_REG_EXP,h=function(a){a=b.lang.string(c.getTextContent(a)).trim();"www."===a.substr(0,4)&&(a="http://"+a);return a};c.observe(this.element,"keydown",function(a){if(g.length){var a=d.selection.getSelectedNode(a.target.ownerDocument),b=c.getParentElement(a,{nodeName:"A"},4),e;b&&(e=h(b),setTimeout(function(){var a=h(b);a!==e&&a.match(i)&&b.setAttribute("href",a)},0))}})}},_initObjectResizing:function(){var d= | ||||
| ["width","height"],e=d.length,f=this.element;this.commands.exec("enableObjectResizing",this.config.allowObjectResizing);this.config.allowObjectResizing?a.supportsEvent("resizeend")&&c.observe(f,"resizeend",function(a){for(var a=a.target||a.srcElement,c=a.style,h=0,k;h<e;h++)k=d[h],c[k]&&(a.setAttribute(k,parseInt(c[k],10)),c[k]="");b.quirks.redraw(f)}):a.supportsEvent("resizestart")&&c.observe(f,"resizestart",function(a){a.preventDefault()})},_initUndoManager:function(){new b.UndoManager(this.parent)}})})(wysihtml5); | ||||
| (function(b){var c=b.dom,a=document,d=window,e=a.createElement("div"),f="background-color color cursor font-family font-size font-style font-variant font-weight line-height letter-spacing text-align text-decoration text-indent text-rendering word-break word-wrap word-spacing".split(" "),g="background-color border-collapse border-bottom-color border-bottom-style border-bottom-width border-left-color border-left-style border-left-width border-right-color border-right-style border-right-width border-top-color border-top-style border-top-width clear display float margin-bottom margin-left margin-right margin-top outline-color outline-offset outline-width outline-style padding-left padding-right padding-top padding-bottom position top left right bottom z-index vertical-align text-align -webkit-box-sizing -moz-box-sizing -ms-box-sizing box-sizing -webkit-box-shadow -moz-box-shadow -ms-box-shadow box-shadow -webkit-border-top-right-radius -moz-border-radius-topright border-top-right-radius -webkit-border-bottom-right-radius -moz-border-radius-bottomright border-bottom-right-radius -webkit-border-bottom-left-radius -moz-border-radius-bottomleft border-bottom-left-radius -webkit-border-top-left-radius -moz-border-radius-topleft border-top-left-radius width height".split(" "), | ||||
| i="width height top left right bottom".split(" "),h=["html             { height: 100%; }","body             { min-height: 100%; padding: 0; margin: 0; margin-top: -1px; padding-top: 1px; }","._wysihtml5-temp { display: none; }",b.browser.isGecko?"body.placeholder { color: graytext !important; }":"body.placeholder { color: #a9a9a9 !important; }","body[disabled]   { background-color: #eee !important; color: #999 !important; cursor: default !important; }","img:-moz-broken  { -moz-force-broken-image-icon: 1; height: 24px; width: 24px; }"], | ||||
| k=function(b){if(b.setActive)try{b.setActive()}catch(e){}else{var f=b.style,h=a.documentElement.scrollTop||a.body.scrollTop,g=a.documentElement.scrollLeft||a.body.scrollLeft,f={position:f.position,top:f.top,left:f.left,WebkitUserSelect:f.WebkitUserSelect};c.setStyles({position:"absolute",top:"-99999px",left:"-99999px",WebkitUserSelect:"none"}).on(b);b.focus();c.setStyles(f).on(b);d.scrollTo&&d.scrollTo(g,h)}};b.views.Composer.prototype.style=function(){var j=this,n=a.querySelector(":focus"),p=this.textarea.element, | ||||
| q=p.hasAttribute("placeholder"),r=q&&p.getAttribute("placeholder");this.focusStylesHost=this.focusStylesHost||e.cloneNode(!1);this.blurStylesHost=this.blurStylesHost||e.cloneNode(!1);q&&p.removeAttribute("placeholder");p===n&&p.blur();c.copyStyles(g).from(p).to(this.iframe).andTo(this.blurStylesHost);c.copyStyles(f).from(p).to(this.element).andTo(this.blurStylesHost);c.insertCSS(h).into(this.element.ownerDocument);k(p);c.copyStyles(g).from(p).to(this.focusStylesHost);c.copyStyles(f).from(p).to(this.focusStylesHost); | ||||
| var m=b.lang.array(g).without(["display"]);n?n.focus():p.blur();q&&p.setAttribute("placeholder",r);if(!b.browser.hasCurrentStyleProperty())var s=c.observe(d,"resize",function(){if(c.contains(document.documentElement,j.iframe)){var a=c.getStyle("display").from(p),b=c.getStyle("display").from(j.iframe);p.style.display="";j.iframe.style.display="none";c.copyStyles(i).from(p).to(j.iframe).andTo(j.focusStylesHost).andTo(j.blurStylesHost);j.iframe.style.display=b;p.style.display=a}else s.stop()});this.parent.observe("focus:composer", | ||||
| function(){c.copyStyles(m).from(j.focusStylesHost).to(j.iframe);c.copyStyles(f).from(j.focusStylesHost).to(j.element)});this.parent.observe("blur:composer",function(){c.copyStyles(m).from(j.blurStylesHost).to(j.iframe);c.copyStyles(f).from(j.blurStylesHost).to(j.element)});return this}})(wysihtml5); | ||||
| (function(b){var c=b.dom,a=b.browser,d={66:"bold",73:"italic",85:"underline"};b.views.Composer.prototype.observe=function(){var e=this,f=this.getValue(),g=this.sandbox.getIframe(),i=this.element,h=a.supportsEventsInIframeCorrectly()?i:this.sandbox.getWindow(),k=a.supportsEvent("drop")?["drop","paste"]:["dragdrop","paste"];c.observe(g,"DOMNodeRemoved",function(){clearInterval(j);e.parent.fire("destroy:composer")});var j=setInterval(function(){c.contains(document.documentElement,g)||(clearInterval(j), | ||||
| e.parent.fire("destroy:composer"))},250);c.observe(h,"focus",function(){e.parent.fire("focus").fire("focus:composer");setTimeout(function(){f=e.getValue()},0)});c.observe(h,"blur",function(){f!==e.getValue()&&e.parent.fire("change").fire("change:composer");e.parent.fire("blur").fire("blur:composer")});b.browser.isIos()&&c.observe(i,"blur",function(){var a=i.ownerDocument.createElement("input"),b=document.documentElement.scrollTop||document.body.scrollTop,c=document.documentElement.scrollLeft||document.body.scrollLeft; | ||||
| try{e.selection.insertNode(a)}catch(d){i.appendChild(a)}a.focus();a.parentNode.removeChild(a);window.scrollTo(c,b)});c.observe(i,"dragenter",function(){e.parent.fire("unset_placeholder")});a.firesOnDropOnlyWhenOnDragOverIsCancelled()&&c.observe(i,["dragover","dragenter"],function(a){a.preventDefault()});c.observe(i,k,function(b){var c=b.dataTransfer,d;c&&a.supportsDataTransfer()&&(d=c.getData("text/html")||c.getData("text/plain"));d?(i.focus(),e.commands.exec("insertHTML",d),e.parent.fire("paste").fire("paste:composer"), | ||||
| b.stopPropagation(),b.preventDefault()):setTimeout(function(){e.parent.fire("paste").fire("paste:composer")},0)});c.observe(i,"keyup",function(a){a=a.keyCode;(a===b.SPACE_KEY||a===b.ENTER_KEY)&&e.parent.fire("newword:composer")});this.parent.observe("paste:composer",function(){setTimeout(function(){e.parent.fire("newword:composer")},0)});a.canSelectImagesInContentEditable()||c.observe(i,"mousedown",function(a){var b=a.target;"IMG"===b.nodeName&&(e.selection.selectNode(b),a.preventDefault())});c.observe(i, | ||||
| "keydown",function(a){var b=d[a.keyCode];if((a.ctrlKey||a.metaKey)&&!a.altKey&&b)e.commands.exec(b),a.preventDefault()});c.observe(i,"keydown",function(a){var c=e.selection.getSelectedNode(!0),d=a.keyCode;if(c&&"IMG"===c.nodeName&&(d===b.BACKSPACE_KEY||d===b.DELETE_KEY))d=c.parentNode,d.removeChild(c),"A"===d.nodeName&&!d.firstChild&&d.parentNode.removeChild(d),setTimeout(function(){b.quirks.redraw(i)},0),a.preventDefault()});var n={IMG:"Image: ",A:"Link: "};c.observe(i,"mouseover",function(a){var a= | ||||
| a.target,b=a.nodeName;!("A"!==b&&"IMG"!==b)&&!a.hasAttribute("title")&&(b=n[b]+(a.getAttribute("href")||a.getAttribute("src")),a.setAttribute("title",b))})}})(wysihtml5); | ||||
| (function(b){b.views.Synchronizer=Base.extend({constructor:function(b,a,d){this.editor=b;this.textarea=a;this.composer=d;this._observe()},fromComposerToTextarea:function(c){this.textarea.setValue(b.lang.string(this.composer.getValue()).trim(),c)},fromTextareaToComposer:function(b){var a=this.textarea.getValue();a?this.composer.setValue(a,b):(this.composer.clear(),this.editor.fire("set_placeholder"))},sync:function(b){"textarea"===this.editor.currentView.name?this.fromTextareaToComposer(b):this.fromComposerToTextarea(b)}, | ||||
| _observe:function(){var c,a=this,d=this.textarea.element.form,e=function(){c=setInterval(function(){a.fromComposerToTextarea()},400)},f=function(){clearInterval(c);c=null};e();d&&(b.dom.observe(d,"submit",function(){a.sync(!0)}),b.dom.observe(d,"reset",function(){setTimeout(function(){a.fromTextareaToComposer()},0)}));this.editor.observe("change_view",function(b){if(b==="composer"&&!c){a.fromTextareaToComposer(true);e()}else if(b==="textarea"){a.fromComposerToTextarea(true);f()}});this.editor.observe("destroy:composer", | ||||
| f)}})})(wysihtml5); | ||||
| wysihtml5.views.Textarea=wysihtml5.views.View.extend({name:"textarea",constructor:function(b,c,a){this.base(b,c,a);this._observe()},clear:function(){this.element.value=""},getValue:function(b){var c=this.isEmpty()?"":this.element.value;b&&(c=this.parent.parse(c));return c},setValue:function(b,c){c&&(b=this.parent.parse(b));this.element.value=b},hasPlaceholderSet:function(){var b=wysihtml5.browser.supportsPlaceholderAttributeOn(this.element),c=this.element.getAttribute("placeholder")||null,a=this.element.value; | ||||
| return b&&!a||a===c},isEmpty:function(){return!wysihtml5.lang.string(this.element.value).trim()||this.hasPlaceholderSet()},_observe:function(){var b=this.element,c=this.parent,a={focusin:"focus",focusout:"blur"},d=wysihtml5.browser.supportsEvent("focusin")?["focusin","focusout","change"]:["focus","blur","change"];c.observe("beforeload",function(){wysihtml5.dom.observe(b,d,function(b){b=a[b.type]||b.type;c.fire(b).fire(b+":textarea")});wysihtml5.dom.observe(b,["paste","drop"],function(){setTimeout(function(){c.fire("paste").fire("paste:textarea")}, | ||||
| 0)})})}}); | ||||
| (function(b){var c=b.dom;b.toolbar.Dialog=b.lang.Dispatcher.extend({constructor:function(a,b){this.link=a;this.container=b},_observe:function(){if(!this._observed){var a=this,d=function(b){var c=a._serialize();c==a.elementToChange?a.fire("edit",c):a.fire("save",c);a.hide();b.preventDefault();b.stopPropagation()};c.observe(a.link,"click",function(){c.hasClass(a.link,"wysihtml5-command-dialog-opened")&&setTimeout(function(){a.hide()},0)});c.observe(this.container,"keydown",function(c){var e=c.keyCode; | ||||
| e===b.ENTER_KEY&&d(c);e===b.ESCAPE_KEY&&a.hide()});c.delegate(this.container,"[data-wysihtml5-dialog-action=save]","click",d);c.delegate(this.container,"[data-wysihtml5-dialog-action=cancel]","click",function(b){a.fire("cancel");a.hide();b.preventDefault();b.stopPropagation()});for(var e=this.container.querySelectorAll("input, select, textarea"),f=0,g=e.length,i=function(){clearInterval(a.interval)};f<g;f++)c.observe(e[f],"change",i);this._observed=!0}},_serialize:function(){for(var a=this.elementToChange|| | ||||
| {},b=this.container.querySelectorAll("[data-wysihtml5-dialog-field]"),c=b.length,f=0;f<c;f++)a[b[f].getAttribute("data-wysihtml5-dialog-field")]=b[f].value;return a},_interpolate:function(a){for(var b,c,f=document.querySelector(":focus"),g=this.container.querySelectorAll("[data-wysihtml5-dialog-field]"),i=g.length,h=0;h<i;h++)b=g[h],b!==f&&!(a&&"hidden"===b.type)&&(c=b.getAttribute("data-wysihtml5-dialog-field"),c=this.elementToChange?this.elementToChange[c]||"":b.defaultValue,b.value=c)},show:function(a){var b= | ||||
| this,e=this.container.querySelector("input, select, textarea");this.elementToChange=a;this._observe();this._interpolate();a&&(this.interval=setInterval(function(){b._interpolate(!0)},500));c.addClass(this.link,"wysihtml5-command-dialog-opened");this.container.style.display="";this.fire("show");if(e&&!a)try{e.focus()}catch(f){}},hide:function(){clearInterval(this.interval);this.elementToChange=null;c.removeClass(this.link,"wysihtml5-command-dialog-opened");this.container.style.display="none";this.fire("hide")}})})(wysihtml5); | ||||
| (function(b){var c=b.dom,a={position:"relative"},d={left:0,margin:0,opacity:0,overflow:"hidden",padding:0,position:"absolute",top:0,zIndex:1},e={cursor:"inherit",fontSize:"50px",height:"50px",marginTop:"-25px",outline:0,padding:0,position:"absolute",right:"-4px",top:"50%"},f={"x-webkit-speech":"",speech:""};b.toolbar.Speech=function(g,i){var h=document.createElement("input");if(b.browser.supportsSpeechApiOn(h)){var k=document.createElement("div");b.lang.object(d).merge({width:i.offsetWidth+"px",height:i.offsetHeight+ | ||||
| "px"});c.insert(h).into(k);c.insert(k).into(i);c.setStyles(e).on(h);c.setAttributes(f).on(h);c.setStyles(d).on(k);c.setStyles(a).on(i);c.observe(h,"onwebkitspeechchange"in h?"webkitspeechchange":"speechchange",function(){g.execCommand("insertText",h.value);h.value=""});c.observe(h,"click",function(a){c.hasClass(i,"wysihtml5-command-disabled")&&a.preventDefault();a.stopPropagation()})}else i.style.display="none"}})(wysihtml5); | ||||
| (function(b){var c=b.dom;b.toolbar.Toolbar=Base.extend({constructor:function(a,c){this.editor=a;this.container="string"===typeof c?document.getElementById(c):c;this.composer=a.composer;this._getLinks("command");this._getLinks("action");this._observe();this.show();for(var e=this.container.querySelectorAll("[data-wysihtml5-command=insertSpeech]"),f=e.length,g=0;g<f;g++)new b.toolbar.Speech(this,e[g])},_getLinks:function(a){for(var c=this[a+"Links"]=b.lang.array(this.container.querySelectorAll("[data-wysihtml5-"+ | ||||
| a+"]")).get(),e=c.length,f=0,g=this[a+"Mapping"]={},i,h,k,j,n;f<e;f++)i=c[f],k=i.getAttribute("data-wysihtml5-"+a),j=i.getAttribute("data-wysihtml5-"+a+"-value"),h=this.container.querySelector("[data-wysihtml5-"+a+"-group='"+k+"']"),n=this._getDialog(i,k),g[k+":"+j]={link:i,group:h,name:k,value:j,dialog:n,state:!1}},_getDialog:function(a,c){var e=this,f=this.container.querySelector("[data-wysihtml5-dialog='"+c+"']"),g,i;f&&(g=new b.toolbar.Dialog(a,f),g.observe("show",function(){i=e.composer.selection.getBookmark(); | ||||
| e.editor.fire("show:dialog",{command:c,dialogContainer:f,commandLink:a})}),g.observe("save",function(b){i&&e.composer.selection.setBookmark(i);e._execCommand(c,b);e.editor.fire("save:dialog",{command:c,dialogContainer:f,commandLink:a})}),g.observe("cancel",function(){e.editor.focus(!1);e.editor.fire("cancel:dialog",{command:c,dialogContainer:f,commandLink:a})}));return g},execCommand:function(a,b){if(!this.commandsDisabled){var c=this.commandMapping[a+":"+b];c&&c.dialog&&!c.state?c.dialog.show(): | ||||
| this._execCommand(a,b)}},_execCommand:function(a,b){this.editor.focus(!1);this.composer.commands.exec(a,b);this._updateLinkStates()},execAction:function(a){var b=this.editor;switch(a){case "change_view":b.currentView===b.textarea?b.fire("change_view","composer"):b.fire("change_view","textarea")}},_observe:function(){for(var a=this,b=this.editor,e=this.container,f=this.commandLinks.concat(this.actionLinks),g=f.length,i=0;i<g;i++)c.setAttributes({href:"javascript:;",unselectable:"on"}).on(f[i]);c.delegate(e, | ||||
| "[data-wysihtml5-command]","mousedown",function(a){a.preventDefault()});c.delegate(e,"[data-wysihtml5-command]","click",function(b){var c=this.getAttribute("data-wysihtml5-command"),d=this.getAttribute("data-wysihtml5-command-value");a.execCommand(c,d);b.preventDefault()});c.delegate(e,"[data-wysihtml5-action]","click",function(b){var c=this.getAttribute("data-wysihtml5-action");a.execAction(c);b.preventDefault()});b.observe("focus:composer",function(){a.bookmark=null;clearInterval(a.interval);a.interval= | ||||
| setInterval(function(){a._updateLinkStates()},500)});b.observe("blur:composer",function(){clearInterval(a.interval)});b.observe("destroy:composer",function(){clearInterval(a.interval)});b.observe("change_view",function(b){setTimeout(function(){a.commandsDisabled="composer"!==b;a._updateLinkStates();a.commandsDisabled?c.addClass(e,"wysihtml5-commands-disabled"):c.removeClass(e,"wysihtml5-commands-disabled")},0)})},_updateLinkStates:function(){var a=this.commandMapping,d=this.actionMapping,e,f,g;for(e in a)if(g= | ||||
| a[e],this.commandsDisabled?(f=!1,c.removeClass(g.link,"wysihtml5-command-active"),g.group&&c.removeClass(g.group,"wysihtml5-command-active"),g.dialog&&g.dialog.hide()):(f=this.composer.commands.state(g.name,g.value),b.lang.object(f).isArray()&&(f=1===f.length?f[0]:!0),c.removeClass(g.link,"wysihtml5-command-disabled"),g.group&&c.removeClass(g.group,"wysihtml5-command-disabled")),g.state!==f)(g.state=f)?(c.addClass(g.link,"wysihtml5-command-active"),g.group&&c.addClass(g.group,"wysihtml5-command-active"), | ||||
| g.dialog&&("object"===typeof f?g.dialog.show(f):g.dialog.hide())):(c.removeClass(g.link,"wysihtml5-command-active"),g.group&&c.removeClass(g.group,"wysihtml5-command-active"),g.dialog&&g.dialog.hide());for(e in d)a=d[e],"change_view"===a.name&&(a.state=this.editor.currentView===this.editor.textarea,a.state?c.addClass(a.link,"wysihtml5-action-active"):c.removeClass(a.link,"wysihtml5-action-active"))},show:function(){this.container.style.display=""},hide:function(){this.container.style.display="none"}})})(wysihtml5); | ||||
| (function(b){var c={name:void 0,style:!0,toolbar:void 0,autoLink:!0,parserRules:{tags:{br:{},span:{},div:{},p:{}},classes:{}},parser:b.dom.parse,composerClassName:"wysihtml5-editor",bodyClassName:"wysihtml5-supported",stylesheets:[],placeholderText:void 0,allowObjectResizing:!0,supportTouchDevices:!0};b.Editor=b.lang.Dispatcher.extend({constructor:function(a,d){this.textareaElement="string"===typeof a?document.getElementById(a):a;this.config=b.lang.object({}).merge(c).merge(d).get();this.currentView= | ||||
| this.textarea=new b.views.Textarea(this,this.textareaElement,this.config);this._isCompatible=b.browser.supported();if(!this._isCompatible||!this.config.supportTouchDevices&&b.browser.isTouchDevice()){var e=this;setTimeout(function(){e.fire("beforeload").fire("load")},0)}else{b.dom.addClass(document.body,this.config.bodyClassName);this.currentView=this.composer=new b.views.Composer(this,this.textareaElement,this.config);"function"===typeof this.config.parser&&this._initParser();this.observe("beforeload", | ||||
| function(){this.synchronizer=new b.views.Synchronizer(this,this.textarea,this.composer);this.config.toolbar&&(this.toolbar=new b.toolbar.Toolbar(this,this.config.toolbar))});try{console.log("Heya! This page is using wysihtml5 for rich text editing. Check out https://github.com/xing/wysihtml5")}catch(f){}}},isCompatible:function(){return this._isCompatible},clear:function(){this.currentView.clear();return this},getValue:function(a){return this.currentView.getValue(a)},setValue:function(a,b){if(!a)return this.clear(); | ||||
| this.currentView.setValue(a,b);return this},focus:function(a){this.currentView.focus(a);return this},disable:function(){this.currentView.disable();return this},enable:function(){this.currentView.enable();return this},isEmpty:function(){return this.currentView.isEmpty()},hasPlaceholderSet:function(){return this.currentView.hasPlaceholderSet()},parse:function(a){var c=this.config.parser(a,this.config.parserRules,this.composer.sandbox.getDocument(),!0);"object"===typeof a&&b.quirks.redraw(a);return c}, | ||||
| _initParser:function(){this.observe("paste:composer",function(){var a=this;a.composer.selection.executeAndRestore(function(){b.quirks.cleanPastedHTML(a.composer.element);a.parse(a.composer.element)},!0)});this.observe("paste:textarea",function(){this.textarea.setValue(this.parse(this.textarea.getValue()))})}})})(wysihtml5); | ||||
| @@ -1,67 +0,0 @@ | ||||
| .wysiwyg-color-black { | ||||
|   color: black; | ||||
| } | ||||
|  | ||||
| .wysiwyg-color-silver { | ||||
|   color: silver; | ||||
| } | ||||
|  | ||||
| .wysiwyg-color-gray { | ||||
|   color: gray; | ||||
| } | ||||
|  | ||||
| .wysiwyg-color-white { | ||||
|   color: white; | ||||
| } | ||||
|  | ||||
| .wysiwyg-color-maroon { | ||||
|   color: maroon; | ||||
| } | ||||
|  | ||||
| .wysiwyg-color-red { | ||||
|   color: red; | ||||
| } | ||||
|  | ||||
| .wysiwyg-color-purple { | ||||
|   color: purple; | ||||
| } | ||||
|  | ||||
| .wysiwyg-color-fuchsia { | ||||
|   color: fuchsia; | ||||
| } | ||||
|  | ||||
| .wysiwyg-color-green { | ||||
|   color: green; | ||||
| } | ||||
|  | ||||
| .wysiwyg-color-lime { | ||||
|   color: lime; | ||||
| } | ||||
|  | ||||
| .wysiwyg-color-olive { | ||||
|   color: olive; | ||||
| } | ||||
|  | ||||
| .wysiwyg-color-yellow { | ||||
|   color: yellow; | ||||
| } | ||||
|  | ||||
| .wysiwyg-color-navy { | ||||
|   color: navy; | ||||
| } | ||||
|  | ||||
| .wysiwyg-color-blue { | ||||
|   color: blue; | ||||
| } | ||||
|  | ||||
| .wysiwyg-color-teal { | ||||
|   color: teal; | ||||
| } | ||||
|  | ||||
| .wysiwyg-color-aqua { | ||||
|   color: aqua; | ||||
| } | ||||
|  | ||||
| .wysiwyg-color-orange { | ||||
|   color: orange; | ||||
| } | ||||
| @@ -1,138 +0,0 @@ | ||||
| /** | ||||
| Bootstrap wysihtml5 editor. Based on [bootstrap-wysihtml5](https://github.com/jhollingworth/bootstrap-wysihtml5).   | ||||
| You should include **manually** distributives of `wysihtml5` and `bootstrap-wysihtml5`: | ||||
|  | ||||
|     <link href="js/inputs-ext/wysihtml5/bootstrap-wysihtml5-0.0.2/bootstrap-wysihtml5-0.0.2.css" rel="stylesheet" type="text/css"></link>   | ||||
|     <script src="js/inputs-ext/wysihtml5/bootstrap-wysihtml5-0.0.2/wysihtml5-0.3.0.min.js"></script>   | ||||
|     <script src="js/inputs-ext/wysihtml5/bootstrap-wysihtml5-0.0.2/bootstrap-wysihtml5-0.0.2.min.js"></script> | ||||
|      | ||||
| And also include `wysihtml5.js` from `inputs-ext` directory of x-editable: | ||||
|        | ||||
|     <script src="js/inputs-ext/wysihtml5/wysihtml5.js"></script>   | ||||
|  | ||||
| **Note:** It's better to use fresh bootstrap-wysihtml5 from it's [master branch](https://github.com/jhollingworth/bootstrap-wysihtml5/tree/master/src) as there is update for correct image insertion.     | ||||
|      | ||||
| @class wysihtml5 | ||||
| @extends abstractinput | ||||
| @final | ||||
| @since 1.4.0 | ||||
| @example | ||||
| <div id="comments" data-type="wysihtml5" data-pk="1"><h2>awesome</h2> comment!</div> | ||||
| <script> | ||||
| $(function(){ | ||||
|     $('#comments').editable({ | ||||
|         url: '/post', | ||||
|         title: 'Enter comments' | ||||
|     }); | ||||
| }); | ||||
| </script> | ||||
| **/ | ||||
| (function ($) { | ||||
|     "use strict"; | ||||
|      | ||||
|     var Wysihtml5 = function (options) { | ||||
|         this.init('wysihtml5', options, Wysihtml5.defaults); | ||||
|          | ||||
|         //extend wysihtml5 manually as $.extend not recursive  | ||||
|         this.options.wysihtml5 = $.extend({}, Wysihtml5.defaults.wysihtml5, options.wysihtml5); | ||||
|     }; | ||||
|  | ||||
|     $.fn.editableutils.inherit(Wysihtml5, $.fn.editabletypes.abstractinput); | ||||
|  | ||||
|     $.extend(Wysihtml5.prototype, { | ||||
|         render: function () { | ||||
|             var deferred = $.Deferred(), | ||||
|             msieOld; | ||||
|              | ||||
|             //generate unique id as it required for wysihtml5 | ||||
|             this.$input.attr('id', 'textarea_'+(new Date()).getTime()); | ||||
|  | ||||
|             this.setClass(); | ||||
|             this.setAttr('placeholder');             | ||||
|              | ||||
|             //resolve deffered when widget loaded | ||||
|             $.extend(this.options.wysihtml5, { | ||||
|                 events: { | ||||
|                   load: function() { | ||||
|                       deferred.resolve(); | ||||
|                   }   | ||||
|                 } | ||||
|             }); | ||||
|              | ||||
|             this.$input.wysihtml5(this.options.wysihtml5); | ||||
|              | ||||
|             /* | ||||
|              In IE8 wysihtml5 iframe stays on the same line with buttons toolbar (inside popover). | ||||
|              The only solution I found is to add <br>. If you fine better way, please send PR.    | ||||
|             */ | ||||
|             msieOld = /msie\s*(8|7|6)/.test(navigator.userAgent.toLowerCase()); | ||||
|             if(msieOld) { | ||||
|                 this.$input.before('<br><br>');  | ||||
|             } | ||||
|              | ||||
|             return deferred.promise(); | ||||
|         }, | ||||
|         | ||||
|         value2html: function(value, element) { | ||||
|             $(element).html(value); | ||||
|         }, | ||||
|  | ||||
|         html2value: function(html) { | ||||
|             return html; | ||||
|         }, | ||||
|          | ||||
|         value2input: function(value) { | ||||
|             this.$input.data("wysihtml5").editor.setValue(value, true); | ||||
|         },  | ||||
|  | ||||
|         activate: function() { | ||||
|             this.$input.data("wysihtml5").editor.focus(); | ||||
|         }, | ||||
|          | ||||
|         isEmpty: function($element) { | ||||
|             if($element.html().trim() === '') { | ||||
|                 return true; | ||||
|             } else if($element.text().trim() !== '') { | ||||
|                 return false; | ||||
|             } else { | ||||
|                 //e.g. '<img>', '<br>', '<p></p>' | ||||
|                 return !$element.height() || !$element.width(); | ||||
|             }  | ||||
|         } | ||||
|     }); | ||||
|  | ||||
|     Wysihtml5.defaults = $.extend({}, $.fn.editabletypes.abstractinput.defaults, { | ||||
|         /** | ||||
|         @property tpl | ||||
|         @default <textarea></textarea> | ||||
|         **/ | ||||
|         tpl:'<textarea></textarea>', | ||||
|         /** | ||||
|         @property inputclass | ||||
|         @default editable-wysihtml5 | ||||
|         **/ | ||||
|         inputclass: 'editable-wysihtml5', | ||||
|         /** | ||||
|         Placeholder attribute of input. Shown when input is empty. | ||||
|  | ||||
|         @property placeholder | ||||
|         @type string | ||||
|         @default null | ||||
|         **/ | ||||
|         placeholder: null, | ||||
|         /** | ||||
|         Wysihtml5 default options.   | ||||
|         See https://github.com/jhollingworth/bootstrap-wysihtml5#options | ||||
|  | ||||
|         @property wysihtml5 | ||||
|         @type object | ||||
|         @default {stylesheets: false} | ||||
|         **/         | ||||
|         wysihtml5: { | ||||
|             stylesheets: false //see https://github.com/jhollingworth/bootstrap-wysihtml5/issues/183 | ||||
|         } | ||||
|     }); | ||||
|  | ||||
|     $.fn.editabletypes.wysihtml5 = Wysihtml5; | ||||
|  | ||||
| }(window.jQuery)); | ||||
| @@ -1,197 +0,0 @@ | ||||
| /** | ||||
| Combodate input - dropdown date and time picker.     | ||||
| Based on [combodate](http://vitalets.github.com/combodate) plugin (included). To use it you should manually include [momentjs](http://momentjs.com). | ||||
|  | ||||
|     <script src="js/moment.min.js"></script> | ||||
|     | ||||
| Allows to input: | ||||
|  | ||||
| * only date | ||||
| * only time  | ||||
| * both date and time   | ||||
|  | ||||
| Please note, that format is taken from momentjs and **not compatible** with bootstrap-datepicker / jquery UI datepicker.   | ||||
| Internally value stored as `momentjs` object.  | ||||
|  | ||||
| @class combodate | ||||
| @extends abstractinput | ||||
| @final | ||||
| @since 1.4.0 | ||||
| @example | ||||
| <a href="#" id="dob" data-type="combodate" data-pk="1" data-url="/post" data-value="1984-05-15" data-title="Select date"></a> | ||||
| <script> | ||||
| $(function(){ | ||||
|     $('#dob').editable({ | ||||
|         format: 'YYYY-MM-DD',     | ||||
|         viewformat: 'DD.MM.YYYY',     | ||||
|         template: 'D / MMMM / YYYY',     | ||||
|         combodate: { | ||||
|                 minYear: 2000, | ||||
|                 maxYear: 2015, | ||||
|                 minuteStep: 1 | ||||
|            } | ||||
|         } | ||||
|     }); | ||||
| }); | ||||
| </script> | ||||
| **/ | ||||
|  | ||||
| /*global moment*/ | ||||
|  | ||||
| (function ($) { | ||||
|     "use strict"; | ||||
|      | ||||
|     var Constructor = function (options) { | ||||
|         this.init('combodate', options, Constructor.defaults); | ||||
|          | ||||
|         //by default viewformat equals to format | ||||
|         if(!this.options.viewformat) { | ||||
|             this.options.viewformat = this.options.format; | ||||
|         }         | ||||
|          | ||||
|         //try parse combodate config defined as json string in data-combodate | ||||
|         options.combodate = $.fn.editableutils.tryParseJson(options.combodate, true); | ||||
|  | ||||
|         //overriding combodate config (as by default jQuery extend() is not recursive) | ||||
|         this.options.combodate = $.extend({}, Constructor.defaults.combodate, options.combodate, { | ||||
|             format: this.options.format, | ||||
|             template: this.options.template | ||||
|         }); | ||||
|     }; | ||||
|  | ||||
|     $.fn.editableutils.inherit(Constructor, $.fn.editabletypes.abstractinput);     | ||||
|      | ||||
|     $.extend(Constructor.prototype, { | ||||
|         render: function () { | ||||
|             this.$input.combodate(this.options.combodate); | ||||
|                      | ||||
|             if($.fn.editableform.engine === 'bs3') { | ||||
|                 this.$input.siblings().find('select').addClass('form-control'); | ||||
|             } | ||||
|              | ||||
|             if(this.options.inputclass) { | ||||
|                 this.$input.siblings().find('select').addClass(this.options.inputclass); | ||||
|             }             | ||||
|             //"clear" link | ||||
|             /* | ||||
|             if(this.options.clear) { | ||||
|                 this.$clear = $('<a href="#"></a>').html(this.options.clear).click($.proxy(function(e){ | ||||
|                     e.preventDefault(); | ||||
|                     e.stopPropagation(); | ||||
|                     this.clear(); | ||||
|                 }, this)); | ||||
|                  | ||||
|                 this.$tpl.parent().append($('<div class="editable-clear">').append(this.$clear));   | ||||
|             }  | ||||
|             */                | ||||
|         }, | ||||
|          | ||||
|         value2html: function(value, element) { | ||||
|             var text = value ? value.format(this.options.viewformat) : ''; | ||||
|             //$(element).text(text); | ||||
|             Constructor.superclass.value2html.call(this, text, element);   | ||||
|         }, | ||||
|  | ||||
|         html2value: function(html) { | ||||
|             return html ? moment(html, this.options.viewformat) : null; | ||||
|         },    | ||||
|          | ||||
|         value2str: function(value) { | ||||
|             return value ? value.format(this.options.format) : ''; | ||||
|        },  | ||||
|         | ||||
|        str2value: function(str) { | ||||
|            return str ? moment(str, this.options.format) : null; | ||||
|        },  | ||||
|         | ||||
|        value2submit: function(value) { | ||||
|            return this.value2str(value); | ||||
|        },                     | ||||
|  | ||||
|        value2input: function(value) { | ||||
|            this.$input.combodate('setValue', value); | ||||
|        }, | ||||
|          | ||||
|        input2value: function() {  | ||||
|            return this.$input.combodate('getValue', null); | ||||
|        },        | ||||
|         | ||||
|        activate: function() { | ||||
|            this.$input.siblings('.combodate').find('select').eq(0).focus(); | ||||
|        }, | ||||
|         | ||||
|        /* | ||||
|        clear:  function() { | ||||
|           this.$input.data('datepicker').date = null; | ||||
|           this.$input.find('.active').removeClass('active'); | ||||
|        }, | ||||
|        */ | ||||
|         | ||||
|        autosubmit: function() { | ||||
|             | ||||
|        } | ||||
|  | ||||
|     }); | ||||
|      | ||||
|     Constructor.defaults = $.extend({}, $.fn.editabletypes.abstractinput.defaults, { | ||||
|         /** | ||||
|         @property tpl  | ||||
|         @default <input type="text"> | ||||
|         **/          | ||||
|         tpl:'<input type="text">', | ||||
|         /** | ||||
|         @property inputclass  | ||||
|         @default null | ||||
|         **/          | ||||
|         inputclass: null, | ||||
|         /** | ||||
|         Format used for sending value to server. Also applied when converting date from <code>data-value</code> attribute.<br> | ||||
|         See list of tokens in [momentjs docs](http://momentjs.com/docs/#/parsing/string-format)   | ||||
|          | ||||
|         @property format  | ||||
|         @type string | ||||
|         @default YYYY-MM-DD | ||||
|         **/          | ||||
|         format:'YYYY-MM-DD', | ||||
|         /** | ||||
|         Format used for displaying date. Also applied when converting date from element's text on init.    | ||||
|         If not specified equals to `format`. | ||||
|          | ||||
|         @property viewformat  | ||||
|         @type string | ||||
|         @default null | ||||
|         **/           | ||||
|         viewformat: null,         | ||||
|         /** | ||||
|         Template used for displaying dropdowns. | ||||
|          | ||||
|         @property template  | ||||
|         @type string | ||||
|         @default D / MMM / YYYY | ||||
|         **/           | ||||
|         template: 'D / MMM / YYYY',   | ||||
|         /** | ||||
|         Configuration of combodate. | ||||
|         Full list of options: http://vitalets.github.com/combodate/#docs | ||||
|          | ||||
|         @property combodate  | ||||
|         @type object | ||||
|         @default null | ||||
|         **/ | ||||
|         combodate: null | ||||
|          | ||||
|         /* | ||||
|         (not implemented yet) | ||||
|         Text shown as clear date button.  | ||||
|         If <code>false</code> clear button will not be rendered. | ||||
|          | ||||
|         @property clear  | ||||
|         @type boolean|string | ||||
|         @default 'x clear'          | ||||
|         */ | ||||
|         //clear: '× clear' | ||||
|     });    | ||||
|  | ||||
|     $.fn.editabletypes.combodate = Constructor; | ||||
|  | ||||
| }(window.jQuery)); | ||||
| @@ -1,486 +0,0 @@ | ||||
| /** | ||||
| * Combodate - 1.0.5 | ||||
| * Dropdown date and time picker. | ||||
| * Converts text input into dropdowns to pick day, month, year, hour, minute and second. | ||||
| * Uses momentjs as datetime library http://momentjs.com. | ||||
| * For i18n include corresponding file from https://github.com/timrwood/moment/tree/master/lang  | ||||
| * | ||||
| * Confusion at noon and midnight - see http://en.wikipedia.org/wiki/12-hour_clock#Confusion_at_noon_and_midnight | ||||
| * In combodate:  | ||||
| * 12:00 pm --> 12:00 (24-h format, midday) | ||||
| * 12:00 am --> 00:00 (24-h format, midnight, start of day) | ||||
| *  | ||||
| * Differs from momentjs parse rules: | ||||
| * 00:00 pm, 12:00 pm --> 12:00 (24-h format, day not change) | ||||
| * 00:00 am, 12:00 am --> 00:00 (24-h format, day not change) | ||||
| *  | ||||
| *  | ||||
| * Author: Vitaliy Potapov | ||||
| * Project page: http://github.com/vitalets/combodate | ||||
| * Copyright (c) 2012 Vitaliy Potapov. Released under MIT License. | ||||
| **/ | ||||
| (function ($) { | ||||
|  | ||||
|     var Combodate = function (element, options) { | ||||
|         this.$element = $(element); | ||||
|         if(!this.$element.is('input')) { | ||||
|             $.error('Combodate should be applied to INPUT element'); | ||||
|             return; | ||||
|         } | ||||
|         this.options = $.extend({}, $.fn.combodate.defaults, options, this.$element.data()); | ||||
|         this.init();   | ||||
|      }; | ||||
|  | ||||
|     Combodate.prototype = { | ||||
|         constructor: Combodate,  | ||||
|         init: function () { | ||||
|             this.map = { | ||||
|                 //key   regexp    moment.method | ||||
|                 day:    ['D',    'date'],  | ||||
|                 month:  ['M',    'month'],  | ||||
|                 year:   ['Y',    'year'],  | ||||
|                 hour:   ['[Hh]', 'hours'], | ||||
|                 minute: ['m',    'minutes'],  | ||||
|                 second: ['s',    'seconds'], | ||||
|                 ampm:   ['[Aa]', '']  | ||||
|             }; | ||||
|              | ||||
|             this.$widget = $('<span class="combodate"></span>').html(this.getTemplate()); | ||||
|                        | ||||
|             this.initCombos(); | ||||
|              | ||||
|             //update original input on change  | ||||
|             this.$widget.on('change', 'select', $.proxy(function(e) { | ||||
|                 this.$element.val(this.getValue()).change(); | ||||
|                 // update days count if month or year changes | ||||
|                 if (this.options.smartDays) { | ||||
|                     if ($(e.target).is('.month') || $(e.target).is('.year')) { | ||||
|                         this.fillCombo('day'); | ||||
|                     } | ||||
|                 } | ||||
|             }, this)); | ||||
|              | ||||
|             this.$widget.find('select').css('width', 'auto'); | ||||
|                                         | ||||
|             // hide original input and insert widget                                        | ||||
|             this.$element.hide().after(this.$widget); | ||||
|              | ||||
|             // set initial value | ||||
|             this.setValue(this.$element.val() || this.options.value); | ||||
|         }, | ||||
|          | ||||
|         /* | ||||
|          Replace tokens in template with <select> elements  | ||||
|         */          | ||||
|         getTemplate: function() { | ||||
|             var tpl = this.options.template; | ||||
|  | ||||
|             //first pass | ||||
|             $.each(this.map, function(k, v) { | ||||
|                 v = v[0];  | ||||
|                 var r = new RegExp(v+'+'), | ||||
|                     token = v.length > 1 ? v.substring(1, 2) : v; | ||||
|                      | ||||
|                 tpl = tpl.replace(r, '{'+token+'}'); | ||||
|             }); | ||||
|  | ||||
|             //replace spaces with   | ||||
|             tpl = tpl.replace(/ /g, ' '); | ||||
|  | ||||
|             //second pass | ||||
|             $.each(this.map, function(k, v) { | ||||
|                 v = v[0]; | ||||
|                 var token = v.length > 1 ? v.substring(1, 2) : v; | ||||
|                      | ||||
|                 tpl = tpl.replace('{'+token+'}', '<select class="'+k+'"></select>'); | ||||
|             });    | ||||
|  | ||||
|             return tpl; | ||||
|         }, | ||||
|          | ||||
|         /* | ||||
|          Initialize combos that presents in template  | ||||
|         */         | ||||
|         initCombos: function() { | ||||
|             for (var k in this.map) { | ||||
|                 var $c = this.$widget.find('.'+k); | ||||
|                 // set properties like this.$day, this.$month etc. | ||||
|                 this['$'+k] = $c.length ? $c : null; | ||||
|                 // fill with items | ||||
|                 this.fillCombo(k); | ||||
|             } | ||||
|         }, | ||||
|  | ||||
|         /* | ||||
|          Fill combo with items  | ||||
|         */         | ||||
|         fillCombo: function(k) { | ||||
|             var $combo = this['$'+k]; | ||||
|             if (!$combo) { | ||||
|                 return; | ||||
|             } | ||||
|  | ||||
|             // define method name to fill items, e.g `fillDays` | ||||
|             var f = 'fill' + k.charAt(0).toUpperCase() + k.slice(1);  | ||||
|             var items = this[f](); | ||||
|             var value = $combo.val(); | ||||
|  | ||||
|             $combo.empty(); | ||||
|             for(var i=0; i<items.length; i++) { | ||||
|                 $combo.append('<option value="'+items[i][0]+'">'+items[i][1]+'</option>'); | ||||
|             } | ||||
|  | ||||
|             $combo.val(value); | ||||
|         }, | ||||
|  | ||||
|         /* | ||||
|          Initialize items of combos. Handles `firstItem` option  | ||||
|         */ | ||||
|         fillCommon: function(key) { | ||||
|             var values = [], | ||||
|                 relTime; | ||||
|                  | ||||
|             if(this.options.firstItem === 'name') { | ||||
|                 //need both to support moment ver < 2 and  >= 2 | ||||
|                 relTime = moment.relativeTime || moment.langData()._relativeTime;  | ||||
|                 var header = typeof relTime[key] === 'function' ? relTime[key](1, true, key, false) : relTime[key]; | ||||
|                 //take last entry (see momentjs lang files structure)  | ||||
|                 header = header.split(' ').reverse()[0];                 | ||||
|                 values.push(['', header]); | ||||
|             } else if(this.options.firstItem === 'empty') { | ||||
|                 values.push(['', '']); | ||||
|             } | ||||
|             return values; | ||||
|         },   | ||||
|  | ||||
|  | ||||
|         /* | ||||
|         fill day | ||||
|         */ | ||||
|         fillDay: function() { | ||||
|             var items = this.fillCommon('d'), name, i, | ||||
|                 twoDigit = this.options.template.indexOf('DD') !== -1, | ||||
|                 daysCount = 31; | ||||
|  | ||||
|             // detect days count (depends on month and year) | ||||
|             // originally https://github.com/vitalets/combodate/pull/7 | ||||
|             if (this.options.smartDays && this.$month && this.$year) { | ||||
|                 var month = parseInt(this.$month.val(), 10); | ||||
|                 var year = parseInt(this.$year.val(), 10); | ||||
|  | ||||
|                 if (!isNaN(month) && !isNaN(year)) { | ||||
|                     daysCount = moment([year, month]).daysInMonth(); | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             for (i = 1; i <= daysCount; i++) { | ||||
|                 name = twoDigit ? this.leadZero(i) : i; | ||||
|                 items.push([i, name]); | ||||
|             } | ||||
|             return items;         | ||||
|         }, | ||||
|          | ||||
|         /* | ||||
|         fill month | ||||
|         */ | ||||
|         fillMonth: function() { | ||||
|             var items = this.fillCommon('M'), name, i,  | ||||
|                 longNames = this.options.template.indexOf('MMMM') !== -1, | ||||
|                 shortNames = this.options.template.indexOf('MMM') !== -1, | ||||
|                 twoDigit = this.options.template.indexOf('MM') !== -1; | ||||
|                  | ||||
|             for(i=0; i<=11; i++) { | ||||
|                 if(longNames) { | ||||
|                     //see https://github.com/timrwood/momentjs.com/pull/36 | ||||
|                     name = moment().date(1).month(i).format('MMMM'); | ||||
|                 } else if(shortNames) { | ||||
|                     name = moment().date(1).month(i).format('MMM'); | ||||
|                 } else if(twoDigit) { | ||||
|                     name = this.leadZero(i+1); | ||||
|                 } else { | ||||
|                     name = i+1; | ||||
|                 } | ||||
|                 items.push([i, name]); | ||||
|             }  | ||||
|             return items; | ||||
|         },   | ||||
|          | ||||
|         /* | ||||
|         fill year | ||||
|         */ | ||||
|         fillYear: function() { | ||||
|             var items = [], name, i,  | ||||
|                 longNames = this.options.template.indexOf('YYYY') !== -1; | ||||
|             | ||||
|             for(i=this.options.maxYear; i>=this.options.minYear; i--) { | ||||
|                 name = longNames ? i : (i+'').substring(2); | ||||
|                 items[this.options.yearDescending ? 'push' : 'unshift']([i, name]); | ||||
|             } | ||||
|              | ||||
|             items = this.fillCommon('y').concat(items); | ||||
|              | ||||
|             return items;               | ||||
|         },     | ||||
|          | ||||
|         /* | ||||
|         fill hour | ||||
|         */ | ||||
|         fillHour: function() { | ||||
|             var items = this.fillCommon('h'), name, i, | ||||
|                 h12 = this.options.template.indexOf('h') !== -1, | ||||
|                 h24 = this.options.template.indexOf('H') !== -1, | ||||
|                 twoDigit = this.options.template.toLowerCase().indexOf('hh') !== -1, | ||||
|                 min = h12 ? 1 : 0,  | ||||
|                 max = h12 ? 12 : 23; | ||||
|                  | ||||
|             for(i=min; i<=max; i++) { | ||||
|                 name = twoDigit ? this.leadZero(i) : i; | ||||
|                 items.push([i, name]); | ||||
|             }  | ||||
|             return items;                  | ||||
|         },     | ||||
|          | ||||
|         /* | ||||
|         fill minute | ||||
|         */ | ||||
|         fillMinute: function() { | ||||
|             var items = this.fillCommon('m'), name, i, | ||||
|                 twoDigit = this.options.template.indexOf('mm') !== -1; | ||||
|  | ||||
|             for(i=0; i<=59; i+= this.options.minuteStep) { | ||||
|                 name = twoDigit ? this.leadZero(i) : i; | ||||
|                 items.push([i, name]); | ||||
|             }     | ||||
|             return items;               | ||||
|         },   | ||||
|          | ||||
|         /* | ||||
|         fill second | ||||
|         */ | ||||
|         fillSecond: function() { | ||||
|             var items = this.fillCommon('s'), name, i, | ||||
|                 twoDigit = this.options.template.indexOf('ss') !== -1; | ||||
|  | ||||
|             for(i=0; i<=59; i+= this.options.secondStep) { | ||||
|                 name = twoDigit ? this.leadZero(i) : i; | ||||
|                 items.push([i, name]); | ||||
|             }     | ||||
|             return items;               | ||||
|         },   | ||||
|          | ||||
|         /* | ||||
|         fill ampm | ||||
|         */ | ||||
|         fillAmpm: function() { | ||||
|             var ampmL = this.options.template.indexOf('a') !== -1, | ||||
|                 ampmU = this.options.template.indexOf('A') !== -1,             | ||||
|                 items = [ | ||||
|                     ['am', ampmL ? 'am' : 'AM'], | ||||
|                     ['pm', ampmL ? 'pm' : 'PM'] | ||||
|                 ]; | ||||
|             return items;                               | ||||
|         },                                        | ||||
|  | ||||
|         /* | ||||
|          Returns current date value from combos.  | ||||
|          If format not specified - `options.format` used. | ||||
|          If format = `null` - Moment object returned. | ||||
|         */ | ||||
|         getValue: function(format) { | ||||
|             var dt, values = {},  | ||||
|                 that = this, | ||||
|                 notSelected = false; | ||||
|                  | ||||
|             //getting selected values     | ||||
|             $.each(this.map, function(k, v) { | ||||
|                 if(k === 'ampm') { | ||||
|                     return; | ||||
|                 } | ||||
|                 var def = k === 'day' ? 1 : 0; | ||||
|                    | ||||
|                 values[k] = that['$'+k] ? parseInt(that['$'+k].val(), 10) : def;  | ||||
|                  | ||||
|                 if(isNaN(values[k])) { | ||||
|                    notSelected = true; | ||||
|                    return false;  | ||||
|                 } | ||||
|             }); | ||||
|              | ||||
|             //if at least one visible combo not selected - return empty string | ||||
|             if(notSelected) { | ||||
|                return ''; | ||||
|             } | ||||
|              | ||||
|             //convert hours 12h --> 24h  | ||||
|             if(this.$ampm) { | ||||
|                 //12:00 pm --> 12:00 (24-h format, midday), 12:00 am --> 00:00 (24-h format, midnight, start of day) | ||||
|                 if(values.hour === 12) { | ||||
|                     values.hour = this.$ampm.val() === 'am' ? 0 : 12;                     | ||||
|                 } else { | ||||
|                     values.hour = this.$ampm.val() === 'am' ? values.hour : values.hour+12; | ||||
|                 } | ||||
|             }     | ||||
|              | ||||
|             dt = moment([values.year, values.month, values.day, values.hour, values.minute, values.second]); | ||||
|              | ||||
|             //highlight invalid date | ||||
|             this.highlight(dt); | ||||
|                                | ||||
|             format = format === undefined ? this.options.format : format; | ||||
|             if(format === null) { | ||||
|                return dt.isValid() ? dt : null;  | ||||
|             } else { | ||||
|                return dt.isValid() ? dt.format(format) : '';  | ||||
|             }            | ||||
|         }, | ||||
|          | ||||
|         setValue: function(value) { | ||||
|             if(!value) { | ||||
|                 return; | ||||
|             } | ||||
|              | ||||
|             var dt = typeof value === 'string' ? moment(value, this.options.format) : moment(value), | ||||
|                 that = this, | ||||
|                 values = {}; | ||||
|              | ||||
|             //function to find nearest value in select options | ||||
|             function getNearest($select, value) { | ||||
|                 var delta = {}; | ||||
|                 $select.children('option').each(function(i, opt){ | ||||
|                     var optValue = $(opt).attr('value'), | ||||
|                     distance; | ||||
|  | ||||
|                     if(optValue === '') return; | ||||
|                     distance = Math.abs(optValue - value);  | ||||
|                     if(typeof delta.distance === 'undefined' || distance < delta.distance) { | ||||
|                         delta = {value: optValue, distance: distance}; | ||||
|                     }  | ||||
|                 });  | ||||
|                 return delta.value; | ||||
|             }              | ||||
|              | ||||
|             if(dt.isValid()) { | ||||
|                 //read values from date object | ||||
|                 $.each(this.map, function(k, v) { | ||||
|                     if(k === 'ampm') { | ||||
|                        return;  | ||||
|                     } | ||||
|                     values[k] = dt[v[1]](); | ||||
|                 }); | ||||
|                 | ||||
|                 if(this.$ampm) { | ||||
|                     //12:00 pm --> 12:00 (24-h format, midday), 12:00 am --> 00:00 (24-h format, midnight, start of day) | ||||
|                     if(values.hour >= 12) { | ||||
|                         values.ampm = 'pm'; | ||||
|                         if(values.hour > 12) { | ||||
|                             values.hour -= 12; | ||||
|                         } | ||||
|                     } else { | ||||
|                         values.ampm = 'am'; | ||||
|                         if(values.hour === 0) { | ||||
|                             values.hour = 12; | ||||
|                         } | ||||
|                     }  | ||||
|                 } | ||||
|                 | ||||
|                 $.each(values, function(k, v) { | ||||
|                     //call val() for each existing combo, e.g. this.$hour.val() | ||||
|                     if(that['$'+k]) { | ||||
|                         | ||||
|                         if(k === 'minute' && that.options.minuteStep > 1 && that.options.roundTime) { | ||||
|                            v = getNearest(that['$'+k], v); | ||||
|                         } | ||||
|                         | ||||
|                         if(k === 'second' && that.options.secondStep > 1 && that.options.roundTime) { | ||||
|                            v = getNearest(that['$'+k], v); | ||||
|                         }                        | ||||
|                         | ||||
|                         that['$'+k].val(v); | ||||
|                     } | ||||
|                 }); | ||||
|  | ||||
|                 // update days count | ||||
|                 if (this.options.smartDays) { | ||||
|                     this.fillCombo('day'); | ||||
|                 } | ||||
|                 | ||||
|                this.$element.val(dt.format(this.options.format)).change(); | ||||
|             } | ||||
|         }, | ||||
|          | ||||
|         /* | ||||
|          highlight combos if date is invalid | ||||
|         */ | ||||
|         highlight: function(dt) { | ||||
|             if(!dt.isValid()) { | ||||
|                 if(this.options.errorClass) { | ||||
|                     this.$widget.addClass(this.options.errorClass); | ||||
|                 } else { | ||||
|                     //store original border color | ||||
|                     if(!this.borderColor) { | ||||
|                         this.borderColor = this.$widget.find('select').css('border-color');  | ||||
|                     } | ||||
|                     this.$widget.find('select').css('border-color', 'red'); | ||||
|                 }  | ||||
|             } else { | ||||
|                 if(this.options.errorClass) { | ||||
|                     this.$widget.removeClass(this.options.errorClass); | ||||
|                 } else { | ||||
|                     this.$widget.find('select').css('border-color', this.borderColor); | ||||
|                 }   | ||||
|             } | ||||
|         }, | ||||
|          | ||||
|         leadZero: function(v) { | ||||
|             return v <= 9 ? '0' + v : v;  | ||||
|         }, | ||||
|          | ||||
|         destroy: function() { | ||||
|             this.$widget.remove(); | ||||
|             this.$element.removeData('combodate').show(); | ||||
|         } | ||||
|          | ||||
|         //todo: clear method         | ||||
|     }; | ||||
|  | ||||
|     $.fn.combodate = function ( option ) { | ||||
|         var d, args = Array.apply(null, arguments); | ||||
|         args.shift(); | ||||
|  | ||||
|         //getValue returns date as string / object (not jQuery object) | ||||
|         if(option === 'getValue' && this.length && (d = this.eq(0).data('combodate'))) { | ||||
|           return d.getValue.apply(d, args); | ||||
|         }         | ||||
|          | ||||
|         return this.each(function () { | ||||
|             var $this = $(this), | ||||
|             data = $this.data('combodate'), | ||||
|             options = typeof option == 'object' && option; | ||||
|             if (!data) { | ||||
|                 $this.data('combodate', (data = new Combodate(this, options))); | ||||
|             } | ||||
|             if (typeof option == 'string' && typeof data[option] == 'function') { | ||||
|                 data[option].apply(data, args); | ||||
|             } | ||||
|         }); | ||||
|     };   | ||||
|      | ||||
|     $.fn.combodate.defaults = { | ||||
|          //in this format value stored in original input | ||||
|         format: 'DD-MM-YYYY HH:mm',       | ||||
|         //in this format items in dropdowns are displayed | ||||
|         template: 'D / MMM / YYYY   H : mm', | ||||
|         //initial value, can be `new Date()`     | ||||
|         value: null,                        | ||||
|         minYear: 1970, | ||||
|         maxYear: (new Date().getFullYear()), | ||||
|         yearDescending: true, | ||||
|         minuteStep: 5, | ||||
|         secondStep: 1, | ||||
|         firstItem: 'empty', //'name', 'empty', 'none' | ||||
|         errorClass: null, | ||||
|         roundTime: true, // whether to round minutes and seconds if step > 1 | ||||
|         smartDays: false // whether days in combo depend on selected month: 31, 30, 28 | ||||
|     }; | ||||
|  | ||||
| }(window.jQuery)); | ||||
							
								
								
									
										6
									
								
								src/inputs/combodate/lib/moment.min.js
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,366 +0,0 @@ | ||||
| /*! | ||||
|  * Datetimepicker for Bootstrap | ||||
|  * | ||||
|  * Copyright 2012 Stefan Petre | ||||
|  * Improvements by Andrew Rowls | ||||
|  * Licensed under the Apache License v2.0 | ||||
|  * http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  */ | ||||
| .datetimepicker { | ||||
|   padding: 4px; | ||||
|   margin-top: 1px; | ||||
|   -webkit-border-radius: 4px; | ||||
|   -moz-border-radius: 4px; | ||||
|   border-radius: 4px; | ||||
|   direction: ltr; | ||||
|   /*.dow { | ||||
| 		border-top: 1px solid #ddd !important; | ||||
| 	}*/ | ||||
|  | ||||
| } | ||||
| .datetimepicker-inline { | ||||
|   width: 220px; | ||||
| } | ||||
| .datetimepicker.datetimepicker-rtl { | ||||
|   direction: rtl; | ||||
| } | ||||
| .datetimepicker.datetimepicker-rtl table tr td span { | ||||
|   float: right; | ||||
| } | ||||
| .datetimepicker-dropdown, .datetimepicker-dropdown-left { | ||||
|   top: 0; | ||||
|   left: 0; | ||||
| } | ||||
| [class*=" datetimepicker-dropdown"]:before { | ||||
|   content: ''; | ||||
|   display: inline-block; | ||||
|   border-left: 7px solid transparent; | ||||
|   border-right: 7px solid transparent; | ||||
|   border-bottom: 7px solid #ccc; | ||||
|   border-bottom-color: rgba(0, 0, 0, 0.2); | ||||
|   position: absolute; | ||||
| } | ||||
| [class*=" datetimepicker-dropdown"]:after { | ||||
|   content: ''; | ||||
|   display: inline-block; | ||||
|   border-left: 6px solid transparent; | ||||
|   border-right: 6px solid transparent; | ||||
|   border-bottom: 6px solid #ffffff; | ||||
|   position: absolute; | ||||
| } | ||||
| [class*=" datetimepicker-dropdown-top"]:before { | ||||
|   content: ''; | ||||
|   display: inline-block; | ||||
|   border-left: 7px solid transparent; | ||||
|   border-right: 7px solid transparent; | ||||
|   border-top: 7px solid #ccc; | ||||
|   border-top-color: rgba(0, 0, 0, 0.2); | ||||
|   border-bottom: 0; | ||||
| } | ||||
| [class*=" datetimepicker-dropdown-top"]:after { | ||||
|   content: ''; | ||||
|   display: inline-block; | ||||
|   border-left: 6px solid transparent; | ||||
|   border-right: 6px solid transparent; | ||||
|   border-top: 6px solid #ffffff; | ||||
|   border-bottom: 0; | ||||
| } | ||||
| .datetimepicker-dropdown-bottom-right:before { | ||||
|   top: -7px; | ||||
|   right: 6px; | ||||
| } | ||||
| .datetimepicker-dropdown-bottom-right:after { | ||||
|   top: -6px; | ||||
|   right: 7px; | ||||
| } | ||||
| .datetimepicker-dropdown-bottom-left:before { | ||||
|   top: -7px; | ||||
|   left: 6px; | ||||
| } | ||||
| .datetimepicker-dropdown-bottom-left:after { | ||||
|   top: -6px; | ||||
|   left: 7px; | ||||
| } | ||||
| .datetimepicker-dropdown-top-right:before { | ||||
|   bottom: -7px; | ||||
|   right: 6px; | ||||
| } | ||||
| .datetimepicker-dropdown-top-right:after { | ||||
|   bottom: -6px; | ||||
|   right: 7px; | ||||
| } | ||||
| .datetimepicker-dropdown-top-left:before { | ||||
|   bottom: -7px; | ||||
|   left: 6px; | ||||
| } | ||||
| .datetimepicker-dropdown-top-left:after { | ||||
|   bottom: -6px; | ||||
|   left: 7px; | ||||
| } | ||||
| .datetimepicker > div { | ||||
|   display: none; | ||||
| } | ||||
| .datetimepicker.minutes div.datetimepicker-minutes { | ||||
|     display: block; | ||||
| } | ||||
| .datetimepicker.hours div.datetimepicker-hours { | ||||
|     display: block; | ||||
| } | ||||
| .datetimepicker.days div.datetimepicker-days { | ||||
|     display: block; | ||||
| } | ||||
| .datetimepicker.months div.datetimepicker-months { | ||||
|   display: block; | ||||
| } | ||||
| .datetimepicker.years div.datetimepicker-years { | ||||
|   display: block; | ||||
| } | ||||
| .datetimepicker table { | ||||
|   margin: 0; | ||||
| } | ||||
| .datetimepicker  td, | ||||
| .datetimepicker th { | ||||
|   text-align: center; | ||||
|   width: 20px; | ||||
|   height: 20px; | ||||
|   -webkit-border-radius: 4px; | ||||
|   -moz-border-radius: 4px; | ||||
|   border-radius: 4px; | ||||
|   border: none; | ||||
| } | ||||
| .table-striped .datetimepicker table tr td, | ||||
| .table-striped .datetimepicker table tr th { | ||||
|   background-color: transparent; | ||||
| } | ||||
| .datetimepicker table tr td.minute:hover { | ||||
|     background: #eeeeee; | ||||
|     cursor: pointer; | ||||
| } | ||||
| .datetimepicker table tr td.hour:hover { | ||||
|     background: #eeeeee; | ||||
|     cursor: pointer; | ||||
| } | ||||
| .datetimepicker table tr td.day:hover { | ||||
|     background: #eeeeee; | ||||
|     cursor: pointer; | ||||
| } | ||||
| .datetimepicker table tr td.old, | ||||
| .datetimepicker table tr td.new { | ||||
|   color: #999999; | ||||
| } | ||||
| .datetimepicker table tr td.disabled, | ||||
| .datetimepicker table tr td.disabled:hover { | ||||
|   background: none; | ||||
|   color: #999999; | ||||
|   cursor: default; | ||||
| } | ||||
| .datetimepicker table tr td.today, | ||||
| .datetimepicker table tr td.today:hover, | ||||
| .datetimepicker table tr td.today.disabled, | ||||
| .datetimepicker table tr td.today.disabled:hover { | ||||
|   background-color: #fde19a; | ||||
|   background-image: -moz-linear-gradient(top, #fdd49a, #fdf59a); | ||||
|   background-image: -ms-linear-gradient(top, #fdd49a, #fdf59a); | ||||
|   background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#fdd49a), to(#fdf59a)); | ||||
|   background-image: -webkit-linear-gradient(top, #fdd49a, #fdf59a); | ||||
|   background-image: -o-linear-gradient(top, #fdd49a, #fdf59a); | ||||
|   background-image: linear-gradient(top, #fdd49a, #fdf59a); | ||||
|   background-repeat: repeat-x; | ||||
|   filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fdd49a', endColorstr='#fdf59a', GradientType=0); | ||||
|   border-color: #fdf59a #fdf59a #fbed50; | ||||
|   border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); | ||||
|   filter: progid:DXImageTransform.Microsoft.gradient(enabled=false); | ||||
| } | ||||
| .datetimepicker table tr td.today:hover, | ||||
| .datetimepicker table tr td.today:hover:hover, | ||||
| .datetimepicker table tr td.today.disabled:hover, | ||||
| .datetimepicker table tr td.today.disabled:hover:hover, | ||||
| .datetimepicker table tr td.today:active, | ||||
| .datetimepicker table tr td.today:hover:active, | ||||
| .datetimepicker table tr td.today.disabled:active, | ||||
| .datetimepicker table tr td.today.disabled:hover:active, | ||||
| .datetimepicker table tr td.today.active, | ||||
| .datetimepicker table tr td.today:hover.active, | ||||
| .datetimepicker table tr td.today.disabled.active, | ||||
| .datetimepicker table tr td.today.disabled:hover.active, | ||||
| .datetimepicker table tr td.today.disabled, | ||||
| .datetimepicker table tr td.today:hover.disabled, | ||||
| .datetimepicker table tr td.today.disabled.disabled, | ||||
| .datetimepicker table tr td.today.disabled:hover.disabled, | ||||
| .datetimepicker table tr td.today[disabled], | ||||
| .datetimepicker table tr td.today:hover[disabled], | ||||
| .datetimepicker table tr td.today.disabled[disabled], | ||||
| .datetimepicker table tr td.today.disabled:hover[disabled] { | ||||
|   background-color: #fdf59a; | ||||
| } | ||||
| .datetimepicker table tr td.today:active, | ||||
| .datetimepicker table tr td.today:hover:active, | ||||
| .datetimepicker table tr td.today.disabled:active, | ||||
| .datetimepicker table tr td.today.disabled:hover:active, | ||||
| .datetimepicker table tr td.today.active, | ||||
| .datetimepicker table tr td.today:hover.active, | ||||
| .datetimepicker table tr td.today.disabled.active, | ||||
| .datetimepicker table tr td.today.disabled:hover.active { | ||||
|   background-color: #fbf069 \9; | ||||
| } | ||||
| .datetimepicker table tr td.active, | ||||
| .datetimepicker table tr td.active:hover, | ||||
| .datetimepicker table tr td.active.disabled, | ||||
| .datetimepicker table tr td.active.disabled:hover { | ||||
|   background-color: #006dcc; | ||||
|   background-image: -moz-linear-gradient(top, #0088cc, #0044cc); | ||||
|   background-image: -ms-linear-gradient(top, #0088cc, #0044cc); | ||||
|   background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#0088cc), to(#0044cc)); | ||||
|   background-image: -webkit-linear-gradient(top, #0088cc, #0044cc); | ||||
|   background-image: -o-linear-gradient(top, #0088cc, #0044cc); | ||||
|   background-image: linear-gradient(top, #0088cc, #0044cc); | ||||
|   background-repeat: repeat-x; | ||||
|   filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#0088cc', endColorstr='#0044cc', GradientType=0); | ||||
|   border-color: #0044cc #0044cc #002a80; | ||||
|   border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); | ||||
|   filter: progid:DXImageTransform.Microsoft.gradient(enabled=false); | ||||
|   color: #fff; | ||||
|   text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); | ||||
| } | ||||
| .datetimepicker table tr td.active:hover, | ||||
| .datetimepicker table tr td.active:hover:hover, | ||||
| .datetimepicker table tr td.active.disabled:hover, | ||||
| .datetimepicker table tr td.active.disabled:hover:hover, | ||||
| .datetimepicker table tr td.active:active, | ||||
| .datetimepicker table tr td.active:hover:active, | ||||
| .datetimepicker table tr td.active.disabled:active, | ||||
| .datetimepicker table tr td.active.disabled:hover:active, | ||||
| .datetimepicker table tr td.active.active, | ||||
| .datetimepicker table tr td.active:hover.active, | ||||
| .datetimepicker table tr td.active.disabled.active, | ||||
| .datetimepicker table tr td.active.disabled:hover.active, | ||||
| .datetimepicker table tr td.active.disabled, | ||||
| .datetimepicker table tr td.active:hover.disabled, | ||||
| .datetimepicker table tr td.active.disabled.disabled, | ||||
| .datetimepicker table tr td.active.disabled:hover.disabled, | ||||
| .datetimepicker table tr td.active[disabled], | ||||
| .datetimepicker table tr td.active:hover[disabled], | ||||
| .datetimepicker table tr td.active.disabled[disabled], | ||||
| .datetimepicker table tr td.active.disabled:hover[disabled] { | ||||
|   background-color: #0044cc; | ||||
| } | ||||
| .datetimepicker table tr td.active:active, | ||||
| .datetimepicker table tr td.active:hover:active, | ||||
| .datetimepicker table tr td.active.disabled:active, | ||||
| .datetimepicker table tr td.active.disabled:hover:active, | ||||
| .datetimepicker table tr td.active.active, | ||||
| .datetimepicker table tr td.active:hover.active, | ||||
| .datetimepicker table tr td.active.disabled.active, | ||||
| .datetimepicker table tr td.active.disabled:hover.active { | ||||
|   background-color: #003399 \9; | ||||
| } | ||||
| .datetimepicker table tr td span { | ||||
|   display: block; | ||||
|   width: 23%; | ||||
|   height: 54px; | ||||
|   line-height: 54px; | ||||
|   float: left; | ||||
|   margin: 1%; | ||||
|   cursor: pointer; | ||||
|   -webkit-border-radius: 4px; | ||||
|   -moz-border-radius: 4px; | ||||
|   border-radius: 4px; | ||||
| } | ||||
| .datetimepicker .datetimepicker-hours span { | ||||
|   height: 26px; | ||||
|   line-height: 26px; | ||||
| } | ||||
| .datetimepicker .datetimepicker-hours table tr td span.hour_am, | ||||
| .datetimepicker .datetimepicker-hours table tr td span.hour_pm { | ||||
|   width: 14.6%; | ||||
| } | ||||
| .datetimepicker .datetimepicker-hours fieldset legend, | ||||
| .datetimepicker .datetimepicker-minutes fieldset legend { | ||||
|   margin-bottom: inherit; | ||||
|   line-height: 30px; | ||||
| } | ||||
| .datetimepicker .datetimepicker-minutes span { | ||||
|   height: 26px; | ||||
|   line-height: 26px; | ||||
| } | ||||
| .datetimepicker table tr td span:hover { | ||||
|   background: #eeeeee; | ||||
| } | ||||
| .datetimepicker table tr td span.disabled, | ||||
| .datetimepicker table tr td span.disabled:hover { | ||||
|   background: none; | ||||
|   color: #999999; | ||||
|   cursor: default; | ||||
| } | ||||
| .datetimepicker table tr td span.active, | ||||
| .datetimepicker table tr td span.active:hover, | ||||
| .datetimepicker table tr td span.active.disabled, | ||||
| .datetimepicker table tr td span.active.disabled:hover { | ||||
|   background-color: #006dcc; | ||||
|   background-image: -moz-linear-gradient(top, #0088cc, #0044cc); | ||||
|   background-image: -ms-linear-gradient(top, #0088cc, #0044cc); | ||||
|   background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#0088cc), to(#0044cc)); | ||||
|   background-image: -webkit-linear-gradient(top, #0088cc, #0044cc); | ||||
|   background-image: -o-linear-gradient(top, #0088cc, #0044cc); | ||||
|   background-image: linear-gradient(top, #0088cc, #0044cc); | ||||
|   background-repeat: repeat-x; | ||||
|   filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#0088cc', endColorstr='#0044cc', GradientType=0); | ||||
|   border-color: #0044cc #0044cc #002a80; | ||||
|   border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); | ||||
|   filter: progid:DXImageTransform.Microsoft.gradient(enabled=false); | ||||
|   color: #fff; | ||||
|   text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); | ||||
| } | ||||
| .datetimepicker table tr td span.active:hover, | ||||
| .datetimepicker table tr td span.active:hover:hover, | ||||
| .datetimepicker table tr td span.active.disabled:hover, | ||||
| .datetimepicker table tr td span.active.disabled:hover:hover, | ||||
| .datetimepicker table tr td span.active:active, | ||||
| .datetimepicker table tr td span.active:hover:active, | ||||
| .datetimepicker table tr td span.active.disabled:active, | ||||
| .datetimepicker table tr td span.active.disabled:hover:active, | ||||
| .datetimepicker table tr td span.active.active, | ||||
| .datetimepicker table tr td span.active:hover.active, | ||||
| .datetimepicker table tr td span.active.disabled.active, | ||||
| .datetimepicker table tr td span.active.disabled:hover.active, | ||||
| .datetimepicker table tr td span.active.disabled, | ||||
| .datetimepicker table tr td span.active:hover.disabled, | ||||
| .datetimepicker table tr td span.active.disabled.disabled, | ||||
| .datetimepicker table tr td span.active.disabled:hover.disabled, | ||||
| .datetimepicker table tr td span.active[disabled], | ||||
| .datetimepicker table tr td span.active:hover[disabled], | ||||
| .datetimepicker table tr td span.active.disabled[disabled], | ||||
| .datetimepicker table tr td span.active.disabled:hover[disabled] { | ||||
|   background-color: #0044cc; | ||||
| } | ||||
| .datetimepicker table tr td span.active:active, | ||||
| .datetimepicker table tr td span.active:hover:active, | ||||
| .datetimepicker table tr td span.active.disabled:active, | ||||
| .datetimepicker table tr td span.active.disabled:hover:active, | ||||
| .datetimepicker table tr td span.active.active, | ||||
| .datetimepicker table tr td span.active:hover.active, | ||||
| .datetimepicker table tr td span.active.disabled.active, | ||||
| .datetimepicker table tr td span.active.disabled:hover.active { | ||||
|   background-color: #003399 \9; | ||||
| } | ||||
| .datetimepicker table tr td span.old { | ||||
|   color: #999999; | ||||
| } | ||||
| .datetimepicker th.switch { | ||||
|   width: 145px; | ||||
| } | ||||
| .datetimepicker thead tr:first-child th, | ||||
| .datetimepicker tfoot tr:first-child th { | ||||
|   cursor: pointer; | ||||
| } | ||||
| .datetimepicker thead tr:first-child th:hover, | ||||
| .datetimepicker tfoot tr:first-child th:hover { | ||||
|   background: #eeeeee; | ||||
| } | ||||
| .input-append.date .add-on i, | ||||
| .input-prepend.date .add-on i { | ||||
|   cursor: pointer; | ||||
|   width: 14px; | ||||
|   height: 14px; | ||||
| } | ||||
| @@ -1,244 +0,0 @@ | ||||
| /** | ||||
| Bootstrap-datetimepicker.   | ||||
| Based on [smalot bootstrap-datetimepicker plugin](https://github.com/smalot/bootstrap-datetimepicker).  | ||||
| Before usage you should manually include dependent js and css: | ||||
|  | ||||
|     <link href="css/datetimepicker.css" rel="stylesheet" type="text/css"></link>  | ||||
|     <script src="js/bootstrap-datetimepicker.js"></script> | ||||
|  | ||||
| For **i18n** you should include js file from here: https://github.com/smalot/bootstrap-datetimepicker/tree/master/js/locales | ||||
| and set `language` option.   | ||||
|  | ||||
| @class datetime | ||||
| @extends abstractinput | ||||
| @final | ||||
| @since 1.4.4 | ||||
| @example | ||||
| <a href="#" id="last_seen" data-type="datetime" data-pk="1" data-url="/post" title="Select date & time">15/03/2013 12:45</a> | ||||
| <script> | ||||
| $(function(){ | ||||
|     $('#last_seen').editable({ | ||||
|         format: 'yyyy-mm-dd hh:ii',     | ||||
|         viewformat: 'dd/mm/yyyy hh:ii',     | ||||
|         datetimepicker: { | ||||
|                 weekStart: 1 | ||||
|            } | ||||
|         } | ||||
|     }); | ||||
| }); | ||||
| </script> | ||||
| **/ | ||||
| (function ($) { | ||||
|     "use strict"; | ||||
|  | ||||
|     var DateTime = function (options) { | ||||
|         this.init('datetime', options, DateTime.defaults); | ||||
|         this.initPicker(options, DateTime.defaults); | ||||
|     }; | ||||
|  | ||||
|     $.fn.editableutils.inherit(DateTime, $.fn.editabletypes.abstractinput); | ||||
|  | ||||
|     $.extend(DateTime.prototype, { | ||||
|         initPicker: function(options, defaults) { | ||||
|             //'format' is set directly from settings or data-* attributes | ||||
|  | ||||
|             //by default viewformat equals to format | ||||
|             if(!this.options.viewformat) { | ||||
|                 this.options.viewformat = this.options.format; | ||||
|             } | ||||
|              | ||||
|             //try parse datetimepicker config defined as json string in data-datetimepicker | ||||
|             options.datetimepicker = $.fn.editableutils.tryParseJson(options.datetimepicker, true); | ||||
|  | ||||
|             //overriding datetimepicker config (as by default jQuery extend() is not recursive) | ||||
|             //since 1.4 datetimepicker internally uses viewformat instead of format. Format is for submit only | ||||
|             this.options.datetimepicker = $.extend({}, defaults.datetimepicker, options.datetimepicker, { | ||||
|                 format: this.options.viewformat | ||||
|             }); | ||||
|  | ||||
|             //language | ||||
|             this.options.datetimepicker.language = this.options.datetimepicker.language || 'en';  | ||||
|  | ||||
|             //store DPglobal | ||||
|             this.dpg = $.fn.datetimepicker.DPGlobal;  | ||||
|  | ||||
|             //store parsed formats | ||||
|             this.parsedFormat = this.dpg.parseFormat(this.options.format, this.options.formatType); | ||||
|             this.parsedViewFormat = this.dpg.parseFormat(this.options.viewformat, this.options.formatType); | ||||
|         }, | ||||
|  | ||||
|         render: function () { | ||||
|             this.$input.datetimepicker(this.options.datetimepicker); | ||||
|  | ||||
|             //adjust container position when viewMode changes | ||||
|             //see https://github.com/smalot/bootstrap-datetimepicker/pull/80 | ||||
|             this.$input.on('changeMode', function(e) { | ||||
|                 var f = $(this).closest('form').parent(); | ||||
|                 //timeout here, otherwise container changes position before form has new size | ||||
|                 setTimeout(function(){ | ||||
|                     f.triggerHandler('resize'); | ||||
|                 }, 0); | ||||
|             }); | ||||
|  | ||||
|             //"clear" link | ||||
|             if(this.options.clear) { | ||||
|                 this.$clear = $('<a href="#"></a>').html(this.options.clear).click($.proxy(function(e){ | ||||
|                     e.preventDefault(); | ||||
|                     e.stopPropagation(); | ||||
|                     this.clear(); | ||||
|                 }, this)); | ||||
|  | ||||
|                 this.$tpl.parent().append($('<div class="editable-clear">').append(this.$clear));   | ||||
|             } | ||||
|         }, | ||||
|  | ||||
|         value2html: function(value, element) { | ||||
|             //formatDate works with UTCDate! | ||||
|             var text = value ? this.dpg.formatDate(this.toUTC(value), this.parsedViewFormat, this.options.datetimepicker.language, this.options.formatType) : ''; | ||||
|             if(element) { | ||||
|                 DateTime.superclass.value2html.call(this, text, element); | ||||
|             } else { | ||||
|                 return text; | ||||
|             } | ||||
|         }, | ||||
|  | ||||
|         html2value: function(html) { | ||||
|             //parseDate return utc date! | ||||
|             var value = this.parseDate(html, this.parsedViewFormat);  | ||||
|             return value ? this.fromUTC(value) : null; | ||||
|         }, | ||||
|  | ||||
|         value2str: function(value) { | ||||
|             //formatDate works with UTCDate! | ||||
|             return value ? this.dpg.formatDate(this.toUTC(value), this.parsedFormat, this.options.datetimepicker.language, this.options.formatType) : ''; | ||||
|        }, | ||||
|  | ||||
|        str2value: function(str) { | ||||
|            //parseDate return utc date! | ||||
|            var value = this.parseDate(str, this.parsedFormat); | ||||
|            return value ? this.fromUTC(value) : null; | ||||
|        }, | ||||
|  | ||||
|        value2submit: function(value) { | ||||
|            return this.value2str(value); | ||||
|        }, | ||||
|  | ||||
|        value2input: function(value) { | ||||
|            if(value) { | ||||
|              this.$input.data('datetimepicker').setDate(value); | ||||
|            } | ||||
|        }, | ||||
|  | ||||
|        input2value: function() {  | ||||
|            //date may be cleared, in that case getDate() triggers error | ||||
|            var dt = this.$input.data('datetimepicker'); | ||||
|            return dt.date ? dt.getDate() : null; | ||||
|        }, | ||||
|  | ||||
|        activate: function() { | ||||
|        }, | ||||
|  | ||||
|        clear: function() { | ||||
|           this.$input.data('datetimepicker').date = null; | ||||
|           this.$input.find('.active').removeClass('active'); | ||||
|           if(!this.options.showbuttons) { | ||||
|              this.$input.closest('form').submit();  | ||||
|           }           | ||||
|        }, | ||||
|  | ||||
|        autosubmit: function() { | ||||
|            this.$input.on('mouseup', '.minute', function(e){ | ||||
|                var $form = $(this).closest('form'); | ||||
|                setTimeout(function() { | ||||
|                    $form.submit(); | ||||
|                }, 200); | ||||
|            }); | ||||
|        }, | ||||
|  | ||||
|        //convert date from local to utc | ||||
|        toUTC: function(value) { | ||||
|          return value ? new Date(value.valueOf() - value.getTimezoneOffset() * 60000) : value;   | ||||
|        }, | ||||
|  | ||||
|        //convert date from utc to local | ||||
|        fromUTC: function(value) { | ||||
|          return value ? new Date(value.valueOf() + value.getTimezoneOffset() * 60000) : value;   | ||||
|        }, | ||||
|  | ||||
|        /* | ||||
|         For incorrect date bootstrap-datetimepicker returns current date that is not suitable | ||||
|         for datetimefield. | ||||
|         This function returns null for incorrect date.   | ||||
|        */ | ||||
|        parseDate: function(str, format) { | ||||
|            var date = null, formattedBack; | ||||
|            if(str) { | ||||
|                date = this.dpg.parseDate(str, format, this.options.datetimepicker.language, this.options.formatType); | ||||
|                if(typeof str === 'string') { | ||||
|                    formattedBack = this.dpg.formatDate(date, format, this.options.datetimepicker.language, this.options.formatType); | ||||
|                    if(str !== formattedBack) { | ||||
|                        date = null; | ||||
|                    }  | ||||
|                } | ||||
|            } | ||||
|            return date; | ||||
|        } | ||||
|  | ||||
|     }); | ||||
|  | ||||
|     DateTime.defaults = $.extend({}, $.fn.editabletypes.abstractinput.defaults, { | ||||
|         /** | ||||
|         @property tpl  | ||||
|         @default <div></div> | ||||
|         **/          | ||||
|         tpl:'<div class="editable-date well"></div>', | ||||
|         /** | ||||
|         @property inputclass  | ||||
|         @default null | ||||
|         **/ | ||||
|         inputclass: null, | ||||
|         /** | ||||
|         Format used for sending value to server. Also applied when converting date from <code>data-value</code> attribute.<br> | ||||
|         Possible tokens are: <code>d, dd, m, mm, yy, yyyy, h, i</code>   | ||||
|          | ||||
|         @property format  | ||||
|         @type string | ||||
|         @default yyyy-mm-dd hh:ii | ||||
|         **/          | ||||
|         format:'yyyy-mm-dd hh:ii', | ||||
|         formatType:'standard', | ||||
|         /** | ||||
|         Format used for displaying date. Also applied when converting date from element's text on init.    | ||||
|         If not specified equals to <code>format</code> | ||||
|          | ||||
|         @property viewformat  | ||||
|         @type string | ||||
|         @default null | ||||
|         **/ | ||||
|         viewformat: null, | ||||
|         /** | ||||
|         Configuration of datetimepicker. | ||||
|         Full list of options: https://github.com/smalot/bootstrap-datetimepicker | ||||
|  | ||||
|         @property datetimepicker  | ||||
|         @type object | ||||
|         @default { } | ||||
|         **/ | ||||
|         datetimepicker:{ | ||||
|             todayHighlight: false, | ||||
|             autoclose: false | ||||
|         }, | ||||
|         /** | ||||
|         Text shown as clear date button.  | ||||
|         If <code>false</code> clear button will not be rendered. | ||||
|  | ||||
|         @property clear  | ||||
|         @type boolean|string | ||||
|         @default 'x clear' | ||||
|         **/ | ||||
|         clear: '× clear' | ||||
|     }); | ||||
|  | ||||
|     $.fn.editabletypes.datetime = DateTime; | ||||
|  | ||||
| }(window.jQuery)); | ||||
| @@ -1,77 +0,0 @@ | ||||
| /** | ||||
| Bootstrap datetimefield input - datetime input for inline mode. | ||||
| Shows normal <input type="text"> and binds popup datetimepicker.   | ||||
| Automatically shown in inline mode. | ||||
|  | ||||
| @class datetimefield | ||||
| @extends datetime | ||||
|  | ||||
| **/ | ||||
| (function ($) { | ||||
|     "use strict"; | ||||
|      | ||||
|     var DateTimeField = function (options) { | ||||
|         this.init('datetimefield', options, DateTimeField.defaults); | ||||
|         this.initPicker(options, DateTimeField.defaults); | ||||
|     }; | ||||
|  | ||||
|     $.fn.editableutils.inherit(DateTimeField, $.fn.editabletypes.datetime); | ||||
|      | ||||
|     $.extend(DateTimeField.prototype, { | ||||
|         render: function () { | ||||
|             this.$input = this.$tpl.find('input'); | ||||
|             this.setClass(); | ||||
|             this.setAttr('placeholder'); | ||||
|              | ||||
|             this.$tpl.datetimepicker(this.options.datetimepicker); | ||||
|              | ||||
|             //need to disable original event handlers | ||||
|             this.$input.off('focus keydown'); | ||||
|              | ||||
|             //update value of datepicker | ||||
|             this.$input.keyup($.proxy(function(){ | ||||
|                this.$tpl.removeData('date'); | ||||
|                this.$tpl.datetimepicker('update'); | ||||
|             }, this)); | ||||
|              | ||||
|         },    | ||||
|        | ||||
|        value2input: function(value) { | ||||
|            this.$input.val(this.value2html(value)); | ||||
|            this.$tpl.datetimepicker('update'); | ||||
|        }, | ||||
|          | ||||
|        input2value: function() {  | ||||
|            return this.html2value(this.$input.val()); | ||||
|        },               | ||||
|          | ||||
|        activate: function() { | ||||
|            $.fn.editabletypes.text.prototype.activate.call(this); | ||||
|        }, | ||||
|         | ||||
|        autosubmit: function() { | ||||
|          //reset autosubmit to empty   | ||||
|        } | ||||
|     }); | ||||
|      | ||||
|     DateTimeField.defaults = $.extend({}, $.fn.editabletypes.datetime.defaults, { | ||||
|         /** | ||||
|         @property tpl  | ||||
|         **/          | ||||
|         tpl:'<div class="input-append date"><input type="text"/><span class="add-on"><i class="icon-th"></i></span></div>', | ||||
|         /** | ||||
|         @property inputclass  | ||||
|         @default 'input-medium' | ||||
|         **/          | ||||
|         inputclass: 'input-medium', | ||||
|          | ||||
|         /* datetimepicker config */ | ||||
|         datetimepicker:{ | ||||
|             todayHighlight: false, | ||||
|             autoclose: true | ||||
|         } | ||||
|     }); | ||||
|      | ||||
|     $.fn.editabletypes.datetimefield = DateTimeField; | ||||
|  | ||||
| }(window.jQuery)); | ||||
| @@ -1,203 +0,0 @@ | ||||
| /** | ||||
| jQuery UI Datepicker.   | ||||
| Description and examples: http://jqueryui.com/datepicker.    | ||||
| This input is also accessible as **date** type. Do not use it together with __bootstrap-datepicker__ as both apply <code>$().datepicker()</code> method.   | ||||
| For **i18n** you should include js file from here: https://github.com/jquery/jquery-ui/tree/master/ui/i18n. | ||||
|  | ||||
| @class dateui | ||||
| @extends abstractinput | ||||
| @final | ||||
| @example | ||||
| <a href="#" id="dob" data-type="date" data-pk="1" data-url="/post" data-title="Select date">15/05/1984</a> | ||||
| <script> | ||||
| $(function(){ | ||||
|     $('#dob').editable({ | ||||
|         format: 'yyyy-mm-dd',     | ||||
|         viewformat: 'dd/mm/yyyy',     | ||||
|         datepicker: { | ||||
|                 firstDay: 1 | ||||
|            } | ||||
|         } | ||||
|     }); | ||||
| }); | ||||
| </script> | ||||
| **/ | ||||
| (function ($) { | ||||
|     "use strict"; | ||||
|      | ||||
|     var DateUI = function (options) { | ||||
|         this.init('dateui', options, DateUI.defaults); | ||||
|         this.initPicker(options, DateUI.defaults); | ||||
|     }; | ||||
|  | ||||
|     $.fn.editableutils.inherit(DateUI, $.fn.editabletypes.abstractinput);     | ||||
|      | ||||
|     $.extend(DateUI.prototype, { | ||||
|         initPicker: function(options, defaults) { | ||||
|             //by default viewformat equals to format | ||||
|             if(!this.options.viewformat) { | ||||
|                 this.options.viewformat = this.options.format; | ||||
|             } | ||||
|              | ||||
|             //correct formats: replace yyyy with yy (for compatibility with bootstrap datepicker) | ||||
|             this.options.viewformat = this.options.viewformat.replace('yyyy', 'yy');  | ||||
|             this.options.format = this.options.format.replace('yyyy', 'yy');              | ||||
|              | ||||
|             //overriding datepicker config (as by default jQuery extend() is not recursive) | ||||
|             //since 1.4 datepicker internally uses viewformat instead of format. Format is for submit only | ||||
|             this.options.datepicker = $.extend({}, defaults.datepicker, options.datepicker, { | ||||
|                 dateFormat: this.options.viewformat | ||||
|             });                         | ||||
|         }, | ||||
|          | ||||
|         render: function () { | ||||
|             this.$input.datepicker(this.options.datepicker); | ||||
|              | ||||
|             //"clear" link | ||||
|             if(this.options.clear) { | ||||
|                 this.$clear = $('<a href="#"></a>').html(this.options.clear).click($.proxy(function(e){ | ||||
|                     e.preventDefault(); | ||||
|                     e.stopPropagation(); | ||||
|                     this.clear(); | ||||
|                 }, this)); | ||||
|                  | ||||
|                 this.$tpl.parent().append($('<div class="editable-clear">').append(this.$clear));   | ||||
|             }               | ||||
|         }, | ||||
|  | ||||
|         value2html: function(value, element) { | ||||
|             var text = $.datepicker.formatDate(this.options.viewformat, value); | ||||
|             DateUI.superclass.value2html.call(this, text, element);  | ||||
|         }, | ||||
|  | ||||
|         html2value: function(html) { | ||||
|            if(typeof html !== 'string') { | ||||
|                return html; | ||||
|            }             | ||||
|              | ||||
|            //if string does not match format, UI datepicker throws exception | ||||
|            var d; | ||||
|            try { | ||||
|               d = $.datepicker.parseDate(this.options.viewformat, html); | ||||
|            } catch(e) {} | ||||
|             | ||||
|            return d;             | ||||
|         },    | ||||
|          | ||||
|         value2str: function(value) { | ||||
|            return $.datepicker.formatDate(this.options.format, value); | ||||
|        },  | ||||
|         | ||||
|        str2value: function(str) { | ||||
|            if(typeof str !== 'string') { | ||||
|                return str; | ||||
|            } | ||||
|             | ||||
|            //if string does not match format, UI datepicker throws exception | ||||
|            var d; | ||||
|            try { | ||||
|               d = $.datepicker.parseDate(this.options.format, str); | ||||
|            } catch(e) {} | ||||
|             | ||||
|            return d; | ||||
|        },  | ||||
|         | ||||
|        value2submit: function(value) {  | ||||
|            return this.value2str(value); | ||||
|        },                      | ||||
|  | ||||
|        value2input: function(value) { | ||||
|            this.$input.datepicker('setDate', value); | ||||
|        }, | ||||
|          | ||||
|        input2value: function() {  | ||||
|            return this.$input.datepicker('getDate'); | ||||
|        },        | ||||
|         | ||||
|        activate: function() { | ||||
|        }, | ||||
|         | ||||
|        clear:  function() { | ||||
|            this.$input.datepicker('setDate', null); | ||||
|            // submit automatically whe that are no buttons | ||||
|            if(this.isAutosubmit) { | ||||
|               this.submit(); | ||||
|            } | ||||
|        }, | ||||
|         | ||||
|        autosubmit: function() { | ||||
|            this.isAutosubmit = true;  | ||||
|            this.$input.on('mouseup', 'table.ui-datepicker-calendar a.ui-state-default', $.proxy(this.submit, this)); | ||||
|        }, | ||||
|  | ||||
|        submit: function() { | ||||
|            var $form = this.$input.closest('form'); | ||||
|            setTimeout(function() { | ||||
|                $form.submit(); | ||||
|            }, 200); | ||||
|        } | ||||
|  | ||||
|     }); | ||||
|      | ||||
|     DateUI.defaults = $.extend({}, $.fn.editabletypes.abstractinput.defaults, { | ||||
|         /** | ||||
|         @property tpl  | ||||
|         @default <div></div> | ||||
|         **/          | ||||
|         tpl:'<div class="editable-date"></div>', | ||||
|         /** | ||||
|         @property inputclass  | ||||
|         @default null | ||||
|         **/          | ||||
|         inputclass: null, | ||||
|         /** | ||||
|         Format used for sending value to server. Also applied when converting date from <code>data-value</code> attribute.<br> | ||||
|         Full list of tokens: http://docs.jquery.com/UI/Datepicker/formatDate | ||||
|          | ||||
|         @property format  | ||||
|         @type string | ||||
|         @default yyyy-mm-dd | ||||
|         **/           | ||||
|         format:'yyyy-mm-dd',  | ||||
|         /** | ||||
|         Format used for displaying date. Also applied when converting date from element's text on init.     | ||||
|         If not specified equals to <code>format</code> | ||||
|          | ||||
|         @property viewformat  | ||||
|         @type string | ||||
|         @default null | ||||
|         **/           | ||||
|         viewformat: null, | ||||
|          | ||||
|         /** | ||||
|         Configuration of datepicker. | ||||
|         Full list of options: http://api.jqueryui.com/datepicker | ||||
|          | ||||
|         @property datepicker  | ||||
|         @type object | ||||
|         @default { | ||||
|            firstDay: 0,  | ||||
|            changeYear: true,  | ||||
|            changeMonth: true | ||||
|         } | ||||
|         **/ | ||||
|         datepicker: { | ||||
|             firstDay: 0, | ||||
|             changeYear: true, | ||||
|             changeMonth: true, | ||||
|             showOtherMonths: true | ||||
|         }, | ||||
|         /** | ||||
|         Text shown as clear date button.  | ||||
|         If <code>false</code> clear button will not be rendered. | ||||
|          | ||||
|         @property clear  | ||||
|         @type boolean|string | ||||
|         @default 'x clear'          | ||||
|         **/ | ||||
|         clear: '× clear'         | ||||
|     });    | ||||
|  | ||||
|     $.fn.editabletypes.dateui = DateUI; | ||||
|  | ||||
| }(window.jQuery)); | ||||
| @@ -1,78 +0,0 @@ | ||||
| /** | ||||
| jQuery UI datefield input - modification for inline mode. | ||||
| Shows normal <input type="text"> and binds popup datepicker.   | ||||
| Automatically shown in inline mode. | ||||
|  | ||||
| @class dateuifield | ||||
| @extends dateui | ||||
|  | ||||
| @since 1.4.0 | ||||
| **/ | ||||
| (function ($) { | ||||
|     "use strict"; | ||||
|      | ||||
|     var DateUIField = function (options) { | ||||
|         this.init('dateuifield', options, DateUIField.defaults); | ||||
|         this.initPicker(options, DateUIField.defaults); | ||||
|     }; | ||||
|  | ||||
|     $.fn.editableutils.inherit(DateUIField, $.fn.editabletypes.dateui);     | ||||
|      | ||||
|     $.extend(DateUIField.prototype, { | ||||
|        render: function () { | ||||
|           //  this.$input = this.$tpl.find('input');  | ||||
|             this.$input.datepicker(this.options.datepicker); | ||||
|             $.fn.editabletypes.text.prototype.renderClear.call(this); | ||||
|        }, | ||||
|        | ||||
|        value2input: function(value) { | ||||
|            this.$input.val($.datepicker.formatDate(this.options.viewformat, value)); | ||||
|        }, | ||||
|          | ||||
|        input2value: function() {  | ||||
|            return this.html2value(this.$input.val()); | ||||
|        },         | ||||
|          | ||||
|        activate: function() { | ||||
|            $.fn.editabletypes.text.prototype.activate.call(this); | ||||
|        }, | ||||
|         | ||||
|        toggleClear: function() { | ||||
|            $.fn.editabletypes.text.prototype.toggleClear.call(this); | ||||
|        }, | ||||
|         | ||||
|        autosubmit: function() { | ||||
|           //reset autosubmit to empty   | ||||
|        } | ||||
|     }); | ||||
|      | ||||
|     DateUIField.defaults = $.extend({}, $.fn.editabletypes.dateui.defaults, { | ||||
|         /** | ||||
|         @property tpl  | ||||
|         @default <input type="text"> | ||||
|         **/          | ||||
|         tpl: '<input type="text"/>', | ||||
|         /** | ||||
|         @property inputclass  | ||||
|         @default null | ||||
|         **/          | ||||
|         inputclass: null, | ||||
|          | ||||
|         /* datepicker config */ | ||||
|         datepicker: { | ||||
|             showOn: "button", | ||||
|             buttonImage: "http://jqueryui.com/resources/demos/datepicker/images/calendar.gif", | ||||
|             buttonImageOnly: true,             | ||||
|             firstDay: 0, | ||||
|             changeYear: true, | ||||
|             changeMonth: true, | ||||
|             showOtherMonths: true | ||||
|         }, | ||||
|          | ||||
|         /* disable clear link */  | ||||
|         clear: false | ||||
|     }); | ||||
|      | ||||
|     $.fn.editabletypes.dateuifield = DateUIField; | ||||
|  | ||||
| }(window.jQuery)); | ||||
| Before Width: | Height: | Size: 1.7 KiB | 
| Before Width: | Height: | Size: 212 B | 
| Before Width: | Height: | Size: 206 B | 
| Before Width: | Height: | Size: 336 B | 
| Before Width: | Height: | Size: 341 B | 
| Before Width: | Height: | Size: 332 B | 
| Before Width: | Height: | Size: 5.7 KiB | 
| Before Width: | Height: | Size: 333 B | 
| Before Width: | Height: | Size: 292 B | 
| Before Width: | Height: | Size: 4.4 KiB | 
| Before Width: | Height: | Size: 4.4 KiB | 
| Before Width: | Height: | Size: 4.4 KiB | 
| Before Width: | Height: | Size: 4.4 KiB | 
| Before Width: | Height: | Size: 4.4 KiB | 
| Before Width: | Height: | Size: 4.4 KiB | 
| Before Width: | Height: | Size: 4.4 KiB | 
| @@ -1,649 +0,0 @@ | ||||
| /*! jQuery UI - v1.10.1 - 2013-03-08 | ||||
| * http://jqueryui.com | ||||
| * Includes: jquery.ui.core.css, jquery.ui.datepicker.css | ||||
| * To view and modify this theme, visit http://jqueryui.com/themeroller/?ffDefault=Lucida%20Grande%2CLucida%20Sans%2CArial%2Csans-serif&fwDefault=bold&fsDefault=1.1em&cornerRadius=5px&bgColorHeader=5c9ccc&bgTextureHeader=gloss_wave&bgImgOpacityHeader=55&borderColorHeader=4297d7&fcHeader=ffffff&iconColorHeader=d8e7f3&bgColorContent=fcfdfd&bgTextureContent=inset_hard&bgImgOpacityContent=100&borderColorContent=a6c9e2&fcContent=222222&iconColorContent=469bdd&bgColorDefault=dfeffc&bgTextureDefault=glass&bgImgOpacityDefault=85&borderColorDefault=c5dbec&fcDefault=2e6e9e&iconColorDefault=6da8d5&bgColorHover=d0e5f5&bgTextureHover=glass&bgImgOpacityHover=75&borderColorHover=79b7e7&fcHover=1d5987&iconColorHover=217bc0&bgColorActive=f5f8f9&bgTextureActive=inset_hard&bgImgOpacityActive=100&borderColorActive=79b7e7&fcActive=e17009&iconColorActive=f9bd01&bgColorHighlight=fbec88&bgTextureHighlight=flat&bgImgOpacityHighlight=55&borderColorHighlight=fad42e&fcHighlight=363636&iconColorHighlight=2e83ff&bgColorError=fef1ec&bgTextureError=glass&bgImgOpacityError=95&borderColorError=cd0a0a&fcError=cd0a0a&iconColorError=cd0a0a&bgColorOverlay=aaaaaa&bgTextureOverlay=flat&bgImgOpacityOverlay=0&opacityOverlay=30&bgColorShadow=aaaaaa&bgTextureShadow=flat&bgImgOpacityShadow=0&opacityShadow=30&thicknessShadow=8px&offsetTopShadow=-8px&offsetLeftShadow=-8px&cornerRadiusShadow=8px | ||||
| * Copyright (c) 2013 jQuery Foundation and other contributors Licensed MIT */ | ||||
|  | ||||
| /* Layout helpers | ||||
| ----------------------------------*/ | ||||
| .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; | ||||
| 	border-collapse: collapse; | ||||
| } | ||||
| .ui-helper-clearfix:after { | ||||
| 	clear: both; | ||||
| } | ||||
| .ui-helper-clearfix { | ||||
| 	min-height: 0; /* support: IE7 */ | ||||
| } | ||||
| .ui-helper-zfix { | ||||
| 	width: 100%; | ||||
| 	height: 100%; | ||||
| 	top: 0; | ||||
| 	left: 0; | ||||
| 	position: absolute; | ||||
| 	opacity: 0; | ||||
| 	filter:Alpha(Opacity=0); | ||||
| } | ||||
|  | ||||
| .ui-front { | ||||
| 	z-index: 100; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Interaction Cues | ||||
| ----------------------------------*/ | ||||
| .ui-state-disabled { | ||||
| 	cursor: default !important; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Icons | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* states and images */ | ||||
| .ui-icon { | ||||
| 	display: block; | ||||
| 	text-indent: -99999px; | ||||
| 	overflow: hidden; | ||||
| 	background-repeat: no-repeat; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Misc visuals | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* Overlays */ | ||||
| .ui-widget-overlay { | ||||
| 	position: fixed; | ||||
| 	top: 0; | ||||
| 	left: 0; | ||||
| 	width: 100%; | ||||
| 	height: 100%; | ||||
| } | ||||
| .ui-datepicker { | ||||
| 	width: 17em; | ||||
| 	padding: .2em .2em 0; | ||||
| 	display: none; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-header { | ||||
| 	position: relative; | ||||
| 	padding: .2em 0; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev, | ||||
| .ui-datepicker .ui-datepicker-next { | ||||
| 	position: absolute; | ||||
| 	top: 2px; | ||||
| 	width: 1.8em; | ||||
| 	height: 1.8em; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev-hover, | ||||
| .ui-datepicker .ui-datepicker-next-hover { | ||||
| 	top: 1px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev { | ||||
| 	left: 2px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-next { | ||||
| 	right: 2px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev-hover { | ||||
| 	left: 1px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-next-hover { | ||||
| 	right: 1px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev span, | ||||
| .ui-datepicker .ui-datepicker-next span { | ||||
| 	display: block; | ||||
| 	position: absolute; | ||||
| 	left: 50%; | ||||
| 	margin-left: -8px; | ||||
| 	top: 50%; | ||||
| 	margin-top: -8px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-title { | ||||
| 	margin: 0 2.3em; | ||||
| 	line-height: 1.8em; | ||||
| 	text-align: center; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-title select { | ||||
| 	font-size: 1em; | ||||
| 	margin: 1px 0; | ||||
| } | ||||
| .ui-datepicker select.ui-datepicker-month-year { | ||||
| 	width: 100%; | ||||
| } | ||||
| .ui-datepicker select.ui-datepicker-month, | ||||
| .ui-datepicker select.ui-datepicker-year { | ||||
| 	width: 49%; | ||||
| } | ||||
| .ui-datepicker table { | ||||
| 	width: 100%; | ||||
| 	font-size: .9em; | ||||
| 	border-collapse: collapse; | ||||
| 	margin: 0 0 .4em; | ||||
| } | ||||
| .ui-datepicker th { | ||||
| 	padding: .7em .3em; | ||||
| 	text-align: center; | ||||
| 	font-weight: bold; | ||||
| 	border: 0; | ||||
| } | ||||
| .ui-datepicker td { | ||||
| 	border: 0; | ||||
| 	padding: 1px; | ||||
| } | ||||
| .ui-datepicker td span, | ||||
| .ui-datepicker td a { | ||||
| 	display: block; | ||||
| 	padding: .2em; | ||||
| 	text-align: right; | ||||
| 	text-decoration: none; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-buttonpane { | ||||
| 	background-image: none; | ||||
| 	margin: .7em 0 0 0; | ||||
| 	padding: 0 .2em; | ||||
| 	border-left: 0; | ||||
| 	border-right: 0; | ||||
| 	border-bottom: 0; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-buttonpane button { | ||||
| 	float: right; | ||||
| 	margin: .5em .2em .4em; | ||||
| 	cursor: pointer; | ||||
| 	padding: .2em .6em .3em .6em; | ||||
| 	width: auto; | ||||
| 	overflow: visible; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { | ||||
| 	float: left; | ||||
| } | ||||
|  | ||||
| /* with multiple calendars */ | ||||
| .ui-datepicker.ui-datepicker-multi { | ||||
| 	width: auto; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-group { | ||||
| 	float: left; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-group table { | ||||
| 	width: 95%; | ||||
| 	margin: 0 auto .4em; | ||||
| } | ||||
| .ui-datepicker-multi-2 .ui-datepicker-group { | ||||
| 	width: 50%; | ||||
| } | ||||
| .ui-datepicker-multi-3 .ui-datepicker-group { | ||||
| 	width: 33.3%; | ||||
| } | ||||
| .ui-datepicker-multi-4 .ui-datepicker-group { | ||||
| 	width: 25%; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header, | ||||
| .ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { | ||||
| 	border-left-width: 0; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-buttonpane { | ||||
| 	clear: left; | ||||
| } | ||||
| .ui-datepicker-row-break { | ||||
| 	clear: both; | ||||
| 	width: 100%; | ||||
| 	font-size: 0; | ||||
| } | ||||
|  | ||||
| /* RTL support */ | ||||
| .ui-datepicker-rtl { | ||||
| 	direction: rtl; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-prev { | ||||
| 	right: 2px; | ||||
| 	left: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-next { | ||||
| 	left: 2px; | ||||
| 	right: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-prev:hover { | ||||
| 	right: 1px; | ||||
| 	left: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-next:hover { | ||||
| 	left: 1px; | ||||
| 	right: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-buttonpane { | ||||
| 	clear: right; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-buttonpane button { | ||||
| 	float: left; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current, | ||||
| .ui-datepicker-rtl .ui-datepicker-group { | ||||
| 	float: right; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header, | ||||
| .ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { | ||||
| 	border-right-width: 0; | ||||
| 	border-left-width: 1px; | ||||
| } | ||||
|  | ||||
| /* Component containers | ||||
| ----------------------------------*/ | ||||
| .ui-widget { | ||||
| 	font-family: Lucida Grande,Lucida Sans,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: Lucida Grande,Lucida Sans,Arial,sans-serif; | ||||
| 	font-size: 1em; | ||||
| } | ||||
| .ui-widget-content { | ||||
| 	border: 1px solid #a6c9e2; | ||||
| 	background: #fcfdfd url(images/ui-bg_inset-hard_100_fcfdfd_1x100.png) 50% bottom repeat-x; | ||||
| 	color: #222222; | ||||
| } | ||||
| .ui-widget-content a { | ||||
| 	color: #222222; | ||||
| } | ||||
| .ui-widget-header { | ||||
| 	border: 1px solid #4297d7; | ||||
| 	background: #5c9ccc url(images/ui-bg_gloss-wave_55_5c9ccc_500x100.png) 50% 50% repeat-x; | ||||
| 	color: #ffffff; | ||||
| 	font-weight: bold; | ||||
| } | ||||
| .ui-widget-header a { | ||||
| 	color: #ffffff; | ||||
| } | ||||
|  | ||||
| /* Interaction states | ||||
| ----------------------------------*/ | ||||
| .ui-state-default, | ||||
| .ui-widget-content .ui-state-default, | ||||
| .ui-widget-header .ui-state-default { | ||||
| 	border: 1px solid #c5dbec; | ||||
| 	background: #dfeffc url(images/ui-bg_glass_85_dfeffc_1x400.png) 50% 50% repeat-x; | ||||
| 	font-weight: bold; | ||||
| 	color: #2e6e9e; | ||||
| } | ||||
| .ui-state-default a, | ||||
| .ui-state-default a:link, | ||||
| .ui-state-default a:visited { | ||||
| 	color: #2e6e9e; | ||||
| 	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 #79b7e7; | ||||
| 	background: #d0e5f5 url(images/ui-bg_glass_75_d0e5f5_1x400.png) 50% 50% repeat-x; | ||||
| 	font-weight: bold; | ||||
| 	color: #1d5987; | ||||
| } | ||||
| .ui-state-hover a, | ||||
| .ui-state-hover a:hover, | ||||
| .ui-state-hover a:link, | ||||
| .ui-state-hover a:visited { | ||||
| 	color: #1d5987; | ||||
| 	text-decoration: none; | ||||
| } | ||||
| .ui-state-active, | ||||
| .ui-widget-content .ui-state-active, | ||||
| .ui-widget-header .ui-state-active { | ||||
| 	border: 1px solid #79b7e7; | ||||
| 	background: #f5f8f9 url(images/ui-bg_inset-hard_100_f5f8f9_1x100.png) 50% 50% repeat-x; | ||||
| 	font-weight: bold; | ||||
| 	color: #e17009; | ||||
| } | ||||
| .ui-state-active a, | ||||
| .ui-state-active a:link, | ||||
| .ui-state-active a:visited { | ||||
| 	color: #e17009; | ||||
| 	text-decoration: none; | ||||
| } | ||||
|  | ||||
| /* Interaction Cues | ||||
| ----------------------------------*/ | ||||
| .ui-state-highlight, | ||||
| .ui-widget-content .ui-state-highlight, | ||||
| .ui-widget-header .ui-state-highlight { | ||||
| 	border: 1px solid #fad42e; | ||||
| 	background: #fbec88 url(images/ui-bg_flat_55_fbec88_40x100.png) 50% 50% repeat-x; | ||||
| 	color: #363636; | ||||
| } | ||||
| .ui-state-highlight a, | ||||
| .ui-widget-content .ui-state-highlight a, | ||||
| .ui-widget-header .ui-state-highlight a { | ||||
| 	color: #363636; | ||||
| } | ||||
| .ui-state-error, | ||||
| .ui-widget-content .ui-state-error, | ||||
| .ui-widget-header .ui-state-error { | ||||
| 	border: 1px solid #cd0a0a; | ||||
| 	background: #fef1ec url(images/ui-bg_glass_95_fef1ec_1x400.png) 50% 50% repeat-x; | ||||
| 	color: #cd0a0a; | ||||
| } | ||||
| .ui-state-error a, | ||||
| .ui-widget-content .ui-state-error a, | ||||
| .ui-widget-header .ui-state-error a { | ||||
| 	color: #cd0a0a; | ||||
| } | ||||
| .ui-state-error-text, | ||||
| .ui-widget-content .ui-state-error-text, | ||||
| .ui-widget-header .ui-state-error-text { | ||||
| 	color: #cd0a0a; | ||||
| } | ||||
| .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); /* For IE8 - See #6059 */ | ||||
| } | ||||
|  | ||||
| /* Icons | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* states and images */ | ||||
| .ui-icon { | ||||
| 	width: 16px; | ||||
| 	height: 16px; | ||||
| 	background-position: 16px 16px; | ||||
| } | ||||
| .ui-icon, | ||||
| .ui-widget-content .ui-icon { | ||||
| 	background-image: url(images/ui-icons_469bdd_256x240.png); | ||||
| } | ||||
| .ui-widget-header .ui-icon { | ||||
| 	background-image: url(images/ui-icons_d8e7f3_256x240.png); | ||||
| } | ||||
| .ui-state-default .ui-icon { | ||||
| 	background-image: url(images/ui-icons_6da8d5_256x240.png); | ||||
| } | ||||
| .ui-state-hover .ui-icon, | ||||
| .ui-state-focus .ui-icon { | ||||
| 	background-image: url(images/ui-icons_217bc0_256x240.png); | ||||
| } | ||||
| .ui-state-active .ui-icon { | ||||
| 	background-image: url(images/ui-icons_f9bd01_256x240.png); | ||||
| } | ||||
| .ui-state-highlight .ui-icon { | ||||
| 	background-image: url(images/ui-icons_2e83ff_256x240.png); | ||||
| } | ||||
| .ui-state-error .ui-icon, | ||||
| .ui-state-error-text .ui-icon { | ||||
| 	background-image: url(images/ui-icons_cd0a0a_256x240.png); | ||||
| } | ||||
|  | ||||
| /* positioning */ | ||||
| .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 is deprecated, use ui-icon-seek-start instead */ | ||||
| .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; } | ||||
|  | ||||
|  | ||||
| /* Misc visuals | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* Corner radius */ | ||||
| .ui-corner-all, | ||||
| .ui-corner-top, | ||||
| .ui-corner-left, | ||||
| .ui-corner-tl { | ||||
| 	border-top-left-radius: 5px; | ||||
| } | ||||
| .ui-corner-all, | ||||
| .ui-corner-top, | ||||
| .ui-corner-right, | ||||
| .ui-corner-tr { | ||||
| 	border-top-right-radius: 5px; | ||||
| } | ||||
| .ui-corner-all, | ||||
| .ui-corner-bottom, | ||||
| .ui-corner-left, | ||||
| .ui-corner-bl { | ||||
| 	border-bottom-left-radius: 5px; | ||||
| } | ||||
| .ui-corner-all, | ||||
| .ui-corner-bottom, | ||||
| .ui-corner-right, | ||||
| .ui-corner-br { | ||||
| 	border-bottom-right-radius: 5px; | ||||
| } | ||||
|  | ||||
| /* Overlays */ | ||||
| .ui-widget-overlay { | ||||
| 	background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; | ||||
| 	opacity: .3; | ||||
| 	filter: Alpha(Opacity=30); | ||||
| } | ||||
| .ui-widget-shadow { | ||||
| 	margin: -8px 0 0 -8px; | ||||
| 	padding: 8px; | ||||
| 	background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; | ||||
| 	opacity: .3; | ||||
| 	filter: Alpha(Opacity=30); | ||||
| 	border-radius: 8px; | ||||
| } | ||||
| @@ -1,649 +0,0 @@ | ||||
| /*! jQuery UI - v1.10.2 - 2013-04-07 | ||||
| * http://jqueryui.com | ||||
| * Includes: jquery.ui.core.css, jquery.ui.datepicker.css | ||||
| * To view and modify this theme, visit http://jqueryui.com/themeroller/?ffDefault=Lucida%20Grande%2CLucida%20Sans%2CArial%2Csans-serif&fwDefault=bold&fsDefault=1.1em&cornerRadius=5px&bgColorHeader=5c9ccc&bgTextureHeader=gloss_wave&bgImgOpacityHeader=55&borderColorHeader=4297d7&fcHeader=ffffff&iconColorHeader=d8e7f3&bgColorContent=fcfdfd&bgTextureContent=inset_hard&bgImgOpacityContent=100&borderColorContent=a6c9e2&fcContent=222222&iconColorContent=469bdd&bgColorDefault=dfeffc&bgTextureDefault=glass&bgImgOpacityDefault=85&borderColorDefault=c5dbec&fcDefault=2e6e9e&iconColorDefault=6da8d5&bgColorHover=d0e5f5&bgTextureHover=glass&bgImgOpacityHover=75&borderColorHover=79b7e7&fcHover=1d5987&iconColorHover=217bc0&bgColorActive=f5f8f9&bgTextureActive=inset_hard&bgImgOpacityActive=100&borderColorActive=79b7e7&fcActive=e17009&iconColorActive=f9bd01&bgColorHighlight=fbec88&bgTextureHighlight=flat&bgImgOpacityHighlight=55&borderColorHighlight=fad42e&fcHighlight=363636&iconColorHighlight=2e83ff&bgColorError=fef1ec&bgTextureError=glass&bgImgOpacityError=95&borderColorError=cd0a0a&fcError=cd0a0a&iconColorError=cd0a0a&bgColorOverlay=aaaaaa&bgTextureOverlay=flat&bgImgOpacityOverlay=0&opacityOverlay=30&bgColorShadow=aaaaaa&bgTextureShadow=flat&bgImgOpacityShadow=0&opacityShadow=30&thicknessShadow=8px&offsetTopShadow=-8px&offsetLeftShadow=-8px&cornerRadiusShadow=8px | ||||
| * Copyright 2013 jQuery Foundation and other contributors Licensed MIT */ | ||||
|  | ||||
| /* Layout helpers | ||||
| ----------------------------------*/ | ||||
| .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; | ||||
| 	border-collapse: collapse; | ||||
| } | ||||
| .ui-helper-clearfix:after { | ||||
| 	clear: both; | ||||
| } | ||||
| .ui-helper-clearfix { | ||||
| 	min-height: 0; /* support: IE7 */ | ||||
| } | ||||
| .ui-helper-zfix { | ||||
| 	width: 100%; | ||||
| 	height: 100%; | ||||
| 	top: 0; | ||||
| 	left: 0; | ||||
| 	position: absolute; | ||||
| 	opacity: 0; | ||||
| 	filter:Alpha(Opacity=0); | ||||
| } | ||||
|  | ||||
| .ui-front { | ||||
| 	z-index: 100; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Interaction Cues | ||||
| ----------------------------------*/ | ||||
| .ui-state-disabled { | ||||
| 	cursor: default !important; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Icons | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* states and images */ | ||||
| .ui-icon { | ||||
| 	display: block; | ||||
| 	text-indent: -99999px; | ||||
| 	overflow: hidden; | ||||
| 	background-repeat: no-repeat; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Misc visuals | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* Overlays */ | ||||
| .ui-widget-overlay { | ||||
| 	position: fixed; | ||||
| 	top: 0; | ||||
| 	left: 0; | ||||
| 	width: 100%; | ||||
| 	height: 100%; | ||||
| } | ||||
| .ui-datepicker { | ||||
| 	width: 17em; | ||||
| 	padding: .2em .2em 0; | ||||
| 	display: none; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-header { | ||||
| 	position: relative; | ||||
| 	padding: .2em 0; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev, | ||||
| .ui-datepicker .ui-datepicker-next { | ||||
| 	position: absolute; | ||||
| 	top: 2px; | ||||
| 	width: 1.8em; | ||||
| 	height: 1.8em; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev-hover, | ||||
| .ui-datepicker .ui-datepicker-next-hover { | ||||
| 	top: 1px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev { | ||||
| 	left: 2px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-next { | ||||
| 	right: 2px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev-hover { | ||||
| 	left: 1px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-next-hover { | ||||
| 	right: 1px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev span, | ||||
| .ui-datepicker .ui-datepicker-next span { | ||||
| 	display: block; | ||||
| 	position: absolute; | ||||
| 	left: 50%; | ||||
| 	margin-left: -8px; | ||||
| 	top: 50%; | ||||
| 	margin-top: -8px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-title { | ||||
| 	margin: 0 2.3em; | ||||
| 	line-height: 1.8em; | ||||
| 	text-align: center; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-title select { | ||||
| 	font-size: 1em; | ||||
| 	margin: 1px 0; | ||||
| } | ||||
| .ui-datepicker select.ui-datepicker-month-year { | ||||
| 	width: 100%; | ||||
| } | ||||
| .ui-datepicker select.ui-datepicker-month, | ||||
| .ui-datepicker select.ui-datepicker-year { | ||||
| 	width: 49%; | ||||
| } | ||||
| .ui-datepicker table { | ||||
| 	width: 100%; | ||||
| 	font-size: .9em; | ||||
| 	border-collapse: collapse; | ||||
| 	margin: 0 0 .4em; | ||||
| } | ||||
| .ui-datepicker th { | ||||
| 	padding: .7em .3em; | ||||
| 	text-align: center; | ||||
| 	font-weight: bold; | ||||
| 	border: 0; | ||||
| } | ||||
| .ui-datepicker td { | ||||
| 	border: 0; | ||||
| 	padding: 1px; | ||||
| } | ||||
| .ui-datepicker td span, | ||||
| .ui-datepicker td a { | ||||
| 	display: block; | ||||
| 	padding: .2em; | ||||
| 	text-align: right; | ||||
| 	text-decoration: none; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-buttonpane { | ||||
| 	background-image: none; | ||||
| 	margin: .7em 0 0 0; | ||||
| 	padding: 0 .2em; | ||||
| 	border-left: 0; | ||||
| 	border-right: 0; | ||||
| 	border-bottom: 0; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-buttonpane button { | ||||
| 	float: right; | ||||
| 	margin: .5em .2em .4em; | ||||
| 	cursor: pointer; | ||||
| 	padding: .2em .6em .3em .6em; | ||||
| 	width: auto; | ||||
| 	overflow: visible; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { | ||||
| 	float: left; | ||||
| } | ||||
|  | ||||
| /* with multiple calendars */ | ||||
| .ui-datepicker.ui-datepicker-multi { | ||||
| 	width: auto; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-group { | ||||
| 	float: left; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-group table { | ||||
| 	width: 95%; | ||||
| 	margin: 0 auto .4em; | ||||
| } | ||||
| .ui-datepicker-multi-2 .ui-datepicker-group { | ||||
| 	width: 50%; | ||||
| } | ||||
| .ui-datepicker-multi-3 .ui-datepicker-group { | ||||
| 	width: 33.3%; | ||||
| } | ||||
| .ui-datepicker-multi-4 .ui-datepicker-group { | ||||
| 	width: 25%; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header, | ||||
| .ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { | ||||
| 	border-left-width: 0; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-buttonpane { | ||||
| 	clear: left; | ||||
| } | ||||
| .ui-datepicker-row-break { | ||||
| 	clear: both; | ||||
| 	width: 100%; | ||||
| 	font-size: 0; | ||||
| } | ||||
|  | ||||
| /* RTL support */ | ||||
| .ui-datepicker-rtl { | ||||
| 	direction: rtl; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-prev { | ||||
| 	right: 2px; | ||||
| 	left: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-next { | ||||
| 	left: 2px; | ||||
| 	right: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-prev:hover { | ||||
| 	right: 1px; | ||||
| 	left: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-next:hover { | ||||
| 	left: 1px; | ||||
| 	right: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-buttonpane { | ||||
| 	clear: right; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-buttonpane button { | ||||
| 	float: left; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current, | ||||
| .ui-datepicker-rtl .ui-datepicker-group { | ||||
| 	float: right; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header, | ||||
| .ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { | ||||
| 	border-right-width: 0; | ||||
| 	border-left-width: 1px; | ||||
| } | ||||
|  | ||||
| /* Component containers | ||||
| ----------------------------------*/ | ||||
| .ui-widget { | ||||
| 	font-family: Lucida Grande,Lucida Sans,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: Lucida Grande,Lucida Sans,Arial,sans-serif; | ||||
| 	font-size: 1em; | ||||
| } | ||||
| .ui-widget-content { | ||||
| 	border: 1px solid #a6c9e2; | ||||
| 	background: #fcfdfd url(images/ui-bg_inset-hard_100_fcfdfd_1x100.png) 50% bottom repeat-x; | ||||
| 	color: #222222; | ||||
| } | ||||
| .ui-widget-content a { | ||||
| 	color: #222222; | ||||
| } | ||||
| .ui-widget-header { | ||||
| 	border: 1px solid #4297d7; | ||||
| 	background: #5c9ccc url(images/ui-bg_gloss-wave_55_5c9ccc_500x100.png) 50% 50% repeat-x; | ||||
| 	color: #ffffff; | ||||
| 	font-weight: bold; | ||||
| } | ||||
| .ui-widget-header a { | ||||
| 	color: #ffffff; | ||||
| } | ||||
|  | ||||
| /* Interaction states | ||||
| ----------------------------------*/ | ||||
| .ui-state-default, | ||||
| .ui-widget-content .ui-state-default, | ||||
| .ui-widget-header .ui-state-default { | ||||
| 	border: 1px solid #c5dbec; | ||||
| 	background: #dfeffc url(images/ui-bg_glass_85_dfeffc_1x400.png) 50% 50% repeat-x; | ||||
| 	font-weight: bold; | ||||
| 	color: #2e6e9e; | ||||
| } | ||||
| .ui-state-default a, | ||||
| .ui-state-default a:link, | ||||
| .ui-state-default a:visited { | ||||
| 	color: #2e6e9e; | ||||
| 	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 #79b7e7; | ||||
| 	background: #d0e5f5 url(images/ui-bg_glass_75_d0e5f5_1x400.png) 50% 50% repeat-x; | ||||
| 	font-weight: bold; | ||||
| 	color: #1d5987; | ||||
| } | ||||
| .ui-state-hover a, | ||||
| .ui-state-hover a:hover, | ||||
| .ui-state-hover a:link, | ||||
| .ui-state-hover a:visited { | ||||
| 	color: #1d5987; | ||||
| 	text-decoration: none; | ||||
| } | ||||
| .ui-state-active, | ||||
| .ui-widget-content .ui-state-active, | ||||
| .ui-widget-header .ui-state-active { | ||||
| 	border: 1px solid #79b7e7; | ||||
| 	background: #f5f8f9 url(images/ui-bg_inset-hard_100_f5f8f9_1x100.png) 50% 50% repeat-x; | ||||
| 	font-weight: bold; | ||||
| 	color: #e17009; | ||||
| } | ||||
| .ui-state-active a, | ||||
| .ui-state-active a:link, | ||||
| .ui-state-active a:visited { | ||||
| 	color: #e17009; | ||||
| 	text-decoration: none; | ||||
| } | ||||
|  | ||||
| /* Interaction Cues | ||||
| ----------------------------------*/ | ||||
| .ui-state-highlight, | ||||
| .ui-widget-content .ui-state-highlight, | ||||
| .ui-widget-header .ui-state-highlight { | ||||
| 	border: 1px solid #fad42e; | ||||
| 	background: #fbec88 url(images/ui-bg_flat_55_fbec88_40x100.png) 50% 50% repeat-x; | ||||
| 	color: #363636; | ||||
| } | ||||
| .ui-state-highlight a, | ||||
| .ui-widget-content .ui-state-highlight a, | ||||
| .ui-widget-header .ui-state-highlight a { | ||||
| 	color: #363636; | ||||
| } | ||||
| .ui-state-error, | ||||
| .ui-widget-content .ui-state-error, | ||||
| .ui-widget-header .ui-state-error { | ||||
| 	border: 1px solid #cd0a0a; | ||||
| 	background: #fef1ec url(images/ui-bg_glass_95_fef1ec_1x400.png) 50% 50% repeat-x; | ||||
| 	color: #cd0a0a; | ||||
| } | ||||
| .ui-state-error a, | ||||
| .ui-widget-content .ui-state-error a, | ||||
| .ui-widget-header .ui-state-error a { | ||||
| 	color: #cd0a0a; | ||||
| } | ||||
| .ui-state-error-text, | ||||
| .ui-widget-content .ui-state-error-text, | ||||
| .ui-widget-header .ui-state-error-text { | ||||
| 	color: #cd0a0a; | ||||
| } | ||||
| .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); /* For IE8 - See #6059 */ | ||||
| } | ||||
|  | ||||
| /* Icons | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* states and images */ | ||||
| .ui-icon { | ||||
| 	width: 16px; | ||||
| 	height: 16px; | ||||
| } | ||||
| .ui-icon, | ||||
| .ui-widget-content .ui-icon { | ||||
| 	background-image: url(images/ui-icons_469bdd_256x240.png); | ||||
| } | ||||
| .ui-widget-header .ui-icon { | ||||
| 	background-image: url(images/ui-icons_d8e7f3_256x240.png); | ||||
| } | ||||
| .ui-state-default .ui-icon { | ||||
| 	background-image: url(images/ui-icons_6da8d5_256x240.png); | ||||
| } | ||||
| .ui-state-hover .ui-icon, | ||||
| .ui-state-focus .ui-icon { | ||||
| 	background-image: url(images/ui-icons_217bc0_256x240.png); | ||||
| } | ||||
| .ui-state-active .ui-icon { | ||||
| 	background-image: url(images/ui-icons_f9bd01_256x240.png); | ||||
| } | ||||
| .ui-state-highlight .ui-icon { | ||||
| 	background-image: url(images/ui-icons_2e83ff_256x240.png); | ||||
| } | ||||
| .ui-state-error .ui-icon, | ||||
| .ui-state-error-text .ui-icon { | ||||
| 	background-image: url(images/ui-icons_cd0a0a_256x240.png); | ||||
| } | ||||
|  | ||||
| /* positioning */ | ||||
| .ui-icon-blank { background-position: 16px 16px; } | ||||
| .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 is deprecated, use ui-icon-seek-start instead */ | ||||
| .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; } | ||||
|  | ||||
|  | ||||
| /* Misc visuals | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* Corner radius */ | ||||
| .ui-corner-all, | ||||
| .ui-corner-top, | ||||
| .ui-corner-left, | ||||
| .ui-corner-tl { | ||||
| 	border-top-left-radius: 5px; | ||||
| } | ||||
| .ui-corner-all, | ||||
| .ui-corner-top, | ||||
| .ui-corner-right, | ||||
| .ui-corner-tr { | ||||
| 	border-top-right-radius: 5px; | ||||
| } | ||||
| .ui-corner-all, | ||||
| .ui-corner-bottom, | ||||
| .ui-corner-left, | ||||
| .ui-corner-bl { | ||||
| 	border-bottom-left-radius: 5px; | ||||
| } | ||||
| .ui-corner-all, | ||||
| .ui-corner-bottom, | ||||
| .ui-corner-right, | ||||
| .ui-corner-br { | ||||
| 	border-bottom-right-radius: 5px; | ||||
| } | ||||
|  | ||||
| /* Overlays */ | ||||
| .ui-widget-overlay { | ||||
| 	background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; | ||||
| 	opacity: .3; | ||||
| 	filter: Alpha(Opacity=30); | ||||
| } | ||||
| .ui-widget-shadow { | ||||
| 	margin: -8px 0 0 -8px; | ||||
| 	padding: 8px; | ||||
| 	background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; | ||||
| 	opacity: .3; | ||||
| 	filter: Alpha(Opacity=30); | ||||
| 	border-radius: 8px; | ||||
| } | ||||
| @@ -1,649 +0,0 @@ | ||||
| /*! jQuery UI - v1.10.3 - 2013-08-05 | ||||
| * http://jqueryui.com | ||||
| * Includes: jquery.ui.core.css, jquery.ui.datepicker.css | ||||
| * To view and modify this theme, visit http://jqueryui.com/themeroller/?ffDefault=Lucida%20Grande%2CLucida%20Sans%2CArial%2Csans-serif&fwDefault=bold&fsDefault=1.1em&cornerRadius=5px&bgColorHeader=5c9ccc&bgTextureHeader=gloss_wave&bgImgOpacityHeader=55&borderColorHeader=4297d7&fcHeader=ffffff&iconColorHeader=d8e7f3&bgColorContent=fcfdfd&bgTextureContent=inset_hard&bgImgOpacityContent=100&borderColorContent=a6c9e2&fcContent=222222&iconColorContent=469bdd&bgColorDefault=dfeffc&bgTextureDefault=glass&bgImgOpacityDefault=85&borderColorDefault=c5dbec&fcDefault=2e6e9e&iconColorDefault=6da8d5&bgColorHover=d0e5f5&bgTextureHover=glass&bgImgOpacityHover=75&borderColorHover=79b7e7&fcHover=1d5987&iconColorHover=217bc0&bgColorActive=f5f8f9&bgTextureActive=inset_hard&bgImgOpacityActive=100&borderColorActive=79b7e7&fcActive=e17009&iconColorActive=f9bd01&bgColorHighlight=fbec88&bgTextureHighlight=flat&bgImgOpacityHighlight=55&borderColorHighlight=fad42e&fcHighlight=363636&iconColorHighlight=2e83ff&bgColorError=fef1ec&bgTextureError=glass&bgImgOpacityError=95&borderColorError=cd0a0a&fcError=cd0a0a&iconColorError=cd0a0a&bgColorOverlay=aaaaaa&bgTextureOverlay=flat&bgImgOpacityOverlay=0&opacityOverlay=30&bgColorShadow=aaaaaa&bgTextureShadow=flat&bgImgOpacityShadow=0&opacityShadow=30&thicknessShadow=8px&offsetTopShadow=-8px&offsetLeftShadow=-8px&cornerRadiusShadow=8px | ||||
| * Copyright 2013 jQuery Foundation and other contributors Licensed MIT */ | ||||
|  | ||||
| /* Layout helpers | ||||
| ----------------------------------*/ | ||||
| .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; | ||||
| 	border-collapse: collapse; | ||||
| } | ||||
| .ui-helper-clearfix:after { | ||||
| 	clear: both; | ||||
| } | ||||
| .ui-helper-clearfix { | ||||
| 	min-height: 0; /* support: IE7 */ | ||||
| } | ||||
| .ui-helper-zfix { | ||||
| 	width: 100%; | ||||
| 	height: 100%; | ||||
| 	top: 0; | ||||
| 	left: 0; | ||||
| 	position: absolute; | ||||
| 	opacity: 0; | ||||
| 	filter:Alpha(Opacity=0); | ||||
| } | ||||
|  | ||||
| .ui-front { | ||||
| 	z-index: 100; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Interaction Cues | ||||
| ----------------------------------*/ | ||||
| .ui-state-disabled { | ||||
| 	cursor: default !important; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Icons | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* states and images */ | ||||
| .ui-icon { | ||||
| 	display: block; | ||||
| 	text-indent: -99999px; | ||||
| 	overflow: hidden; | ||||
| 	background-repeat: no-repeat; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Misc visuals | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* Overlays */ | ||||
| .ui-widget-overlay { | ||||
| 	position: fixed; | ||||
| 	top: 0; | ||||
| 	left: 0; | ||||
| 	width: 100%; | ||||
| 	height: 100%; | ||||
| } | ||||
| .ui-datepicker { | ||||
| 	width: 17em; | ||||
| 	padding: .2em .2em 0; | ||||
| 	display: none; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-header { | ||||
| 	position: relative; | ||||
| 	padding: .2em 0; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev, | ||||
| .ui-datepicker .ui-datepicker-next { | ||||
| 	position: absolute; | ||||
| 	top: 2px; | ||||
| 	width: 1.8em; | ||||
| 	height: 1.8em; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev-hover, | ||||
| .ui-datepicker .ui-datepicker-next-hover { | ||||
| 	top: 1px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev { | ||||
| 	left: 2px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-next { | ||||
| 	right: 2px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev-hover { | ||||
| 	left: 1px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-next-hover { | ||||
| 	right: 1px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev span, | ||||
| .ui-datepicker .ui-datepicker-next span { | ||||
| 	display: block; | ||||
| 	position: absolute; | ||||
| 	left: 50%; | ||||
| 	margin-left: -8px; | ||||
| 	top: 50%; | ||||
| 	margin-top: -8px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-title { | ||||
| 	margin: 0 2.3em; | ||||
| 	line-height: 1.8em; | ||||
| 	text-align: center; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-title select { | ||||
| 	font-size: 1em; | ||||
| 	margin: 1px 0; | ||||
| } | ||||
| .ui-datepicker select.ui-datepicker-month-year { | ||||
| 	width: 100%; | ||||
| } | ||||
| .ui-datepicker select.ui-datepicker-month, | ||||
| .ui-datepicker select.ui-datepicker-year { | ||||
| 	width: 49%; | ||||
| } | ||||
| .ui-datepicker table { | ||||
| 	width: 100%; | ||||
| 	font-size: .9em; | ||||
| 	border-collapse: collapse; | ||||
| 	margin: 0 0 .4em; | ||||
| } | ||||
| .ui-datepicker th { | ||||
| 	padding: .7em .3em; | ||||
| 	text-align: center; | ||||
| 	font-weight: bold; | ||||
| 	border: 0; | ||||
| } | ||||
| .ui-datepicker td { | ||||
| 	border: 0; | ||||
| 	padding: 1px; | ||||
| } | ||||
| .ui-datepicker td span, | ||||
| .ui-datepicker td a { | ||||
| 	display: block; | ||||
| 	padding: .2em; | ||||
| 	text-align: right; | ||||
| 	text-decoration: none; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-buttonpane { | ||||
| 	background-image: none; | ||||
| 	margin: .7em 0 0 0; | ||||
| 	padding: 0 .2em; | ||||
| 	border-left: 0; | ||||
| 	border-right: 0; | ||||
| 	border-bottom: 0; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-buttonpane button { | ||||
| 	float: right; | ||||
| 	margin: .5em .2em .4em; | ||||
| 	cursor: pointer; | ||||
| 	padding: .2em .6em .3em .6em; | ||||
| 	width: auto; | ||||
| 	overflow: visible; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { | ||||
| 	float: left; | ||||
| } | ||||
|  | ||||
| /* with multiple calendars */ | ||||
| .ui-datepicker.ui-datepicker-multi { | ||||
| 	width: auto; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-group { | ||||
| 	float: left; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-group table { | ||||
| 	width: 95%; | ||||
| 	margin: 0 auto .4em; | ||||
| } | ||||
| .ui-datepicker-multi-2 .ui-datepicker-group { | ||||
| 	width: 50%; | ||||
| } | ||||
| .ui-datepicker-multi-3 .ui-datepicker-group { | ||||
| 	width: 33.3%; | ||||
| } | ||||
| .ui-datepicker-multi-4 .ui-datepicker-group { | ||||
| 	width: 25%; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header, | ||||
| .ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { | ||||
| 	border-left-width: 0; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-buttonpane { | ||||
| 	clear: left; | ||||
| } | ||||
| .ui-datepicker-row-break { | ||||
| 	clear: both; | ||||
| 	width: 100%; | ||||
| 	font-size: 0; | ||||
| } | ||||
|  | ||||
| /* RTL support */ | ||||
| .ui-datepicker-rtl { | ||||
| 	direction: rtl; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-prev { | ||||
| 	right: 2px; | ||||
| 	left: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-next { | ||||
| 	left: 2px; | ||||
| 	right: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-prev:hover { | ||||
| 	right: 1px; | ||||
| 	left: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-next:hover { | ||||
| 	left: 1px; | ||||
| 	right: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-buttonpane { | ||||
| 	clear: right; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-buttonpane button { | ||||
| 	float: left; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current, | ||||
| .ui-datepicker-rtl .ui-datepicker-group { | ||||
| 	float: right; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header, | ||||
| .ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { | ||||
| 	border-right-width: 0; | ||||
| 	border-left-width: 1px; | ||||
| } | ||||
|  | ||||
| /* Component containers | ||||
| ----------------------------------*/ | ||||
| .ui-widget { | ||||
| 	font-family: Lucida Grande,Lucida Sans,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: Lucida Grande,Lucida Sans,Arial,sans-serif; | ||||
| 	font-size: 1em; | ||||
| } | ||||
| .ui-widget-content { | ||||
| 	border: 1px solid #a6c9e2; | ||||
| 	background: #fcfdfd url(images/ui-bg_inset-hard_100_fcfdfd_1x100.png) 50% bottom repeat-x; | ||||
| 	color: #222222; | ||||
| } | ||||
| .ui-widget-content a { | ||||
| 	color: #222222; | ||||
| } | ||||
| .ui-widget-header { | ||||
| 	border: 1px solid #4297d7; | ||||
| 	background: #5c9ccc url(images/ui-bg_gloss-wave_55_5c9ccc_500x100.png) 50% 50% repeat-x; | ||||
| 	color: #ffffff; | ||||
| 	font-weight: bold; | ||||
| } | ||||
| .ui-widget-header a { | ||||
| 	color: #ffffff; | ||||
| } | ||||
|  | ||||
| /* Interaction states | ||||
| ----------------------------------*/ | ||||
| .ui-state-default, | ||||
| .ui-widget-content .ui-state-default, | ||||
| .ui-widget-header .ui-state-default { | ||||
| 	border: 1px solid #c5dbec; | ||||
| 	background: #dfeffc url(images/ui-bg_glass_85_dfeffc_1x400.png) 50% 50% repeat-x; | ||||
| 	font-weight: bold; | ||||
| 	color: #2e6e9e; | ||||
| } | ||||
| .ui-state-default a, | ||||
| .ui-state-default a:link, | ||||
| .ui-state-default a:visited { | ||||
| 	color: #2e6e9e; | ||||
| 	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 #79b7e7; | ||||
| 	background: #d0e5f5 url(images/ui-bg_glass_75_d0e5f5_1x400.png) 50% 50% repeat-x; | ||||
| 	font-weight: bold; | ||||
| 	color: #1d5987; | ||||
| } | ||||
| .ui-state-hover a, | ||||
| .ui-state-hover a:hover, | ||||
| .ui-state-hover a:link, | ||||
| .ui-state-hover a:visited { | ||||
| 	color: #1d5987; | ||||
| 	text-decoration: none; | ||||
| } | ||||
| .ui-state-active, | ||||
| .ui-widget-content .ui-state-active, | ||||
| .ui-widget-header .ui-state-active { | ||||
| 	border: 1px solid #79b7e7; | ||||
| 	background: #f5f8f9 url(images/ui-bg_inset-hard_100_f5f8f9_1x100.png) 50% 50% repeat-x; | ||||
| 	font-weight: bold; | ||||
| 	color: #e17009; | ||||
| } | ||||
| .ui-state-active a, | ||||
| .ui-state-active a:link, | ||||
| .ui-state-active a:visited { | ||||
| 	color: #e17009; | ||||
| 	text-decoration: none; | ||||
| } | ||||
|  | ||||
| /* Interaction Cues | ||||
| ----------------------------------*/ | ||||
| .ui-state-highlight, | ||||
| .ui-widget-content .ui-state-highlight, | ||||
| .ui-widget-header .ui-state-highlight { | ||||
| 	border: 1px solid #fad42e; | ||||
| 	background: #fbec88 url(images/ui-bg_flat_55_fbec88_40x100.png) 50% 50% repeat-x; | ||||
| 	color: #363636; | ||||
| } | ||||
| .ui-state-highlight a, | ||||
| .ui-widget-content .ui-state-highlight a, | ||||
| .ui-widget-header .ui-state-highlight a { | ||||
| 	color: #363636; | ||||
| } | ||||
| .ui-state-error, | ||||
| .ui-widget-content .ui-state-error, | ||||
| .ui-widget-header .ui-state-error { | ||||
| 	border: 1px solid #cd0a0a; | ||||
| 	background: #fef1ec url(images/ui-bg_glass_95_fef1ec_1x400.png) 50% 50% repeat-x; | ||||
| 	color: #cd0a0a; | ||||
| } | ||||
| .ui-state-error a, | ||||
| .ui-widget-content .ui-state-error a, | ||||
| .ui-widget-header .ui-state-error a { | ||||
| 	color: #cd0a0a; | ||||
| } | ||||
| .ui-state-error-text, | ||||
| .ui-widget-content .ui-state-error-text, | ||||
| .ui-widget-header .ui-state-error-text { | ||||
| 	color: #cd0a0a; | ||||
| } | ||||
| .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); /* For IE8 - See #6059 */ | ||||
| } | ||||
|  | ||||
| /* Icons | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* states and images */ | ||||
| .ui-icon { | ||||
| 	width: 16px; | ||||
| 	height: 16px; | ||||
| } | ||||
| .ui-icon, | ||||
| .ui-widget-content .ui-icon { | ||||
| 	background-image: url(images/ui-icons_469bdd_256x240.png); | ||||
| } | ||||
| .ui-widget-header .ui-icon { | ||||
| 	background-image: url(images/ui-icons_d8e7f3_256x240.png); | ||||
| } | ||||
| .ui-state-default .ui-icon { | ||||
| 	background-image: url(images/ui-icons_6da8d5_256x240.png); | ||||
| } | ||||
| .ui-state-hover .ui-icon, | ||||
| .ui-state-focus .ui-icon { | ||||
| 	background-image: url(images/ui-icons_217bc0_256x240.png); | ||||
| } | ||||
| .ui-state-active .ui-icon { | ||||
| 	background-image: url(images/ui-icons_f9bd01_256x240.png); | ||||
| } | ||||
| .ui-state-highlight .ui-icon { | ||||
| 	background-image: url(images/ui-icons_2e83ff_256x240.png); | ||||
| } | ||||
| .ui-state-error .ui-icon, | ||||
| .ui-state-error-text .ui-icon { | ||||
| 	background-image: url(images/ui-icons_cd0a0a_256x240.png); | ||||
| } | ||||
|  | ||||
| /* positioning */ | ||||
| .ui-icon-blank { background-position: 16px 16px; } | ||||
| .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 is deprecated, use ui-icon-seek-start instead */ | ||||
| .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; } | ||||
|  | ||||
|  | ||||
| /* Misc visuals | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* Corner radius */ | ||||
| .ui-corner-all, | ||||
| .ui-corner-top, | ||||
| .ui-corner-left, | ||||
| .ui-corner-tl { | ||||
| 	border-top-left-radius: 5px; | ||||
| } | ||||
| .ui-corner-all, | ||||
| .ui-corner-top, | ||||
| .ui-corner-right, | ||||
| .ui-corner-tr { | ||||
| 	border-top-right-radius: 5px; | ||||
| } | ||||
| .ui-corner-all, | ||||
| .ui-corner-bottom, | ||||
| .ui-corner-left, | ||||
| .ui-corner-bl { | ||||
| 	border-bottom-left-radius: 5px; | ||||
| } | ||||
| .ui-corner-all, | ||||
| .ui-corner-bottom, | ||||
| .ui-corner-right, | ||||
| .ui-corner-br { | ||||
| 	border-bottom-right-radius: 5px; | ||||
| } | ||||
|  | ||||
| /* Overlays */ | ||||
| .ui-widget-overlay { | ||||
| 	background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; | ||||
| 	opacity: .3; | ||||
| 	filter: Alpha(Opacity=30); | ||||
| } | ||||
| .ui-widget-shadow { | ||||
| 	margin: -8px 0 0 -8px; | ||||
| 	padding: 8px; | ||||
| 	background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; | ||||
| 	opacity: .3; | ||||
| 	filter: Alpha(Opacity=30); | ||||
| 	border-radius: 8px; | ||||
| } | ||||
| @@ -1,461 +0,0 @@ | ||||
| /*! jQuery UI - v1.9.1 - 2012-11-05 | ||||
| * http://jqueryui.com | ||||
| * Includes: jquery.ui.core.css, jquery.ui.resizable.css, jquery.ui.selectable.css, jquery.ui.accordion.css, jquery.ui.autocomplete.css, jquery.ui.button.css, jquery.ui.datepicker.css, jquery.ui.dialog.css, jquery.ui.menu.css, jquery.ui.progressbar.css, jquery.ui.slider.css, jquery.ui.spinner.css, jquery.ui.tabs.css, jquery.ui.tooltip.css | ||||
| * To view and modify this theme, visit http://jqueryui.com/themeroller/?ffDefault=Lucida%20Grande%2CLucida%20Sans%2CArial%2Csans-serif&fwDefault=bold&fsDefault=1.1em&cornerRadius=5px&bgColorHeader=5c9ccc&bgTextureHeader=12_gloss_wave.png&bgImgOpacityHeader=55&borderColorHeader=4297d7&fcHeader=ffffff&iconColorHeader=d8e7f3&bgColorContent=fcfdfd&bgTextureContent=06_inset_hard.png&bgImgOpacityContent=100&borderColorContent=a6c9e2&fcContent=222222&iconColorContent=469bdd&bgColorDefault=dfeffc&bgTextureDefault=02_glass.png&bgImgOpacityDefault=85&borderColorDefault=c5dbec&fcDefault=2e6e9e&iconColorDefault=6da8d5&bgColorHover=d0e5f5&bgTextureHover=02_glass.png&bgImgOpacityHover=75&borderColorHover=79b7e7&fcHover=1d5987&iconColorHover=217bc0&bgColorActive=f5f8f9&bgTextureActive=06_inset_hard.png&bgImgOpacityActive=100&borderColorActive=79b7e7&fcActive=e17009&iconColorActive=f9bd01&bgColorHighlight=fbec88&bgTextureHighlight=01_flat.png&bgImgOpacityHighlight=55&borderColorHighlight=fad42e&fcHighlight=363636&iconColorHighlight=2e83ff&bgColorError=fef1ec&bgTextureError=02_glass.png&bgImgOpacityError=95&borderColorError=cd0a0a&fcError=cd0a0a&iconColorError=cd0a0a&bgColorOverlay=aaaaaa&bgTextureOverlay=01_flat.png&bgImgOpacityOverlay=0&opacityOverlay=30&bgColorShadow=aaaaaa&bgTextureShadow=01_flat.png&bgImgOpacityShadow=0&opacityShadow=30&thicknessShadow=8px&offsetTopShadow=-8px&offsetLeftShadow=-8px&cornerRadiusShadow=8px | ||||
| * Copyright (c) 2012 jQuery Foundation and other contributors Licensed MIT */ | ||||
|  | ||||
| /* Layout helpers | ||||
| ----------------------------------*/ | ||||
| .ui-helper-hidden { display: none; } | ||||
| .ui-helper-hidden-accessible { position: absolute !important; clip: rect(1px 1px 1px 1px); clip: rect(1px,1px,1px,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); } | ||||
|  | ||||
|  | ||||
| /* Interaction Cues | ||||
| ----------------------------------*/ | ||||
| .ui-state-disabled { cursor: default !important; } | ||||
|  | ||||
|  | ||||
| /* Icons | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* states and images */ | ||||
| .ui-icon { display: block; text-indent: -99999px; overflow: hidden; background-repeat: no-repeat; } | ||||
|  | ||||
|  | ||||
| /* Misc visuals | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* Overlays */ | ||||
| .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-selectable-helper { position: absolute; z-index: 100; border:1px dotted black; } | ||||
| .ui-accordion .ui-accordion-header { display: block; cursor: pointer; position: relative; margin-top: 2px; padding: .5em .5em .5em .7em; zoom: 1; } | ||||
| .ui-accordion .ui-accordion-icons { padding-left: 2.2em; } | ||||
| .ui-accordion .ui-accordion-noicons { padding-left: .7em; } | ||||
| .ui-accordion .ui-accordion-icons .ui-accordion-icons { padding-left: 2.2em; } | ||||
| .ui-accordion .ui-accordion-header .ui-accordion-header-icon { position: absolute; left: .5em; top: 50%; margin-top: -8px; } | ||||
| .ui-accordion .ui-accordion-content { padding: 1em 2.2em; border-top: 0; overflow: auto; zoom: 1; } | ||||
| .ui-autocomplete { | ||||
| 	position: absolute; | ||||
| 	top: 0; /* #8656 */ | ||||
| 	cursor: default; | ||||
| } | ||||
|  | ||||
| /* workarounds */ | ||||
| * html .ui-autocomplete { width:1px; } /* without this, the menu expands to 100% in IE6 */ | ||||
| .ui-button { display: inline-block; position: relative; padding: 0; margin-right: .1em; cursor: pointer; text-align: center; zoom: 1; overflow: visible; } /* the overflow property removes extra width in IE */ | ||||
| .ui-button, .ui-button:link, .ui-button:visited, .ui-button:hover, .ui-button:active { text-decoration: none; } | ||||
| .ui-button-icon-only { width: 2.2em; } /* to make room for the icon, a width needs to be set here */ | ||||
| button.ui-button-icon-only { width: 2.4em; } /* button elements seem to need a little more width */ | ||||
| .ui-button-icons-only { width: 3.4em; }  | ||||
| button.ui-button-icons-only { width: 3.7em; }  | ||||
|  | ||||
| /*button text element */ | ||||
| .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; } | ||||
| /* no icon support for input elements, provide padding by default */ | ||||
| input.ui-button { padding: .4em 1em; } | ||||
|  | ||||
| /*button icon element(s) */ | ||||
| .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; } | ||||
|  | ||||
| /*button sets*/ | ||||
| .ui-buttonset { margin-right: 7px; } | ||||
| .ui-buttonset .ui-button { margin-left: 0; margin-right: -.3em; } | ||||
|  | ||||
| /* workarounds */ | ||||
| button.ui-button::-moz-focus-inner { border: 0; padding: 0; } /* reset extra padding in Firefox */ | ||||
| .ui-datepicker { width: 17em; padding: .2em .2em 0; display: none; } | ||||
| .ui-datepicker .ui-datepicker-header { position:relative; padding:.2em 0; } | ||||
| .ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next { position:absolute; top: 2px; width: 1.8em; height: 1.8em; } | ||||
| .ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover { top: 1px; } | ||||
| .ui-datepicker .ui-datepicker-prev { left:2px; } | ||||
| .ui-datepicker .ui-datepicker-next { right:2px; } | ||||
| .ui-datepicker .ui-datepicker-prev-hover { left:1px; } | ||||
| .ui-datepicker .ui-datepicker-next-hover { right:1px; } | ||||
| .ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span { display: block; position: absolute; left: 50%; margin-left: -8px; top: 50%; margin-top: -8px;  } | ||||
| .ui-datepicker .ui-datepicker-title { margin: 0 2.3em; line-height: 1.8em; text-align: center; } | ||||
| .ui-datepicker .ui-datepicker-title select { font-size:1em; margin:1px 0; } | ||||
| .ui-datepicker select.ui-datepicker-month-year {width: 100%;} | ||||
| .ui-datepicker select.ui-datepicker-month,  | ||||
| .ui-datepicker select.ui-datepicker-year { width: 49%;} | ||||
| .ui-datepicker table {width: 100%; font-size: .9em; border-collapse: collapse; margin:0 0 .4em; } | ||||
| .ui-datepicker th { padding: .7em .3em; text-align: center; font-weight: bold; border: 0;  } | ||||
| .ui-datepicker td { border: 0; padding: 1px; } | ||||
| .ui-datepicker td span, .ui-datepicker td a { display: block; padding: .2em; text-align: right; text-decoration: none; } | ||||
| .ui-datepicker .ui-datepicker-buttonpane { background-image: none; margin: .7em 0 0 0; padding:0 .2em; border-left: 0; border-right: 0; border-bottom: 0; } | ||||
| .ui-datepicker .ui-datepicker-buttonpane button { float: right; margin: .5em .2em .4em; cursor: pointer; padding: .2em .6em .3em .6em; width:auto; overflow:visible; } | ||||
| .ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { float:left; } | ||||
|  | ||||
| /* with multiple calendars */ | ||||
| .ui-datepicker.ui-datepicker-multi { width:auto; } | ||||
| .ui-datepicker-multi .ui-datepicker-group { float:left; } | ||||
| .ui-datepicker-multi .ui-datepicker-group table { width:95%; margin:0 auto .4em; } | ||||
| .ui-datepicker-multi-2 .ui-datepicker-group { width:50%; } | ||||
| .ui-datepicker-multi-3 .ui-datepicker-group { width:33.3%; } | ||||
| .ui-datepicker-multi-4 .ui-datepicker-group { width:25%; } | ||||
| .ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header { border-left-width:0; } | ||||
| .ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { border-left-width:0; } | ||||
| .ui-datepicker-multi .ui-datepicker-buttonpane { clear:left; } | ||||
| .ui-datepicker-row-break { clear:both; width:100%; font-size:0em; } | ||||
|  | ||||
| /* RTL support */ | ||||
| .ui-datepicker-rtl { direction: rtl; } | ||||
| .ui-datepicker-rtl .ui-datepicker-prev { right: 2px; left: auto; } | ||||
| .ui-datepicker-rtl .ui-datepicker-next { left: 2px; right: auto; } | ||||
| .ui-datepicker-rtl .ui-datepicker-prev:hover { right: 1px; left: auto; } | ||||
| .ui-datepicker-rtl .ui-datepicker-next:hover { left: 1px; right: auto; } | ||||
| .ui-datepicker-rtl .ui-datepicker-buttonpane { clear:right; } | ||||
| .ui-datepicker-rtl .ui-datepicker-buttonpane button { float: left; } | ||||
| .ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current { float:right; } | ||||
| .ui-datepicker-rtl .ui-datepicker-group { float:right; } | ||||
| .ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header { border-right-width:0; border-left-width:1px; } | ||||
| .ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { border-right-width:0; border-left-width:1px; } | ||||
|  | ||||
| /* IE6 IFRAME FIX (taken from datepicker 1.5.3 */ | ||||
| .ui-datepicker-cover { | ||||
|     position: absolute; /*must have*/ | ||||
|     z-index: -1; /*must have*/ | ||||
|     filter: mask(); /*must have*/ | ||||
|     top: -4px; /*must have*/ | ||||
|     left: -4px; /*must have*/ | ||||
|     width: 200px; /*must have*/ | ||||
|     height: 200px; /*must have*/ | ||||
| }.ui-dialog { position: absolute; 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-menu { list-style:none; padding: 2px; margin: 0; display:block; outline: none; } | ||||
| .ui-menu .ui-menu { margin-top: -3px; position: absolute; } | ||||
| .ui-menu .ui-menu-item { margin: 0; padding: 0; zoom: 1; width: 100%; } | ||||
| .ui-menu .ui-menu-divider { margin: 5px -2px 5px -2px; height: 0; font-size: 0; line-height: 0; border-width: 1px 0 0 0; } | ||||
| .ui-menu .ui-menu-item a { text-decoration: none; display: block; padding: 2px .4em; line-height: 1.5; zoom: 1; font-weight: normal; } | ||||
| .ui-menu .ui-menu-item a.ui-state-focus, | ||||
| .ui-menu .ui-menu-item a.ui-state-active { font-weight: normal; margin: -1px; } | ||||
|  | ||||
| .ui-menu .ui-state-disabled { font-weight: normal; margin: .4em 0 .2em; line-height: 1.5; } | ||||
| .ui-menu .ui-state-disabled a { cursor: default; } | ||||
|  | ||||
| /* icon support */ | ||||
| .ui-menu-icons { position: relative; } | ||||
| .ui-menu-icons .ui-menu-item a { position: relative; padding-left: 2em; } | ||||
|  | ||||
| /* left-aligned */ | ||||
| .ui-menu .ui-icon { position: absolute; top: .2em; left: .2em; } | ||||
|  | ||||
| /* right-aligned */ | ||||
| .ui-menu .ui-menu-icon { position: static; float: right; } | ||||
| .ui-progressbar { height:2em; text-align: left; overflow: hidden; } | ||||
| .ui-progressbar .ui-progressbar-value {margin: -1px; height:100%; }.ui-slider { position: relative; text-align: left; } | ||||
| .ui-slider .ui-slider-handle { position: absolute; z-index: 2; width: 1.2em; height: 1.2em; cursor: default; } | ||||
| .ui-slider .ui-slider-range { position: absolute; z-index: 1; font-size: .7em; display: block; border: 0; background-position: 0 0; } | ||||
|  | ||||
| .ui-slider-horizontal { height: .8em; } | ||||
| .ui-slider-horizontal .ui-slider-handle { top: -.3em; margin-left: -.6em; } | ||||
| .ui-slider-horizontal .ui-slider-range { top: 0; height: 100%; } | ||||
| .ui-slider-horizontal .ui-slider-range-min { left: 0; } | ||||
| .ui-slider-horizontal .ui-slider-range-max { right: 0; } | ||||
|  | ||||
| .ui-slider-vertical { width: .8em; height: 100px; } | ||||
| .ui-slider-vertical .ui-slider-handle { left: -.3em; margin-left: 0; margin-bottom: -.6em; } | ||||
| .ui-slider-vertical .ui-slider-range { left: 0; width: 100%; } | ||||
| .ui-slider-vertical .ui-slider-range-min { bottom: 0; } | ||||
| .ui-slider-vertical .ui-slider-range-max { top: 0; }.ui-spinner { position:relative; display: inline-block; overflow: hidden; padding: 0; vertical-align: middle; } | ||||
| .ui-spinner-input { border: none; background: none; padding: 0; margin: .2em 0; vertical-align: middle; margin-left: .4em; margin-right: 22px; } | ||||
| .ui-spinner-button { width: 16px; height: 50%; font-size: .5em; padding: 0; margin: 0; text-align: center; position: absolute; cursor: default; display: block; overflow: hidden; right: 0; } | ||||
| .ui-spinner a.ui-spinner-button { border-top: none; border-bottom: none; border-right: none; } /* more specificity required here to overide default borders */ | ||||
| .ui-spinner .ui-icon { position: absolute; margin-top: -8px; top: 50%; left: 0; } /* vertical centre icon */ | ||||
| .ui-spinner-up { top: 0; } | ||||
| .ui-spinner-down { bottom: 0; } | ||||
|  | ||||
| /* TR overrides */ | ||||
| .ui-spinner .ui-icon-triangle-1-s { | ||||
| 	/* need to fix icons sprite */ | ||||
| 	background-position:-65px -16px; | ||||
| } | ||||
| .ui-tabs { position: relative; padding: .2em; zoom: 1; } /* position: relative prevents IE scroll bug (element with position: relative inside container with overflow: auto appear as "fixed") */ | ||||
| .ui-tabs .ui-tabs-nav { margin: 0; padding: .2em .2em 0; } | ||||
| .ui-tabs .ui-tabs-nav li { list-style: none; float: left; position: relative; top: 0; margin: 1px .2em 0 0; border-bottom: 0; padding: 0; white-space: nowrap; } | ||||
| .ui-tabs .ui-tabs-nav li a { float: left; padding: .5em 1em; text-decoration: none; } | ||||
| .ui-tabs .ui-tabs-nav li.ui-tabs-active { margin-bottom: -1px; padding-bottom: 1px; } | ||||
| .ui-tabs .ui-tabs-nav li.ui-tabs-active a, .ui-tabs .ui-tabs-nav li.ui-state-disabled a, .ui-tabs .ui-tabs-nav li.ui-tabs-loading a { cursor: text; } | ||||
| .ui-tabs .ui-tabs-nav li a, .ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-active a { cursor: pointer; } /* first selector in group seems obsolete, but required to overcome bug in Opera applying cursor: text overall if defined elsewhere... */ | ||||
| .ui-tabs .ui-tabs-panel { display: block; border-width: 0; padding: 1em 1.4em; background: none; } | ||||
| .ui-tooltip { | ||||
| 	padding: 8px; | ||||
| 	position: absolute; | ||||
| 	z-index: 9999; | ||||
| 	max-width: 300px; | ||||
| 	-webkit-box-shadow: 0 0 5px #aaa; | ||||
| 	box-shadow: 0 0 5px #aaa; | ||||
| } | ||||
| /* Fades and background-images don't work well together in IE6, drop the image */ | ||||
| * html .ui-tooltip { | ||||
| 	background-image: none; | ||||
| } | ||||
| body .ui-tooltip { border-width: 2px; } | ||||
|  | ||||
| /* Component containers | ||||
| ----------------------------------*/ | ||||
| .ui-widget { font-family: Lucida Grande,Lucida Sans,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: Lucida Grande,Lucida Sans,Arial,sans-serif; font-size: 1em; } | ||||
| .ui-widget-content { border: 1px solid #a6c9e2; background: #fcfdfd url(images/ui-bg_inset-hard_100_fcfdfd_1x100.png) 50% bottom repeat-x; color: #222222; } | ||||
| .ui-widget-content a { color: #222222; } | ||||
| .ui-widget-header { border: 1px solid #4297d7; background: #5c9ccc url(images/ui-bg_gloss-wave_55_5c9ccc_500x100.png) 50% 50% repeat-x; color: #ffffff; font-weight: bold; } | ||||
| .ui-widget-header a { color: #ffffff; } | ||||
|  | ||||
| /* Interaction states | ||||
| ----------------------------------*/ | ||||
| .ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { border: 1px solid #c5dbec; background: #dfeffc url(images/ui-bg_glass_85_dfeffc_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #2e6e9e; } | ||||
| .ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited { color: #2e6e9e; 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 #79b7e7; background: #d0e5f5 url(images/ui-bg_glass_75_d0e5f5_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #1d5987; } | ||||
| .ui-state-hover a, .ui-state-hover a:hover, .ui-state-hover a:link, .ui-state-hover a:visited { color: #1d5987; text-decoration: none; } | ||||
| .ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { border: 1px solid #79b7e7; background: #f5f8f9 url(images/ui-bg_inset-hard_100_f5f8f9_1x100.png) 50% 50% repeat-x; font-weight: bold; color: #e17009; } | ||||
| .ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited { color: #e17009; text-decoration: none; } | ||||
|  | ||||
| /* Interaction Cues | ||||
| ----------------------------------*/ | ||||
| .ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight  {border: 1px solid #fad42e; background: #fbec88 url(images/ui-bg_flat_55_fbec88_40x100.png) 50% 50% repeat-x; color: #363636; } | ||||
| .ui-state-highlight a, .ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a { color: #363636; } | ||||
| .ui-state-error, .ui-widget-content .ui-state-error, .ui-widget-header .ui-state-error {border: 1px solid #cd0a0a; background: #fef1ec url(images/ui-bg_glass_95_fef1ec_1x400.png) 50% 50% repeat-x; color: #cd0a0a; } | ||||
| .ui-state-error a, .ui-widget-content .ui-state-error a, .ui-widget-header .ui-state-error a { color: #cd0a0a; } | ||||
| .ui-state-error-text, .ui-widget-content .ui-state-error-text, .ui-widget-header .ui-state-error-text { color: #cd0a0a; } | ||||
| .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); } /* For IE8 - See #6059 */ | ||||
|  | ||||
| /* Icons | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* states and images */ | ||||
| .ui-icon { width: 16px; height: 16px; background-image: url(images/ui-icons_469bdd_256x240.png); } | ||||
| .ui-widget-content .ui-icon {background-image: url(images/ui-icons_469bdd_256x240.png); } | ||||
| .ui-widget-header .ui-icon {background-image: url(images/ui-icons_d8e7f3_256x240.png); } | ||||
| .ui-state-default .ui-icon { background-image: url(images/ui-icons_6da8d5_256x240.png); } | ||||
| .ui-state-hover .ui-icon, .ui-state-focus .ui-icon {background-image: url(images/ui-icons_217bc0_256x240.png); } | ||||
| .ui-state-active .ui-icon {background-image: url(images/ui-icons_f9bd01_256x240.png); } | ||||
| .ui-state-highlight .ui-icon {background-image: url(images/ui-icons_2e83ff_256x240.png); } | ||||
| .ui-state-error .ui-icon, .ui-state-error-text .ui-icon {background-image: url(images/ui-icons_cd0a0a_256x240.png); } | ||||
|  | ||||
| /* positioning */ | ||||
| .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 is deprecated, use ui-icon-seek-start instead */ | ||||
| .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; } | ||||
|  | ||||
|  | ||||
| /* Misc visuals | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* Corner radius */ | ||||
| .ui-corner-all, .ui-corner-top, .ui-corner-left, .ui-corner-tl { -moz-border-radius-topleft: 5px; -webkit-border-top-left-radius: 5px; -khtml-border-top-left-radius: 5px; border-top-left-radius: 5px; } | ||||
| .ui-corner-all, .ui-corner-top, .ui-corner-right, .ui-corner-tr { -moz-border-radius-topright: 5px; -webkit-border-top-right-radius: 5px; -khtml-border-top-right-radius: 5px; border-top-right-radius: 5px; } | ||||
| .ui-corner-all, .ui-corner-bottom, .ui-corner-left, .ui-corner-bl { -moz-border-radius-bottomleft: 5px; -webkit-border-bottom-left-radius: 5px; -khtml-border-bottom-left-radius: 5px; border-bottom-left-radius: 5px; } | ||||
| .ui-corner-all, .ui-corner-bottom, .ui-corner-right, .ui-corner-br { -moz-border-radius-bottomright: 5px; -webkit-border-bottom-right-radius: 5px; -khtml-border-bottom-right-radius: 5px; border-bottom-right-radius: 5px; } | ||||
|  | ||||
| /* Overlays */ | ||||
| .ui-widget-overlay { background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; opacity: .3;filter:Alpha(Opacity=30); } | ||||
| .ui-widget-shadow { margin: -8px 0 0 -8px; padding: 8px; background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; opacity: .3;filter:Alpha(Opacity=30); -moz-border-radius: 8px; -khtml-border-radius: 8px; -webkit-border-radius: 8px; border-radius: 8px; } | ||||
							
								
								
									
										87
									
								
								src/inputs/select2/lib/select2-bootstrap.css
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,87 +0,0 @@ | ||||
| .form-control .select2-choice { | ||||
|     border: 0; | ||||
|     border-radius: 2px; | ||||
| } | ||||
|  | ||||
| .form-control .select2-choice .select2-arrow { | ||||
|     border-radius: 0 2px 2px 0;    | ||||
| } | ||||
|  | ||||
| .form-control.select2-container { | ||||
|     height: auto !important; | ||||
|     padding: 0px; | ||||
| } | ||||
|  | ||||
| .form-control.select2-container.select2-dropdown-open { | ||||
|     border-color: #5897FB; | ||||
|     border-radius: 3px 3px 0 0; | ||||
| } | ||||
|  | ||||
| .form-control .select2-container.select2-dropdown-open .select2-choices { | ||||
|     border-radius: 3px 3px 0 0; | ||||
| } | ||||
|  | ||||
| .form-control.select2-container .select2-choices { | ||||
|     border: 0 !important; | ||||
|     border-radius: 3px; | ||||
| } | ||||
|  | ||||
| .control-group.warning .select2-container .select2-choice, | ||||
| .control-group.warning .select2-container .select2-choices, | ||||
| .control-group.warning .select2-container-active .select2-choice, | ||||
| .control-group.warning .select2-container-active .select2-choices, | ||||
| .control-group.warning .select2-dropdown-open.select2-drop-above .select2-choice, | ||||
| .control-group.warning .select2-dropdown-open.select2-drop-above .select2-choices, | ||||
| .control-group.warning .select2-container-multi.select2-container-active .select2-choices { | ||||
|     border: 1px solid #C09853 !important; | ||||
| } | ||||
|  | ||||
| .control-group.warning .select2-container .select2-choice div { | ||||
|     border-left: 1px solid #C09853 !important; | ||||
|     background: #FCF8E3 !important; | ||||
| } | ||||
|  | ||||
| .control-group.error .select2-container .select2-choice, | ||||
| .control-group.error .select2-container .select2-choices, | ||||
| .control-group.error .select2-container-active .select2-choice, | ||||
| .control-group.error .select2-container-active .select2-choices, | ||||
| .control-group.error .select2-dropdown-open.select2-drop-above .select2-choice, | ||||
| .control-group.error .select2-dropdown-open.select2-drop-above .select2-choices, | ||||
| .control-group.error .select2-container-multi.select2-container-active .select2-choices { | ||||
|     border: 1px solid #B94A48 !important; | ||||
| } | ||||
|  | ||||
| .control-group.error .select2-container .select2-choice div { | ||||
|     border-left: 1px solid #B94A48 !important; | ||||
|     background: #F2DEDE !important; | ||||
| } | ||||
|  | ||||
| .control-group.info .select2-container .select2-choice, | ||||
| .control-group.info .select2-container .select2-choices, | ||||
| .control-group.info .select2-container-active .select2-choice, | ||||
| .control-group.info .select2-container-active .select2-choices, | ||||
| .control-group.info .select2-dropdown-open.select2-drop-above .select2-choice, | ||||
| .control-group.info .select2-dropdown-open.select2-drop-above .select2-choices, | ||||
| .control-group.info .select2-container-multi.select2-container-active .select2-choices { | ||||
|     border: 1px solid #3A87AD !important; | ||||
| } | ||||
|  | ||||
| .control-group.info .select2-container .select2-choice div { | ||||
|     border-left: 1px solid #3A87AD !important; | ||||
|     background: #D9EDF7 !important; | ||||
| } | ||||
|  | ||||
| .control-group.success .select2-container .select2-choice, | ||||
| .control-group.success .select2-container .select2-choices, | ||||
| .control-group.success .select2-container-active .select2-choice, | ||||
| .control-group.success .select2-container-active .select2-choices, | ||||
| .control-group.success .select2-dropdown-open.select2-drop-above .select2-choice, | ||||
| .control-group.success .select2-dropdown-open.select2-drop-above .select2-choices, | ||||
| .control-group.success .select2-container-multi.select2-container-active .select2-choices { | ||||
|     border: 1px solid #468847 !important; | ||||
| } | ||||
|  | ||||
| .control-group.success .select2-container .select2-choice div { | ||||
|     border-left: 1px solid #468847 !important; | ||||
|     background: #DFF0D8 !important; | ||||
| } | ||||
| Before Width: | Height: | Size: 1.8 KiB | 
							
								
								
									
										615
									
								
								src/inputs/select2/lib/select2.css
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,615 +0,0 @@ | ||||
| /* | ||||
| Version: 3.4.4 Timestamp: Thu Oct 24 13:23:11 PDT 2013 | ||||
| */ | ||||
| .select2-container { | ||||
|     margin: 0; | ||||
|     position: relative; | ||||
|     display: inline-block; | ||||
|     /* inline-block for ie7 */ | ||||
|     zoom: 1; | ||||
|     *display: inline; | ||||
|     vertical-align: middle; | ||||
| } | ||||
|  | ||||
| .select2-container, | ||||
| .select2-drop, | ||||
| .select2-search, | ||||
| .select2-search input { | ||||
|   /* | ||||
|     Force border-box so that % widths fit the parent | ||||
|     container without overlap because of margin/padding. | ||||
|  | ||||
|     More Info : http://www.quirksmode.org/css/box.html | ||||
|   */ | ||||
|   -webkit-box-sizing: border-box; /* webkit */ | ||||
|      -moz-box-sizing: border-box; /* firefox */ | ||||
|           box-sizing: border-box; /* css3 */ | ||||
| } | ||||
|  | ||||
| .select2-container .select2-choice { | ||||
|     display: block; | ||||
|     height: 26px; | ||||
|     padding: 0 0 0 8px; | ||||
|     overflow: hidden; | ||||
|     position: relative; | ||||
|  | ||||
|     border: 1px solid #aaa; | ||||
|     white-space: nowrap; | ||||
|     line-height: 26px; | ||||
|     color: #444; | ||||
|     text-decoration: none; | ||||
|  | ||||
|     border-radius: 4px; | ||||
|  | ||||
|     background-clip: padding-box; | ||||
|  | ||||
|     -webkit-touch-callout: none; | ||||
|       -webkit-user-select: none; | ||||
|          -moz-user-select: none; | ||||
|           -ms-user-select: none; | ||||
|               user-select: none; | ||||
|  | ||||
|     background-color: #fff; | ||||
|     background-image: -webkit-gradient(linear, left bottom, left top, color-stop(0, #eee), color-stop(0.5, #fff)); | ||||
|     background-image: -webkit-linear-gradient(center bottom, #eee 0%, #fff 50%); | ||||
|     background-image: -moz-linear-gradient(center bottom, #eee 0%, #fff 50%); | ||||
|     filter: progid:DXImageTransform.Microsoft.gradient(startColorstr = '#ffffff', endColorstr = '#eeeeee', GradientType = 0); | ||||
|     background-image: linear-gradient(top, #fff 0%, #eee 50%); | ||||
| } | ||||
|  | ||||
| .select2-container.select2-drop-above .select2-choice { | ||||
|     border-bottom-color: #aaa; | ||||
|  | ||||
|     border-radius: 0 0 4px 4px; | ||||
|  | ||||
|     background-image: -webkit-gradient(linear, left bottom, left top, color-stop(0, #eee), color-stop(0.9, #fff)); | ||||
|     background-image: -webkit-linear-gradient(center bottom, #eee 0%, #fff 90%); | ||||
|     background-image: -moz-linear-gradient(center bottom, #eee 0%, #fff 90%); | ||||
|     filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#eeeeee', GradientType=0); | ||||
|     background-image: linear-gradient(top, #eee 0%, #fff 90%); | ||||
| } | ||||
|  | ||||
| .select2-container.select2-allowclear .select2-choice .select2-chosen { | ||||
|     margin-right: 42px; | ||||
| } | ||||
|  | ||||
| .select2-container .select2-choice > .select2-chosen { | ||||
|     margin-right: 26px; | ||||
|     display: block; | ||||
|     overflow: hidden; | ||||
|  | ||||
|     white-space: nowrap; | ||||
|  | ||||
|     text-overflow: ellipsis; | ||||
| } | ||||
|  | ||||
| .select2-container .select2-choice abbr { | ||||
|     display: none; | ||||
|     width: 12px; | ||||
|     height: 12px; | ||||
|     position: absolute; | ||||
|     right: 24px; | ||||
|     top: 8px; | ||||
|  | ||||
|     font-size: 1px; | ||||
|     text-decoration: none; | ||||
|  | ||||
|     border: 0; | ||||
|     background: url('select2.png') right top no-repeat; | ||||
|     cursor: pointer; | ||||
|     outline: 0; | ||||
| } | ||||
|  | ||||
| .select2-container.select2-allowclear .select2-choice abbr { | ||||
|     display: inline-block; | ||||
| } | ||||
|  | ||||
| .select2-container .select2-choice abbr:hover { | ||||
|     background-position: right -11px; | ||||
|     cursor: pointer; | ||||
| } | ||||
|  | ||||
| .select2-drop-mask { | ||||
|     border: 0; | ||||
|     margin: 0; | ||||
|     padding: 0; | ||||
|     position: fixed; | ||||
|     left: 0; | ||||
|     top: 0; | ||||
|     min-height: 100%; | ||||
|     min-width: 100%; | ||||
|     height: auto; | ||||
|     width: auto; | ||||
|     opacity: 0; | ||||
|     z-index: 9998; | ||||
|     /* styles required for IE to work */ | ||||
|     background-color: #fff; | ||||
|     filter: alpha(opacity=0); | ||||
| } | ||||
|  | ||||
| .select2-drop { | ||||
|     width: 100%; | ||||
|     margin-top: -1px; | ||||
|     position: absolute; | ||||
|     z-index: 9999; | ||||
|     top: 100%; | ||||
|  | ||||
|     background: #fff; | ||||
|     color: #000; | ||||
|     border: 1px solid #aaa; | ||||
|     border-top: 0; | ||||
|  | ||||
|     border-radius: 0 0 4px 4px; | ||||
|  | ||||
|     -webkit-box-shadow: 0 4px 5px rgba(0, 0, 0, .15); | ||||
|             box-shadow: 0 4px 5px rgba(0, 0, 0, .15); | ||||
| } | ||||
|  | ||||
| .select2-drop-auto-width { | ||||
|     border-top: 1px solid #aaa; | ||||
|     width: auto; | ||||
| } | ||||
|  | ||||
| .select2-drop-auto-width .select2-search { | ||||
|     padding-top: 4px; | ||||
| } | ||||
|  | ||||
| .select2-drop.select2-drop-above { | ||||
|     margin-top: 1px; | ||||
|     border-top: 1px solid #aaa; | ||||
|     border-bottom: 0; | ||||
|  | ||||
|     border-radius: 4px 4px 0 0; | ||||
|  | ||||
|     -webkit-box-shadow: 0 -4px 5px rgba(0, 0, 0, .15); | ||||
|             box-shadow: 0 -4px 5px rgba(0, 0, 0, .15); | ||||
| } | ||||
|  | ||||
| .select2-drop-active { | ||||
|     border: 1px solid #5897fb; | ||||
|     border-top: none; | ||||
| } | ||||
|  | ||||
| .select2-drop.select2-drop-above.select2-drop-active { | ||||
|     border-top: 1px solid #5897fb; | ||||
| } | ||||
|  | ||||
| .select2-container .select2-choice .select2-arrow { | ||||
|     display: inline-block; | ||||
|     width: 18px; | ||||
|     height: 100%; | ||||
|     position: absolute; | ||||
|     right: 0; | ||||
|     top: 0; | ||||
|  | ||||
|     border-left: 1px solid #aaa; | ||||
|     border-radius: 0 4px 4px 0; | ||||
|  | ||||
|     background-clip: padding-box; | ||||
|  | ||||
|     background: #ccc; | ||||
|     background-image: -webkit-gradient(linear, left bottom, left top, color-stop(0, #ccc), color-stop(0.6, #eee)); | ||||
|     background-image: -webkit-linear-gradient(center bottom, #ccc 0%, #eee 60%); | ||||
|     background-image: -moz-linear-gradient(center bottom, #ccc 0%, #eee 60%); | ||||
|     filter: progid:DXImageTransform.Microsoft.gradient(startColorstr = '#eeeeee', endColorstr = '#cccccc', GradientType = 0); | ||||
|     background-image: linear-gradient(top, #ccc 0%, #eee 60%); | ||||
| } | ||||
|  | ||||
| .select2-container .select2-choice .select2-arrow b { | ||||
|     display: block; | ||||
|     width: 100%; | ||||
|     height: 100%; | ||||
|     background: url('select2.png') no-repeat 0 1px; | ||||
| } | ||||
|  | ||||
| .select2-search { | ||||
|     display: inline-block; | ||||
|     width: 100%; | ||||
|     min-height: 26px; | ||||
|     margin: 0; | ||||
|     padding-left: 4px; | ||||
|     padding-right: 4px; | ||||
|  | ||||
|     position: relative; | ||||
|     z-index: 10000; | ||||
|  | ||||
|     white-space: nowrap; | ||||
| } | ||||
|  | ||||
| .select2-search input { | ||||
|     width: 100%; | ||||
|     height: auto !important; | ||||
|     min-height: 26px; | ||||
|     padding: 4px 20px 4px 5px; | ||||
|     margin: 0; | ||||
|  | ||||
|     outline: 0; | ||||
|     font-family: sans-serif; | ||||
|     font-size: 1em; | ||||
|  | ||||
|     border: 1px solid #aaa; | ||||
|     border-radius: 0; | ||||
|  | ||||
|     -webkit-box-shadow: none; | ||||
|             box-shadow: none; | ||||
|  | ||||
|     background: #fff url('select2.png') no-repeat 100% -22px; | ||||
|     background: url('select2.png') no-repeat 100% -22px, -webkit-gradient(linear, left bottom, left top, color-stop(0.85, #fff), color-stop(0.99, #eee)); | ||||
|     background: url('select2.png') no-repeat 100% -22px, -webkit-linear-gradient(center bottom, #fff 85%, #eee 99%); | ||||
|     background: url('select2.png') no-repeat 100% -22px, -moz-linear-gradient(center bottom, #fff 85%, #eee 99%); | ||||
|     background: url('select2.png') no-repeat 100% -22px, linear-gradient(top, #fff 85%, #eee 99%); | ||||
| } | ||||
|  | ||||
| .select2-drop.select2-drop-above .select2-search input { | ||||
|     margin-top: 4px; | ||||
| } | ||||
|  | ||||
| .select2-search input.select2-active { | ||||
|     background: #fff url('select2-spinner.gif') no-repeat 100%; | ||||
|     background: url('select2-spinner.gif') no-repeat 100%, -webkit-gradient(linear, left bottom, left top, color-stop(0.85, #fff), color-stop(0.99, #eee)); | ||||
|     background: url('select2-spinner.gif') no-repeat 100%, -webkit-linear-gradient(center bottom, #fff 85%, #eee 99%); | ||||
|     background: url('select2-spinner.gif') no-repeat 100%, -moz-linear-gradient(center bottom, #fff 85%, #eee 99%); | ||||
|     background: url('select2-spinner.gif') no-repeat 100%, linear-gradient(top, #fff 85%, #eee 99%); | ||||
| } | ||||
|  | ||||
| .select2-container-active .select2-choice, | ||||
| .select2-container-active .select2-choices { | ||||
|     border: 1px solid #5897fb; | ||||
|     outline: none; | ||||
|  | ||||
|     -webkit-box-shadow: 0 0 5px rgba(0, 0, 0, .3); | ||||
|             box-shadow: 0 0 5px rgba(0, 0, 0, .3); | ||||
| } | ||||
|  | ||||
| .select2-dropdown-open .select2-choice { | ||||
|     border-bottom-color: transparent; | ||||
|     -webkit-box-shadow: 0 1px 0 #fff inset; | ||||
|             box-shadow: 0 1px 0 #fff inset; | ||||
|  | ||||
|     border-bottom-left-radius: 0; | ||||
|     border-bottom-right-radius: 0; | ||||
|  | ||||
|     background-color: #eee; | ||||
|     background-image: -webkit-gradient(linear, left bottom, left top, color-stop(0, #fff), color-stop(0.5, #eee)); | ||||
|     background-image: -webkit-linear-gradient(center bottom, #fff 0%, #eee 50%); | ||||
|     background-image: -moz-linear-gradient(center bottom, #fff 0%, #eee 50%); | ||||
|     filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#eeeeee', endColorstr='#ffffff', GradientType=0); | ||||
|     background-image: linear-gradient(top, #fff 0%, #eee 50%); | ||||
| } | ||||
|  | ||||
| .select2-dropdown-open.select2-drop-above .select2-choice, | ||||
| .select2-dropdown-open.select2-drop-above .select2-choices { | ||||
|     border: 1px solid #5897fb; | ||||
|     border-top-color: transparent; | ||||
|  | ||||
|     background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0, #fff), color-stop(0.5, #eee)); | ||||
|     background-image: -webkit-linear-gradient(center top, #fff 0%, #eee 50%); | ||||
|     background-image: -moz-linear-gradient(center top, #fff 0%, #eee 50%); | ||||
|     filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#eeeeee', endColorstr='#ffffff', GradientType=0); | ||||
|     background-image: linear-gradient(bottom, #fff 0%, #eee 50%); | ||||
| } | ||||
|  | ||||
| .select2-dropdown-open .select2-choice .select2-arrow { | ||||
|     background: transparent; | ||||
|     border-left: none; | ||||
|     filter: none; | ||||
| } | ||||
| .select2-dropdown-open .select2-choice .select2-arrow b { | ||||
|     background-position: -18px 1px; | ||||
| } | ||||
|  | ||||
| /* results */ | ||||
| .select2-results { | ||||
|     max-height: 200px; | ||||
|     padding: 0 0 0 4px; | ||||
|     margin: 4px 4px 4px 0; | ||||
|     position: relative; | ||||
|     overflow-x: hidden; | ||||
|     overflow-y: auto; | ||||
|     -webkit-tap-highlight-color: rgba(0, 0, 0, 0); | ||||
| } | ||||
|  | ||||
| .select2-results ul.select2-result-sub { | ||||
|     margin: 0; | ||||
|     padding-left: 0; | ||||
| } | ||||
|  | ||||
| .select2-results ul.select2-result-sub > li .select2-result-label { padding-left: 20px } | ||||
| .select2-results ul.select2-result-sub ul.select2-result-sub > li .select2-result-label { padding-left: 40px } | ||||
| .select2-results ul.select2-result-sub ul.select2-result-sub ul.select2-result-sub > li .select2-result-label { padding-left: 60px } | ||||
| .select2-results ul.select2-result-sub ul.select2-result-sub ul.select2-result-sub ul.select2-result-sub > li .select2-result-label { padding-left: 80px } | ||||
| .select2-results ul.select2-result-sub ul.select2-result-sub ul.select2-result-sub ul.select2-result-sub ul.select2-result-sub > li .select2-result-label { padding-left: 100px } | ||||
| .select2-results ul.select2-result-sub ul.select2-result-sub ul.select2-result-sub ul.select2-result-sub ul.select2-result-sub ul.select2-result-sub > li .select2-result-label { padding-left: 110px } | ||||
| .select2-results ul.select2-result-sub ul.select2-result-sub ul.select2-result-sub ul.select2-result-sub ul.select2-result-sub ul.select2-result-sub ul.select2-result-sub > li .select2-result-label { padding-left: 120px } | ||||
|  | ||||
| .select2-results li { | ||||
|     list-style: none; | ||||
|     display: list-item; | ||||
|     background-image: none; | ||||
| } | ||||
|  | ||||
| .select2-results li.select2-result-with-children > .select2-result-label { | ||||
|     font-weight: bold; | ||||
| } | ||||
|  | ||||
| .select2-results .select2-result-label { | ||||
|     padding: 3px 7px 4px; | ||||
|     margin: 0; | ||||
|     cursor: pointer; | ||||
|  | ||||
|     min-height: 1em; | ||||
|  | ||||
|     -webkit-touch-callout: none; | ||||
|       -webkit-user-select: none; | ||||
|          -moz-user-select: none; | ||||
|           -ms-user-select: none; | ||||
|               user-select: none; | ||||
| } | ||||
|  | ||||
| .select2-results .select2-highlighted { | ||||
|     background: #3875d7; | ||||
|     color: #fff; | ||||
| } | ||||
|  | ||||
| .select2-results li em { | ||||
|     background: #feffde; | ||||
|     font-style: normal; | ||||
| } | ||||
|  | ||||
| .select2-results .select2-highlighted em { | ||||
|     background: transparent; | ||||
| } | ||||
|  | ||||
| .select2-results .select2-highlighted ul { | ||||
|     background: #fff; | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
|  | ||||
| .select2-results .select2-no-results, | ||||
| .select2-results .select2-searching, | ||||
| .select2-results .select2-selection-limit { | ||||
|     background: #f4f4f4; | ||||
|     display: list-item; | ||||
| } | ||||
|  | ||||
| /* | ||||
| disabled look for disabled choices in the results dropdown | ||||
| */ | ||||
| .select2-results .select2-disabled.select2-highlighted { | ||||
|     color: #666; | ||||
|     background: #f4f4f4; | ||||
|     display: list-item; | ||||
|     cursor: default; | ||||
| } | ||||
| .select2-results .select2-disabled { | ||||
|   background: #f4f4f4; | ||||
|   display: list-item; | ||||
|   cursor: default; | ||||
| } | ||||
|  | ||||
| .select2-results .select2-selected { | ||||
|     display: none; | ||||
| } | ||||
|  | ||||
| .select2-more-results.select2-active { | ||||
|     background: #f4f4f4 url('select2-spinner.gif') no-repeat 100%; | ||||
| } | ||||
|  | ||||
| .select2-more-results { | ||||
|     background: #f4f4f4; | ||||
|     display: list-item; | ||||
| } | ||||
|  | ||||
| /* disabled styles */ | ||||
|  | ||||
| .select2-container.select2-container-disabled .select2-choice { | ||||
|     background-color: #f4f4f4; | ||||
|     background-image: none; | ||||
|     border: 1px solid #ddd; | ||||
|     cursor: default; | ||||
| } | ||||
|  | ||||
| .select2-container.select2-container-disabled .select2-choice .select2-arrow { | ||||
|     background-color: #f4f4f4; | ||||
|     background-image: none; | ||||
|     border-left: 0; | ||||
| } | ||||
|  | ||||
| .select2-container.select2-container-disabled .select2-choice abbr { | ||||
|     display: none; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* multiselect */ | ||||
|  | ||||
| .select2-container-multi .select2-choices { | ||||
|     height: auto !important; | ||||
|     height: 1%; | ||||
|     margin: 0; | ||||
|     padding: 0; | ||||
|     position: relative; | ||||
|  | ||||
|     border: 1px solid #aaa; | ||||
|     cursor: text; | ||||
|     overflow: hidden; | ||||
|  | ||||
|     background-color: #fff; | ||||
|     background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, color-stop(1%, #eee), color-stop(15%, #fff)); | ||||
|     background-image: -webkit-linear-gradient(top, #eee 1%, #fff 15%); | ||||
|     background-image: -moz-linear-gradient(top, #eee 1%, #fff 15%); | ||||
|     background-image: linear-gradient(top, #eee 1%, #fff 15%); | ||||
| } | ||||
|  | ||||
| .select2-locked { | ||||
|   padding: 3px 5px 3px 5px !important; | ||||
| } | ||||
|  | ||||
| .select2-container-multi .select2-choices { | ||||
|     min-height: 26px; | ||||
| } | ||||
|  | ||||
| .select2-container-multi.select2-container-active .select2-choices { | ||||
|     border: 1px solid #5897fb; | ||||
|     outline: none; | ||||
|  | ||||
|     -webkit-box-shadow: 0 0 5px rgba(0, 0, 0, .3); | ||||
|             box-shadow: 0 0 5px rgba(0, 0, 0, .3); | ||||
| } | ||||
| .select2-container-multi .select2-choices li { | ||||
|     float: left; | ||||
|     list-style: none; | ||||
| } | ||||
| .select2-container-multi .select2-choices .select2-search-field { | ||||
|     margin: 0; | ||||
|     padding: 0; | ||||
|     white-space: nowrap; | ||||
| } | ||||
|  | ||||
| .select2-container-multi .select2-choices .select2-search-field input { | ||||
|     padding: 5px; | ||||
|     margin: 1px 0; | ||||
|  | ||||
|     font-family: sans-serif; | ||||
|     font-size: 100%; | ||||
|     color: #666; | ||||
|     outline: 0; | ||||
|     border: 0; | ||||
|     -webkit-box-shadow: none; | ||||
|             box-shadow: none; | ||||
|     background: transparent !important; | ||||
| } | ||||
|  | ||||
| .select2-container-multi .select2-choices .select2-search-field input.select2-active { | ||||
|     background: #fff url('select2-spinner.gif') no-repeat 100% !important; | ||||
| } | ||||
|  | ||||
| .select2-default { | ||||
|     color: #999 !important; | ||||
| } | ||||
|  | ||||
| .select2-container-multi .select2-choices .select2-search-choice { | ||||
|     padding: 3px 5px 3px 18px; | ||||
|     margin: 3px 0 3px 5px; | ||||
|     position: relative; | ||||
|  | ||||
|     line-height: 13px; | ||||
|     color: #333; | ||||
|     cursor: default; | ||||
|     border: 1px solid #aaaaaa; | ||||
|  | ||||
|     border-radius: 3px; | ||||
|  | ||||
|     -webkit-box-shadow: 0 0 2px #fff inset, 0 1px 0 rgba(0, 0, 0, 0.05); | ||||
|             box-shadow: 0 0 2px #fff inset, 0 1px 0 rgba(0, 0, 0, 0.05); | ||||
|  | ||||
|     background-clip: padding-box; | ||||
|  | ||||
|     -webkit-touch-callout: none; | ||||
|       -webkit-user-select: none; | ||||
|          -moz-user-select: none; | ||||
|           -ms-user-select: none; | ||||
|               user-select: none; | ||||
|  | ||||
|     background-color: #e4e4e4; | ||||
|     filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#eeeeee', endColorstr='#f4f4f4', GradientType=0); | ||||
|     background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, color-stop(20%, #f4f4f4), color-stop(50%, #f0f0f0), color-stop(52%, #e8e8e8), color-stop(100%, #eee)); | ||||
|     background-image: -webkit-linear-gradient(top, #f4f4f4 20%, #f0f0f0 50%, #e8e8e8 52%, #eee 100%); | ||||
|     background-image: -moz-linear-gradient(top, #f4f4f4 20%, #f0f0f0 50%, #e8e8e8 52%, #eee 100%); | ||||
|     background-image: linear-gradient(top, #f4f4f4 20%, #f0f0f0 50%, #e8e8e8 52%, #eee 100%); | ||||
| } | ||||
| .select2-container-multi .select2-choices .select2-search-choice .select2-chosen { | ||||
|     cursor: default; | ||||
| } | ||||
| .select2-container-multi .select2-choices .select2-search-choice-focus { | ||||
|     background: #d4d4d4; | ||||
| } | ||||
|  | ||||
| .select2-search-choice-close { | ||||
|     display: block; | ||||
|     width: 12px; | ||||
|     height: 13px; | ||||
|     position: absolute; | ||||
|     right: 3px; | ||||
|     top: 4px; | ||||
|  | ||||
|     font-size: 1px; | ||||
|     outline: none; | ||||
|     background: url('select2.png') right top no-repeat; | ||||
| } | ||||
|  | ||||
| .select2-container-multi .select2-search-choice-close { | ||||
|     left: 3px; | ||||
| } | ||||
|  | ||||
| .select2-container-multi .select2-choices .select2-search-choice .select2-search-choice-close:hover { | ||||
|   background-position: right -11px; | ||||
| } | ||||
| .select2-container-multi .select2-choices .select2-search-choice-focus .select2-search-choice-close { | ||||
|     background-position: right -11px; | ||||
| } | ||||
|  | ||||
| /* disabled styles */ | ||||
| .select2-container-multi.select2-container-disabled .select2-choices { | ||||
|     background-color: #f4f4f4; | ||||
|     background-image: none; | ||||
|     border: 1px solid #ddd; | ||||
|     cursor: default; | ||||
| } | ||||
|  | ||||
| .select2-container-multi.select2-container-disabled .select2-choices .select2-search-choice { | ||||
|     padding: 3px 5px 3px 5px; | ||||
|     border: 1px solid #ddd; | ||||
|     background-image: none; | ||||
|     background-color: #f4f4f4; | ||||
| } | ||||
|  | ||||
| .select2-container-multi.select2-container-disabled .select2-choices .select2-search-choice .select2-search-choice-close {    display: none; | ||||
|     background: none; | ||||
| } | ||||
| /* end multiselect */ | ||||
|  | ||||
|  | ||||
| .select2-result-selectable .select2-match, | ||||
| .select2-result-unselectable .select2-match { | ||||
|     text-decoration: underline; | ||||
| } | ||||
|  | ||||
| .select2-offscreen, .select2-offscreen:focus { | ||||
|     clip: rect(0 0 0 0) !important; | ||||
|     width: 1px !important; | ||||
|     height: 1px !important; | ||||
|     border: 0 !important; | ||||
|     margin: 0 !important; | ||||
|     padding: 0 !important; | ||||
|     overflow: hidden !important; | ||||
|     position: absolute !important; | ||||
|     outline: 0 !important; | ||||
|     left: 0px !important; | ||||
|     top: 0px !important; | ||||
| } | ||||
|  | ||||
| .select2-display-none { | ||||
|     display: none; | ||||
| } | ||||
|  | ||||
| .select2-measure-scrollbar { | ||||
|     position: absolute; | ||||
|     top: -10000px; | ||||
|     left: -10000px; | ||||
|     width: 100px; | ||||
|     height: 100px; | ||||
|     overflow: scroll; | ||||
| } | ||||
| /* Retina-ize icons */ | ||||
|  | ||||
| @media only screen and (-webkit-min-device-pixel-ratio: 1.5), only screen and (min-resolution: 144dpi)  { | ||||
|   .select2-search input, .select2-search-choice-close, .select2-container .select2-choice abbr, .select2-container .select2-choice .select2-arrow b { | ||||
|       background-image: url('select2x2.png') !important; | ||||
|       background-repeat: no-repeat !important; | ||||
|       background-size: 60px 40px !important; | ||||
|   } | ||||
|   .select2-search input { | ||||
|       background-position: 100% -21px !important; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										3251
									
								
								src/inputs/select2/lib/select2.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
							
								
								
									
										22
									
								
								src/inputs/select2/lib/select2.min.js
									
									
									
									
										vendored
									
									
								
							
							
						
						| Before Width: | Height: | Size: 613 B | 
| Before Width: | Height: | Size: 845 B | 
							
								
								
									
										350
									
								
								src/inputs/select2/select2.js
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,350 +0,0 @@ | ||||
| /** | ||||
| Select2 input. Based on amazing work of Igor Vaynberg https://github.com/ivaynberg/select2.   | ||||
| Please see [original select2 docs](http://ivaynberg.github.com/select2) for detailed description and options.   | ||||
|   | ||||
| You should manually download and include select2 distributive:   | ||||
|  | ||||
|     <link href="select2/select2.css" rel="stylesheet" type="text/css"></link>   | ||||
|     <script src="select2/select2.js"></script>   | ||||
|      | ||||
| To make it **bootstrap-styled** you can use css from [here](https://github.com/t0m/select2-bootstrap-css):  | ||||
|  | ||||
|     <link href="select2-bootstrap.css" rel="stylesheet" type="text/css"></link>     | ||||
|      | ||||
| **Note:** currently `autotext` feature does not work for select2 with `ajax` remote source.     | ||||
| You need initially put both `data-value` and element's text youself:     | ||||
|  | ||||
|     <a href="#" data-type="select2" data-value="1">Text1</a> | ||||
|      | ||||
|      | ||||
| @class select2 | ||||
| @extends abstractinput | ||||
| @since 1.4.1 | ||||
| @final | ||||
| @example | ||||
| <a href="#" id="country" data-type="select2" data-pk="1" data-value="ru" data-url="/post" data-title="Select country"></a> | ||||
| <script> | ||||
| $(function(){ | ||||
|     //local source | ||||
|     $('#country').editable({ | ||||
|         source: [ | ||||
|               {id: 'gb', text: 'Great Britain'}, | ||||
|               {id: 'us', text: 'United States'}, | ||||
|               {id: 'ru', text: 'Russia'} | ||||
|            ], | ||||
|         select2: { | ||||
|            multiple: true | ||||
|         } | ||||
|     }); | ||||
|     //remote source (simple) | ||||
|     $('#country').editable({ | ||||
|         source: '/getCountries', | ||||
|         select2: { | ||||
|             placeholder: 'Select Country', | ||||
|             minimumInputLength: 1 | ||||
|         } | ||||
|     }); | ||||
|     //remote source (advanced) | ||||
|     $('#country').editable({ | ||||
|         select2: { | ||||
|             placeholder: 'Select Country', | ||||
|             allowClear: true, | ||||
|             minimumInputLength: 3, | ||||
|             id: function (item) { | ||||
|                 return item.CountryId; | ||||
|             }, | ||||
|             ajax: { | ||||
|                 url: '/getCountries', | ||||
|                 dataType: 'json', | ||||
|                 data: function (term, page) { | ||||
|                     return { query: term }; | ||||
|                 }, | ||||
|                 results: function (data, page) { | ||||
|                     return { results: data }; | ||||
|                 } | ||||
|             }, | ||||
|             formatResult: function (item) { | ||||
|                 return item.CountryName; | ||||
|             }, | ||||
|             formatSelection: function (item) { | ||||
|                 return item.CountryName; | ||||
|             }, | ||||
|             initSelection: function (element, callback) { | ||||
|                 return $.get('/getCountryById', { query: element.val() }, function (data) { | ||||
|                     callback(data); | ||||
|                 }); | ||||
|             }  | ||||
|         }   | ||||
|     }); | ||||
| }); | ||||
| </script> | ||||
| **/ | ||||
| (function ($) { | ||||
|     "use strict"; | ||||
|      | ||||
|     var Constructor = function (options) { | ||||
|         this.init('select2', options, Constructor.defaults); | ||||
|  | ||||
|         options.select2 = options.select2 || {}; | ||||
|  | ||||
|         this.sourceData = null; | ||||
|          | ||||
|         //placeholder | ||||
|         if(options.placeholder) { | ||||
|             options.select2.placeholder = options.placeholder; | ||||
|         } | ||||
|         | ||||
|         //if not `tags` mode, use source | ||||
|         if(!options.select2.tags && options.source) { | ||||
|             var source = options.source; | ||||
|             //if source is function, call it (once!) | ||||
|             if (typeof (options.source) === 'function') { | ||||
|                 source = options.source.call(options.scope); | ||||
|             }                | ||||
|  | ||||
|             if (typeof source === 'string') { | ||||
|                 options.select2.ajax = options.select2.ajax || {}; | ||||
|                 //some default ajax params | ||||
|                 if(!options.select2.ajax.data) { | ||||
|                     options.select2.ajax.data = function(term) {return { query:term };}; | ||||
|                 } | ||||
|                 if(!options.select2.ajax.results) { | ||||
|                     options.select2.ajax.results = function(data) { return {results:data };}; | ||||
|                 } | ||||
|                 options.select2.ajax.url = source; | ||||
|             } else { | ||||
|                 //check format and convert x-editable format to select2 format (if needed) | ||||
|                 this.sourceData = this.convertSource(source); | ||||
|                 options.select2.data = this.sourceData; | ||||
|             } | ||||
|         }  | ||||
|  | ||||
|         //overriding objects in config (as by default jQuery extend() is not recursive) | ||||
|         this.options.select2 = $.extend({}, Constructor.defaults.select2, options.select2); | ||||
|  | ||||
|         //detect whether it is multi-valued | ||||
|         this.isMultiple = this.options.select2.tags || this.options.select2.multiple; | ||||
|         this.isRemote = ('ajax' in this.options.select2); | ||||
|  | ||||
|         //store function returning ID of item | ||||
|         //should be here as used inautotext for local source | ||||
|         this.idFunc = this.options.select2.id; | ||||
|         if (typeof(this.idFunc) !== "function") { | ||||
|             var idKey = this.idFunc || 'id'; | ||||
|             this.idFunc = function (e) { return e[idKey]; }; | ||||
|         } | ||||
|  | ||||
|         //store function that renders text in select2 | ||||
|         this.formatSelection = this.options.select2.formatSelection; | ||||
|         if (typeof(this.formatSelection) !== "function") { | ||||
|             this.formatSelection = function (e) { return e.text; }; | ||||
|         } | ||||
|     }; | ||||
|  | ||||
|     $.fn.editableutils.inherit(Constructor, $.fn.editabletypes.abstractinput); | ||||
|  | ||||
|     $.extend(Constructor.prototype, { | ||||
|         render: function() { | ||||
|             this.setClass(); | ||||
|  | ||||
|             //can not apply select2 here as it calls initSelection  | ||||
|             //over input that does not have correct value yet. | ||||
|             //apply select2 only in value2input | ||||
|             //this.$input.select2(this.options.select2); | ||||
|  | ||||
|             //when data is loaded via ajax, we need to know when it's done to populate listData | ||||
|             if(this.isRemote) { | ||||
|                 //listen to loaded event to populate data | ||||
|                 this.$input.on('select2-loaded', $.proxy(function(e) { | ||||
|                     this.sourceData = e.items.results; | ||||
|                 }, this)); | ||||
|             } | ||||
|  | ||||
|             //trigger resize of editableform to re-position container in multi-valued mode | ||||
|             if(this.isMultiple) { | ||||
|                this.$input.on('change', function() { | ||||
|                    $(this).closest('form').parent().triggerHandler('resize'); | ||||
|                }); | ||||
|             } | ||||
|        }, | ||||
|  | ||||
|        value2html: function(value, element) { | ||||
|            var text = '', data, | ||||
|                that = this; | ||||
|  | ||||
|            if(this.options.select2.tags) { //in tags mode just assign value | ||||
|               data = value;  | ||||
|               //data = $.fn.editableutils.itemsByValue(value, this.options.select2.tags, this.idFunc); | ||||
|            } else if(this.sourceData) { | ||||
|               data = $.fn.editableutils.itemsByValue(value, this.sourceData, this.idFunc);  | ||||
|            } else { | ||||
|               //can not get list of possible values  | ||||
|               //(e.g. autotext for select2 with ajax source) | ||||
|            } | ||||
|  | ||||
|            //data may be array (when multiple values allowed) | ||||
|            if(Array.isArray(data)) { | ||||
|                //collect selected data and show with separator | ||||
|                text = []; | ||||
|                $.each(data, function(k, v){ | ||||
|                    text.push(v && typeof v === 'object' ? that.formatSelection(v) : v); | ||||
|                }); | ||||
|            } else if(data) { | ||||
|                text = that.formatSelection(data); | ||||
|            } | ||||
|  | ||||
|            text = Array.isArray(text) ? text.join(this.options.viewseparator) : text; | ||||
|  | ||||
|            //$(element).text(text); | ||||
|            Constructor.superclass.value2html.call(this, text, element);  | ||||
|        }, | ||||
|  | ||||
|        html2value: function(html) { | ||||
|            return this.options.select2.tags ? this.str2value(html, this.options.viewseparator) : null; | ||||
|        }, | ||||
|  | ||||
|        value2input: function(value) { | ||||
|            // if value array => join it anyway | ||||
|            if(Array.isArray(value)) { | ||||
|               value = value.join(this.getSeparator()); | ||||
|            } | ||||
|  | ||||
|            //for remote source just set value, text is updated by initSelection | ||||
|            if(!this.$input.data('select2')) { | ||||
|                this.$input.val(value); | ||||
|                this.$input.select2(this.options.select2); | ||||
|            } else { | ||||
|                //second argument needed to separate initial change from user's click (for autosubmit)    | ||||
|                this.$input.val(value).trigger('change', true);  | ||||
|  | ||||
|                //Uncaught Error: cannot call val() if initSelection() is not defined | ||||
|                //this.$input.select2('val', value); | ||||
|            } | ||||
|  | ||||
|            // if defined remote source AND no multiple mode AND no user's initSelection provided -->  | ||||
|            // we should somehow get text for provided id. | ||||
|            // The solution is to use element's text as text for that id (exclude empty) | ||||
|            if(this.isRemote && !this.isMultiple && !this.options.select2.initSelection) { | ||||
|                // customId and customText are methods to extract `id` and `text` from data object | ||||
|                // we can use this workaround only if user did not define these methods | ||||
|                // otherwise we cant construct data object | ||||
|                var customId = this.options.select2.id, | ||||
|                    customText = this.options.select2.formatSelection; | ||||
|  | ||||
|                if(!customId && !customText) { | ||||
|                    var $el = $(this.options.scope); | ||||
|                    if (!$el.data('editable').isEmpty) { | ||||
|                        var data = {id: value, text: $el.text()}; | ||||
|                        this.$input.select2('data', data);  | ||||
|                    } | ||||
|                } | ||||
|            } | ||||
|        }, | ||||
|         | ||||
|        input2value: function() {  | ||||
|            return this.$input.select2('val'); | ||||
|        }, | ||||
|  | ||||
|        str2value: function(str, separator) { | ||||
|             if(typeof str !== 'string' || !this.isMultiple) { | ||||
|                 return str; | ||||
|             } | ||||
|  | ||||
|             separator = separator || this.getSeparator(); | ||||
|  | ||||
|             var val, i, l; | ||||
|  | ||||
|             if (str === null || str.length < 1) { | ||||
|                 return null; | ||||
|             } | ||||
|             val = str.split(separator); | ||||
|             for (i = 0, l = val.length; i < l; i = i + 1) { | ||||
|                 val[i] = val[i].trim(); | ||||
|             } | ||||
|  | ||||
|             return val; | ||||
|        }, | ||||
|  | ||||
|         autosubmit: function() { | ||||
|             this.$input.on('change', function(e, isInitial){ | ||||
|                 if(!isInitial) { | ||||
|                   $(this).closest('form').submit(); | ||||
|                 } | ||||
|             }); | ||||
|         }, | ||||
|  | ||||
|         getSeparator: function() { | ||||
|             return this.options.select2.separator || $.fn.select2.defaults.separator; | ||||
|         }, | ||||
|  | ||||
|         /* | ||||
|         Converts source from x-editable format: {value: 1, text: "1"} to | ||||
|         select2 format: {id: 1, text: "1"} | ||||
|         */ | ||||
|         convertSource: function(source) { | ||||
|             if(Array.isArray(source) && source.length && source[0].value !== undefined) { | ||||
|                 for(var i = 0; i<source.length; i++) { | ||||
|                     if(source[i].value !== undefined) { | ||||
|                         source[i].id = source[i].value; | ||||
|                         delete source[i].value; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             return source; | ||||
|         }, | ||||
|          | ||||
|         destroy: function() { | ||||
| 	        if(this.$input) { | ||||
| 	            if(this.$input.data('select2')) { | ||||
| 	                this.$input.select2('destroy'); | ||||
| 	            } | ||||
| 	        } | ||||
|         } | ||||
|          | ||||
|     }); | ||||
|  | ||||
|     Constructor.defaults = $.extend({}, $.fn.editabletypes.abstractinput.defaults, { | ||||
|         /** | ||||
|         @property tpl  | ||||
|         @default <input type="hidden"> | ||||
|         **/ | ||||
|         tpl:'<input type="hidden">', | ||||
|         /** | ||||
|         Configuration of select2. [Full list of options](http://ivaynberg.github.com/select2). | ||||
|  | ||||
|         @property select2  | ||||
|         @type object | ||||
|         @default null | ||||
|         **/ | ||||
|         select2: null, | ||||
|         /** | ||||
|         Placeholder attribute of select | ||||
|  | ||||
|         @property placeholder  | ||||
|         @type string | ||||
|         @default null | ||||
|         **/ | ||||
|         placeholder: null, | ||||
|         /** | ||||
|         Source data for select. It will be assigned to select2 `data` property and kept here just for convenience. | ||||
|         Please note, that format is different from simple `select` input: use 'id' instead of 'value'. | ||||
|         E.g. `[{id: 1, text: "text1"}, {id: 2, text: "text2"}, ...]`. | ||||
|  | ||||
|         @property source  | ||||
|         @type array|string|function | ||||
|         @default null         | ||||
|         **/ | ||||
|         source: null, | ||||
|         /** | ||||
|         Separator used to display tags. | ||||
|  | ||||
|         @property viewseparator  | ||||
|         @type string | ||||
|         @default ', '         | ||||
|         **/ | ||||
|         viewseparator: ', ' | ||||
|     }); | ||||
|  | ||||
|     $.fn.editabletypes.select2 = Constructor; | ||||
|  | ||||
| }(window.jQuery)); | ||||
| @@ -1,268 +0,0 @@ | ||||
| /** | ||||
| Typeahead input (bootstrap 2 only). Based on Twitter Bootstrap 2 [typeahead](http://getbootstrap.com/2.3.2/javascript.html#typeahead).   | ||||
| Depending on `source` format typeahead operates in two modes: | ||||
|  | ||||
| * **strings**:   | ||||
|   When `source` defined as array of strings, e.g. `['text1', 'text2', 'text3' ...]`.   | ||||
|   User can submit one of these strings or any text entered in input (even if it is not matching source). | ||||
|    | ||||
| * **objects**:   | ||||
|   When `source` defined as array of objects, e.g. `[{value: 1, text: "text1"}, {value: 2, text: "text2"}, ...]`.   | ||||
|   User can submit only values that are in source (otherwise `null` is submitted). This is more like *dropdown* behavior. | ||||
|  | ||||
| @class typeahead | ||||
| @extends list | ||||
| @since 1.4.1 | ||||
| @final | ||||
| @example | ||||
| <a href="#" id="country" data-type="typeahead" data-pk="1" data-url="/post" data-title="Input country"></a> | ||||
| <script> | ||||
| $(function(){ | ||||
|     $('#country').editable({ | ||||
|         value: 'ru',     | ||||
|         source: [ | ||||
|               {value: 'gb', text: 'Great Britain'}, | ||||
|               {value: 'us', text: 'United States'}, | ||||
|               {value: 'ru', text: 'Russia'} | ||||
|            ] | ||||
|     }); | ||||
| }); | ||||
| </script> | ||||
| **/ | ||||
| (function ($) { | ||||
|     "use strict"; | ||||
|      | ||||
|     var Constructor = function (options) { | ||||
|         this.init('typeahead', options, Constructor.defaults); | ||||
|          | ||||
|         //overriding objects in config (as by default jQuery extend() is not recursive) | ||||
|         this.options.typeahead = $.extend({}, Constructor.defaults.typeahead, { | ||||
|             //set default methods for typeahead to work with objects | ||||
|             matcher: this.matcher,   | ||||
|             sorter: this.sorter,   | ||||
|             highlighter: this.highlighter,   | ||||
|             updater: this.updater   | ||||
|         }, options.typeahead); | ||||
|     }; | ||||
|  | ||||
|     $.fn.editableutils.inherit(Constructor, $.fn.editabletypes.list); | ||||
|  | ||||
|     $.extend(Constructor.prototype, { | ||||
|         renderList: function() { | ||||
|             this.$input = this.$tpl.is('input') ? this.$tpl : this.$tpl.find('input[type="text"]'); | ||||
|              | ||||
|             //set source of typeahead | ||||
|             this.options.typeahead.source = this.sourceData; | ||||
|              | ||||
|             //apply typeahead | ||||
|             this.$input.typeahead(this.options.typeahead); | ||||
|              | ||||
|             //patch some methods in typeahead | ||||
|             var ta = this.$input.data('typeahead'); | ||||
|             ta.render = $.proxy(this.typeaheadRender, ta); | ||||
|             ta.select = $.proxy(this.typeaheadSelect, ta); | ||||
|             ta.move = $.proxy(this.typeaheadMove, ta); | ||||
|  | ||||
|             this.renderClear(); | ||||
|             this.setClass(); | ||||
|             this.setAttr('placeholder'); | ||||
|         }, | ||||
|         | ||||
|         value2htmlFinal: function(value, element) { | ||||
|             if(this.getIsObjects()) { | ||||
|                 var items = $.fn.editableutils.itemsByValue(value, this.sourceData); | ||||
|                 value = items.length ? items[0].text : ''; | ||||
|             }  | ||||
|             $.fn.editabletypes.abstractinput.prototype.value2html.call(this, value, element); | ||||
|         }, | ||||
|          | ||||
|         html2value: function (html) { | ||||
|             return html ? html : null; | ||||
|         }, | ||||
|          | ||||
|         value2input: function(value) { | ||||
|             if(this.getIsObjects()) { | ||||
|                 var items = $.fn.editableutils.itemsByValue(value, this.sourceData); | ||||
|                 this.$input.data('value', value).val(items.length ? items[0].text : '');                 | ||||
|             } else { | ||||
|                 this.$input.val(value); | ||||
|             } | ||||
|         }, | ||||
|          | ||||
|         input2value: function() { | ||||
|             if(this.getIsObjects()) { | ||||
|                 var value = this.$input.data('value'), | ||||
|                     items = $.fn.editableutils.itemsByValue(value, this.sourceData); | ||||
|                      | ||||
|                 if(items.length && items[0].text.toLowerCase() === this.$input.val().toLowerCase()) { | ||||
|                    return value; | ||||
|                 } else { | ||||
|                    return null; //entered string not found in source | ||||
|                 }                  | ||||
|             } else { | ||||
|                 return this.$input.val(); | ||||
|             } | ||||
|         }, | ||||
|          | ||||
|         /* | ||||
|          if in sourceData values <> texts, typeahead in "objects" mode:  | ||||
|          user must pick some value from list, otherwise `null` returned. | ||||
|          if all values == texts put typeahead in "strings" mode: | ||||
|          anything what entered is submited. | ||||
|         */         | ||||
|         getIsObjects: function() { | ||||
|             if(this.isObjects === undefined) { | ||||
|                 this.isObjects = false; | ||||
|                 for(var i=0; i<this.sourceData.length; i++) { | ||||
|                     if(this.sourceData[i].value !== this.sourceData[i].text) { | ||||
|                         this.isObjects = true; | ||||
|                         break; | ||||
|                     }  | ||||
|                 } | ||||
|             }  | ||||
|             return this.isObjects; | ||||
|         },   | ||||
|                 | ||||
|         /* | ||||
|           Methods borrowed from text input | ||||
|         */ | ||||
|         activate: $.fn.editabletypes.text.prototype.activate, | ||||
|         renderClear: $.fn.editabletypes.text.prototype.renderClear, | ||||
|         postrender: $.fn.editabletypes.text.prototype.postrender, | ||||
|         toggleClear: $.fn.editabletypes.text.prototype.toggleClear, | ||||
|         clear: function() { | ||||
|             $.fn.editabletypes.text.prototype.clear.call(this); | ||||
|             this.$input.data('value', '');  | ||||
|         }, | ||||
|          | ||||
|          | ||||
|         /* | ||||
|           Typeahead option methods used as defaults | ||||
|         */ | ||||
|         /*jshint eqeqeq:false, curly: false, laxcomma: true, asi: true*/ | ||||
|         matcher: function (item) { | ||||
|             return $.fn.typeahead.Constructor.prototype.matcher.call(this, item.text); | ||||
|         }, | ||||
|         sorter: function (items) { | ||||
|             var beginswith = [] | ||||
|             , caseSensitive = [] | ||||
|             , caseInsensitive = [] | ||||
|             , item | ||||
|             , text; | ||||
|  | ||||
|             while (item = items.shift()) { | ||||
|                 text = item.text; | ||||
|                 if (!text.toLowerCase().indexOf(this.query.toLowerCase())) beginswith.push(item); | ||||
|                 else if (~text.indexOf(this.query)) caseSensitive.push(item); | ||||
|                 else caseInsensitive.push(item); | ||||
|             } | ||||
|  | ||||
|             return beginswith.concat(caseSensitive, caseInsensitive); | ||||
|         }, | ||||
|         highlighter: function (item) { | ||||
|             return $.fn.typeahead.Constructor.prototype.highlighter.call(this, item.text); | ||||
|         }, | ||||
|         updater: function (item) { | ||||
|             this.$element.data('value', item.value); | ||||
|             return item.text; | ||||
|         },   | ||||
|     | ||||
|          | ||||
|         /* | ||||
|           Overwrite typeahead's render method to store objects. | ||||
|           There are a lot of disscussion in bootstrap repo on this point and still no result. | ||||
|           See https://github.com/twitter/bootstrap/issues/5967  | ||||
|            | ||||
|           This function just store item via jQuery data() method instead of attr('data-value') | ||||
|         */         | ||||
|         typeaheadRender: function (items) { | ||||
|             var that = this; | ||||
|  | ||||
|             items = $(items).map(function (i, item) { | ||||
| //                i = $(that.options.item).attr('data-value', item) | ||||
|                 i = $(that.options.item).data('item', item); | ||||
|                 i.find('a').html(that.highlighter(item)); | ||||
|                 return i[0]; | ||||
|             }); | ||||
|  | ||||
|             //add option to disable autoselect of first line | ||||
|             //see https://github.com/twitter/bootstrap/pull/4164  | ||||
|             if (this.options.autoSelect) { | ||||
|               items.first().addClass('active'); | ||||
|             } | ||||
|             this.$menu.html(items); | ||||
|             return this; | ||||
|         }, | ||||
|         | ||||
|         //add option to disable autoselect of first line | ||||
|         //see https://github.com/twitter/bootstrap/pull/4164          | ||||
|         typeaheadSelect: function () { | ||||
|           var val = this.$menu.find('.active').data('item') | ||||
|           if(this.options.autoSelect || val){ | ||||
|             this.$element | ||||
|             .val(this.updater(val)) | ||||
|             .change() | ||||
|           } | ||||
|           return this.hide() | ||||
|         }, | ||||
|          | ||||
|         /* | ||||
|          if autoSelect = false and nothing matched we need extra press onEnter that is not convinient. | ||||
|          This patch fixes it. | ||||
|         */ | ||||
|         typeaheadMove: function (e) { | ||||
|           if (!this.shown) return | ||||
|  | ||||
|           switch(e.keyCode) { | ||||
|             case 9: // tab | ||||
|             case 13: // enter | ||||
|             case 27: // escape | ||||
|               if (!this.$menu.find('.active').length) return | ||||
|               e.preventDefault() | ||||
|               break | ||||
|  | ||||
|             case 38: // up arrow | ||||
|               e.preventDefault() | ||||
|               this.prev() | ||||
|               break | ||||
|  | ||||
|             case 40: // down arrow | ||||
|               e.preventDefault() | ||||
|               this.next() | ||||
|               break | ||||
|           } | ||||
|  | ||||
|           e.stopPropagation() | ||||
|         } | ||||
|          | ||||
|         /*jshint eqeqeq: true, curly: true, laxcomma: false, asi: false*/   | ||||
|          | ||||
|     });       | ||||
|  | ||||
|     Constructor.defaults = $.extend({}, $.fn.editabletypes.list.defaults, { | ||||
|         /** | ||||
|         @property tpl  | ||||
|         @default <input type="text"> | ||||
|         **/          | ||||
|         tpl:'<input type="text">', | ||||
|         /** | ||||
|         Configuration of typeahead. [Full list of options](http://getbootstrap.com/2.3.2/javascript.html#typeahead). | ||||
|          | ||||
|         @property typeahead  | ||||
|         @type object | ||||
|         @default null | ||||
|         **/ | ||||
|         typeahead: null, | ||||
|         /** | ||||
|         Whether to show `clear` button  | ||||
|          | ||||
|         @property clear  | ||||
|         @type boolean | ||||
|         @default true         | ||||
|         **/ | ||||
|         clear: true | ||||
|     }); | ||||
|  | ||||
|     $.fn.editabletypes.typeahead = Constructor;       | ||||
|      | ||||
| }(window.jQuery)); | ||||
 Micha
					Micha