Browse Source

going towards bootstrap2

pull/1/head
Nicolae Claudius 13 years ago
parent
commit
ef81960721
  1. 5
      Gemfile
  2. 19
      Gemfile.lock
  3. BIN
      app/assets/images/bootstrap/glyphicons-halflings-white.png
  4. BIN
      app/assets/images/bootstrap/glyphicons-halflings.png
  5. 20
      app/assets/javascripts/application.js
  6. 19
      app/assets/javascripts/application.js.coffee
  7. 95
      app/assets/javascripts/bootstrap-popover.js
  8. 273
      app/assets/javascripts/bootstrap-tooltip.js
  9. 14
      app/assets/stylesheets/application.css.scss
  10. 545
      app/assets/stylesheets/bootstrap/bootstrap.scss
  11. 44
      app/assets/stylesheets/overrides.css.scss
  12. 2
      app/views/devise/confirmations/new.html.erb
  13. 4
      app/views/devise/passwords/edit.html.erb
  14. 2
      app/views/devise/passwords/new.html.erb
  15. 8
      app/views/devise/registrations/edit.html.erb
  16. 13
      app/views/devise/registrations/new.html.erb
  17. 4
      app/views/devise/sessions/new.html.erb
  18. 2
      app/views/devise/unlocks/new.html.erb
  19. 2
      app/views/domains/_list_record_columns.html.erb
  20. 21
      app/views/fragments/_top.html.erb

5
Gemfile

@ -12,8 +12,8 @@ gem 'cancan', '~> 1.6.7'
gem 'squeel', '~> 0.9.3' gem 'squeel', '~> 0.9.3'
gem 'sentient_user', '~> 0.3.2' gem 'sentient_user', '~> 0.3.2'
gem 'userstamp_basic', '~> 0.1.0' gem 'userstamp_basic', '~> 0.1.0'
gem 'active_scaffold', '~> 3.1.20' gem 'active_scaffold', :git => 'https://github.com/activescaffold/active_scaffold.git'
# :git => 'https://github.com/activescaffold/active_scaffold.git' # '~> 3.2.0'
# :path => '/home/clyfe/dev/active_scaffold' # :path => '/home/clyfe/dev/active_scaffold'
gem 'pjax_rails', '~> 0.1.10' gem 'pjax_rails', '~> 0.1.10'
gem 'validates_hostname', '~> 1.0.0', :git => 'https://github.com/KimNorgaard/validates_hostname.git' gem 'validates_hostname', '~> 1.0.0', :git => 'https://github.com/KimNorgaard/validates_hostname.git'
@ -23,6 +23,7 @@ gem 'rails_config', '~> 0.2.4'
gem 'active-model-email-validator', '~> 1.0.2' gem 'active-model-email-validator', '~> 1.0.2'
gem 'mail_form', '~> 1.3.0' gem 'mail_form', '~> 1.3.0'
gem 'switch_user', '~> 0.6.0' gem 'switch_user', '~> 0.6.0'
gem 'bootstrap-sass-rails', '~> 2.0.0.2'
# Gems used only for assets and not required # Gems used only for assets and not required
# in production environments by default. # in production environments by default.

19
Gemfile.lock

@ -4,6 +4,13 @@ GIT
specs: specs:
validates_hostname (1.0.0) validates_hostname (1.0.0)
GIT
remote: https://github.com/activescaffold/active_scaffold.git
revision: d7ca8758e270d225f6b7f634e2e79d750d530297
specs:
active_scaffold (3.2.0)
rails (>= 3.1.3)
GEM GEM
remote: http://rubygems.org/ remote: http://rubygems.org/
specs: specs:
@ -23,8 +30,6 @@ GEM
active-model-email-validator (1.0.2) active-model-email-validator (1.0.2)
activemodel activemodel
mail mail
active_scaffold (3.1.20)
rails (>= 3.1.3)
activemodel (3.2.0) activemodel (3.2.0)
activesupport (= 3.2.0) activesupport (= 3.2.0)
builder (~> 3.0.0) builder (~> 3.0.0)
@ -41,6 +46,9 @@ GEM
multi_json (~> 1.0) multi_json (~> 1.0)
arel (3.0.0) arel (3.0.0)
bcrypt-ruby (3.0.1) bcrypt-ruby (3.0.1)
bootstrap-sass-rails (2.0.0.3)
rails (~> 3.1)
sass-rails (~> 3.1)
builder (3.0.0) builder (3.0.0)
cancan (1.6.7) cancan (1.6.7)
capistrano (2.9.0) capistrano (2.9.0)
@ -58,7 +66,7 @@ GEM
rack-test (>= 0.5.4) rack-test (>= 0.5.4)
selenium-webdriver (~> 2.0) selenium-webdriver (~> 2.0)
xpath (~> 0.1.4) xpath (~> 0.1.4)
childprocess (0.3.0) childprocess (0.3.1)
ffi (~> 1.0.6) ffi (~> 1.0.6)
chunky_png (1.2.5) chunky_png (1.2.5)
coffee-rails (3.2.2) coffee-rails (3.2.2)
@ -184,7 +192,7 @@ GEM
railties (>= 3.0) railties (>= 3.0)
rspec (~> 2.8.0) rspec (~> 2.8.0)
rubyzip (0.9.5) rubyzip (0.9.5)
sass (3.1.13) sass (3.1.14)
sass-rails (3.2.4) sass-rails (3.2.4)
railties (~> 3.2.0) railties (~> 3.2.0)
sass (>= 3.1.10) sass (>= 3.1.10)
@ -232,7 +240,8 @@ PLATFORMS
DEPENDENCIES DEPENDENCIES
active-model-email-validator (~> 1.0.2) active-model-email-validator (~> 1.0.2)
active_scaffold (~> 3.1.20) active_scaffold!
bootstrap-sass-rails (~> 2.0.0.2)
cancan (~> 1.6.7) cancan (~> 1.6.7)
capistrano (~> 2.9.0) capistrano (~> 2.9.0)
capistrano-ext (~> 1.2.1) capistrano-ext (~> 1.2.1)

BIN
app/assets/images/bootstrap/glyphicons-halflings-white.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 4.3 KiB

BIN
app/assets/images/bootstrap/glyphicons-halflings.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 4.3 KiB

20
app/assets/javascripts/application.js

@ -1,20 +0,0 @@
// This is a manifest file that'll be compiled into including all the files listed below.
// Add new JavaScript/Coffee code in separate files in this directory and they'll automatically
// be included in the compiled file accessible from http://example.com/assets/application.js
// It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the
// the compiled file.
//
//= require jquery
//= require jquery-ui
//= require jquery_ujs
//= require pjax
//= require active_scaffold
//= require slides
//= require bootstrap-tooltip
//= require bootstrap-popover
//= require_self
$(function(){
$('[rel=popover]').popover();
$('[rel=tooltip]').tooltip();
});

19
app/assets/javascripts/application.js.coffee

@ -0,0 +1,19 @@
# This is a manifest file that'll be compiled into including all the files listed below.
# Add new JavaScript/Coffee code in separate files in this directory and they'll automatically
# be included in the compiled file accessible from http:#example.com/assets/application.js
# It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the
# the compiled file.
#
#= require jquery
#= require jquery-ui
#= require jquery_ujs
#= require pjax
#= require active_scaffold
#= require slides
#= require twitter/bootstrap/tooltip
#= require twitter/bootstrap/popover
#= require_self
$ ->
$('[rel=popover]').popover()
$('[rel=tooltip]').tooltip()

95
app/assets/javascripts/bootstrap-popover.js vendored

@ -1,95 +0,0 @@
/* ===========================================================
* bootstrap-popover.js v2.0.0
* http://twitter.github.com/bootstrap/javascript.html#popovers
* ===========================================================
* Copyright 2012 Twitter, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* =========================================================== */
!function( $ ) {
"use strict"
var Popover = function ( element, options ) {
this.init('popover', element, options)
}
/* NOTE: POPOVER EXTENDS BOOTSTRAP-TOOLTIP.js
========================================== */
Popover.prototype = $.extend({}, $.fn.tooltip.Constructor.prototype, {
constructor: Popover
, setContent: function () {
var $tip = this.tip()
, title = this.getTitle()
, content = this.getContent()
$tip.find('.title')[ $.type(title) == 'object' ? 'append' : 'html' ](title)
$tip.find('.content > *')[ $.type(content) == 'object' ? 'append' : 'html' ](content)
$tip.removeClass('fade top bottom left right in')
}
, hasContent: function () {
return this.getTitle() || this.getContent()
}
, getContent: function () {
var content
, $e = this.$element
, o = this.options
content = $e.attr('data-content')
|| (typeof o.content == 'function' ? o.content.call($e[0]) : o.content)
content = content.toString().replace(/(^\s*|\s*$)/, "")
return content
}
, tip: function() {
if (!this.$tip) {
this.$tip = $(this.options.template)
}
return this.$tip
}
})
/* POPOVER PLUGIN DEFINITION
* ======================= */
$.fn.popover = function ( option ) {
return this.each(function () {
var $this = $(this)
, data = $this.data('popover')
, options = typeof option == 'object' && option
if (!data) $this.data('popover', (data = new Popover(this, options)))
if (typeof option == 'string') data[option]()
})
}
$.fn.popover.Constructor = Popover
$.fn.popover.defaults = $.extend({} , $.fn.tooltip.defaults, {
placement: 'right'
, content: ''
, template: '<div class="popover"><div class="arrow"></div><div class="inner"><h3 class="title"></h3><div class="content"><p></p></div></div></div>'
})
}( window.jQuery )

273
app/assets/javascripts/bootstrap-tooltip.js vendored

@ -1,273 +0,0 @@
/* ===========================================================
* bootstrap-tooltip.js v2.0.0
* http://twitter.github.com/bootstrap/javascript.html#tooltips
* Inspired by the original jQuery.tipsy by Jason Frame
* ===========================================================
* Copyright 2012 Twitter, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* ========================================================== */
!function( $ ) {
"use strict"
/* TOOLTIP PUBLIC CLASS DEFINITION
* =============================== */
var Tooltip = function ( element, options ) {
this.init('tooltip', element, options)
}
Tooltip.prototype = {
constructor: Tooltip
, init: function ( type, element, options ) {
var eventIn
, eventOut
this.type = type
this.$element = $(element)
this.options = this.getOptions(options)
this.enabled = true
if (this.options.trigger != 'manual') {
eventIn = this.options.trigger == 'hover' ? 'mouseenter' : 'focus'
eventOut = this.options.trigger == 'hover' ? 'mouseleave' : 'blur'
this.$element.on(eventIn, this.options.selector, $.proxy(this.enter, this))
this.$element.on(eventOut, this.options.selector, $.proxy(this.leave, this))
}
this.options.selector ?
(this._options = $.extend({}, this.options, { trigger: 'manual', selector: '' })) :
this.fixTitle()
}
, getOptions: function ( options ) {
options = $.extend({}, $.fn[this.type].defaults, options, this.$element.data())
if (options.delay && typeof options.delay == 'number') {
options.delay = {
show: options.delay
, hide: options.delay
}
}
return options
}
, enter: function ( e ) {
var self = $(e.currentTarget)[this.type](this._options).data(this.type)
if (!self.options.delay || !self.options.delay.show) {
self.show()
} else {
self.hoverState = 'in'
setTimeout(function() {
if (self.hoverState == 'in') {
self.show()
}
}, self.options.delay.show)
}
}
, leave: function ( e ) {
var self = $(e.currentTarget)[this.type](this._options).data(this.type)
if (!self.options.delay || !self.options.delay.hide) {
self.hide()
} else {
self.hoverState = 'out'
setTimeout(function() {
if (self.hoverState == 'out') {
self.hide()
}
}, self.options.delay.hide)
}
}
, show: function () {
var $tip
, inside
, pos
, actualWidth
, actualHeight
, placement
, tp
if (this.hasContent() && this.enabled) {
$tip = this.tip()
this.setContent()
if (this.options.animation) {
$tip.addClass('fade')
}
placement = typeof this.options.placement == 'function' ?
this.options.placement.call(this, $tip[0], this.$element[0]) :
this.options.placement
inside = /in/.test(placement)
$tip
.remove()
.css({ top: 0, left: 0, display: 'block' })
.appendTo(inside ? this.$element : document.body)
pos = this.getPosition(inside)
actualWidth = $tip[0].offsetWidth
actualHeight = $tip[0].offsetHeight
switch (inside ? placement.split(' ')[1] : placement) {
case 'bottom':
tp = {top: pos.top + pos.height, left: pos.left + pos.width / 2 - actualWidth / 2}
break
case 'top':
tp = {top: pos.top - actualHeight, left: pos.left + pos.width / 2 - actualWidth / 2}
break
case 'left':
tp = {top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left - actualWidth}
break
case 'right':
tp = {top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left + pos.width}
break
}
if (this.options['z-index']) tp['z-index'] = this.options['z-index']
$tip
.css(tp)
.addClass(placement)
.addClass('in')
}
}
, setContent: function () {
var $tip = this.tip()
$tip.find('.tooltip-inner').html(this.getTitle())
$tip.removeClass('fade in top bottom left right')
}
, hide: function () {
var that = this
, $tip = this.tip()
$tip.removeClass('in')
function removeWithAnimation() {
var timeout = setTimeout(function () {
$tip.off($.support.transition.end).remove()
}, 500)
$tip.one($.support.transition.end, function () {
clearTimeout(timeout)
$tip.remove()
})
}
$.support.transition && this.$tip.hasClass('fade') ?
removeWithAnimation() :
$tip.remove()
}
, fixTitle: function () {
var $e = this.$element
if ($e.attr('title') || typeof($e.attr('data-original-title')) != 'string') {
$e.attr('data-original-title', $e.attr('title') || '').removeAttr('title')
}
}
, hasContent: function () {
return this.getTitle()
}
, getPosition: function (inside) {
return $.extend({}, (inside ? {top: 0, left: 0} : this.$element.offset()), {
width: this.$element[0].offsetWidth
, height: this.$element[0].offsetHeight
})
}
, getTitle: function () {
var title
, $e = this.$element
, o = this.options
title = $e.attr('data-original-title')
|| (typeof o.title == 'function' ? o.title.call($e[0]) : o.title)
title = title.toString().replace(/(^\s*|\s*$)/, "")
return title
}
, tip: function () {
return this.$tip = this.$tip || $(this.options.template)
}
, validate: function () {
if (!this.$element[0].parentNode) {
this.hide()
this.$element = null
this.options = null
}
}
, enable: function () {
this.enabled = true
}
, disable: function () {
this.enabled = false
}
, toggleEnabled: function () {
this.enabled = !this.enabled
}
, toggle: function () {
this[this.tip().hasClass('in') ? 'hide' : 'show']()
}
}
/* TOOLTIP PLUGIN DEFINITION
* ========================= */
$.fn.tooltip = function ( option ) {
return this.each(function () {
var $this = $(this)
, data = $this.data('tooltip')
, options = typeof option == 'object' && option
if (!data) $this.data('tooltip', (data = new Tooltip(this, options)))
if (typeof option == 'string') data[option]()
})
}
$.fn.tooltip.Constructor = Tooltip
$.fn.tooltip.defaults = {
animation: true
, delay: 0
, selector: false
, placement: 'top'
, trigger: 'hover'
, title: ''
, template: '<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>'
, 'z-index': false
}
}( window.jQuery )

14
app/assets/stylesheets/application.css → app/assets/stylesheets/application.css.scss

@ -3,9 +3,7 @@
* and any sub-directories. You're free to add application-wide styles to this file and they'll appear at * and any sub-directories. You're free to add application-wide styles to this file and they'll appear at
* the top of the compiled file, but it's generally better to create a new file per style scope. * the top of the compiled file, but it's generally better to create a new file per style scope.
*= require normalize *= require_self
*= require bootstrap/bootstrap
*= require theme/base *= require theme/base
*= require theme/theme *= require theme/theme
@ -20,11 +18,9 @@
*= require pages/contact *= require pages/contact
*= require pages/donate *= require pages/donate
*= require active_scaffold_layout
*= require active_scaffold_default
*= active_scaffold_colors
*= require overrides
*= require slides *= require slides
*= require_self
*/ */
@import "twitter/bootstrap";
@import "active_scaffold";
@import "overrides";

545
app/assets/stylesheets/bootstrap/bootstrap.scss vendored

@ -1,545 +0,0 @@
.icon {
background-image: url(image-path('bootstrap/glyphicons-halflings.png'));
background-position: 14px 14px;
background-repeat: no-repeat;
display: inline-block;
vertical-align: text-top;
width: 14px;
height: 14px;
*margin-right: .3em;
}
.icon:last-child {
*margin-left: 0;
}
.icon.white {
background-image: url(image-path('bootstrap/glyphicons-halflings-white.png'));
}
.icon.glass {
background-position: 0 0;
}
.icon.music {
background-position: -24px 0;
}
.icon.search {
background-position: -48px 0;
}
.icon.envelope {
background-position: -72px 0;
}
.icon.heart {
background-position: -96px 0;
}
.icon.star {
background-position: -120px 0;
}
.icon.star-empty {
background-position: -144px 0;
}
.icon.user {
background-position: -168px 0;
}
.icon.film {
background-position: -192px 0;
}
.icon.th-large {
background-position: -216px 0;
}
.icon.th {
background-position: -240px 0;
}
.icon.th-list {
background-position: -264px 0;
}
.icon.ok {
background-position: -288px 0;
}
.icon.remove {
background-position: -312px 0;
}
.icon.zoom-in {
background-position: -336px 0;
}
.icon.zoom-out {
background-position: -360px 0;
}
.icon.off {
background-position: -384px 0;
}
.icon.signal {
background-position: -408px 0;
}
.icon.cog {
background-position: -432px 0;
}
.icon.trash {
background-position: -456px 0;
}
.icon.home {
background-position: 0 -24px;
}
.icon.file {
background-position: -24px -24px;
}
.icon.time {
background-position: -48px -24px;
}
.icon.road {
background-position: -72px -24px;
}
.icon.download-alt {
background-position: -96px -24px;
}
.icon.download {
background-position: -120px -24px;
}
.icon.upload {
background-position: -144px -24px;
}
.icon.inbox {
background-position: -168px -24px;
}
.icon.play-circle {
background-position: -192px -24px;
}
.icon.repeat {
background-position: -216px -24px;
}
.icon.refresh {
background-position: -240px -24px;
}
.icon.list-alt {
background-position: -264px -24px;
}
.icon.lock {
background-position: -287px -24px;
}
.icon.flag {
background-position: -312px -24px;
}
.icon.headphones {
background-position: -336px -24px;
}
.icon.volume-off {
background-position: -360px -24px;
}
.icon.volume-down {
background-position: -384px -24px;
}
.icon.volume-up {
background-position: -408px -24px;
}
.icon.qrcode {
background-position: -432px -24px;
}
.icon.barcode {
background-position: -456px -24px;
}
.icon.tag {
background-position: 0 -48px;
}
.icon.tags {
background-position: -25px -48px;
}
.icon.book {
background-position: -48px -48px;
}
.icon.bookmark {
background-position: -72px -48px;
}
.icon.print {
background-position: -96px -48px;
}
.icon.camera {
background-position: -120px -48px;
}
.icon.font {
background-position: -144px -48px;
}
.icon.bold {
background-position: -167px -48px;
}
.icon.italic {
background-position: -192px -48px;
}
.icon.text-height {
background-position: -216px -48px;
}
.icon.text-width {
background-position: -240px -48px;
}
.icon.align-left {
background-position: -264px -48px;
}
.icon.align-center {
background-position: -288px -48px;
}
.icon.align-right {
background-position: -312px -48px;
}
.icon.align-justify {
background-position: -336px -48px;
}
.icon.list {
background-position: -360px -48px;
}
.icon.indent-left {
background-position: -384px -48px;
}
.icon.indent-right {
background-position: -408px -48px;
}
.icon.facetime-video {
background-position: -432px -48px;
}
.icon.picture {
background-position: -456px -48px;
}
.icon.pencil {
background-position: 0 -72px;
}
.icon.map-marker {
background-position: -24px -72px;
}
.icon.adjust {
background-position: -48px -72px;
}
.icon.tint {
background-position: -72px -72px;
}
.icon.edit {
background-position: -96px -72px;
}
.icon.share {
background-position: -120px -72px;
}
.icon.check {
background-position: -144px -72px;
}
.icon.move {
background-position: -168px -72px;
}
.icon.step-backward {
background-position: -192px -72px;
}
.icon.fast-backward {
background-position: -216px -72px;
}
.icon.backward {
background-position: -240px -72px;
}
.icon.play {
background-position: -264px -72px;
}
.icon.pause {
background-position: -288px -72px;
}
.icon.stop {
background-position: -312px -72px;
}
.icon.forward {
background-position: -336px -72px;
}
.icon.fast-forward {
background-position: -360px -72px;
}
.icon.step-forward {
background-position: -384px -72px;
}
.icon.eject {
background-position: -408px -72px;
}
.icon.chevron-left {
background-position: -432px -72px;
}
.icon.chevron-right {
background-position: -456px -72px;
}
.icon.plus-sign {
background-position: 0 -96px;
}
.icon.minus-sign {
background-position: -24px -96px;
}
.icon.remove-sign {
background-position: -48px -96px;
}
.icon.ok-sign {
background-position: -72px -96px;
}
.icon.question-sign {
background-position: -96px -96px;
}
.icon.info-sign {
background-position: -120px -96px;
}
.icon.screenshot {
background-position: -144px -96px;
}
.icon.remove-circle {
background-position: -168px -96px;
}
.icon.ok-circle {
background-position: -192px -96px;
}
.icon.ban-circle {
background-position: -216px -96px;
}
.icon.arrow-left {
background-position: -240px -96px;
}
.icon.arrow-right {
background-position: -264px -96px;
}
.icon.arrow-up {
background-position: -289px -96px;
}
.icon.arrow-down {
background-position: -312px -96px;
}
.icon.share-alt {
background-position: -336px -96px;
}
.icon.resize-full {
background-position: -360px -96px;
}
.icon.resize-small {
background-position: -384px -96px;
}
.icon.plus {
background-position: -408px -96px;
}
.icon.minus {
background-position: -433px -96px;
}
.icon.asterisk {
background-position: -456px -96px;
}
.icon.exclamation-sign {
background-position: 0 -120px;
}
.icon.gift {
background-position: -24px -120px;
}
.icon.leaf {
background-position: -48px -120px;
}
.icon.fire {
background-position: -72px -120px;
}
.icon.eye-open {
background-position: -96px -120px;
}
.icon.eye-close {
background-position: -120px -120px;
}
.icon.warning-sign {
background-position: -144px -120px;
}
.icon.plane {
background-position: -168px -120px;
}
.icon.calendar {
background-position: -192px -120px;
}
.icon.random {
background-position: -216px -120px;
}
.icon.comment {
background-position: -240px -120px;
}
.icon.magnet {
background-position: -264px -120px;
}
.icon.chevron-up {
background-position: -288px -120px;
}
.icon.chevron-down {
background-position: -313px -119px;
}
.icon.retweet {
background-position: -336px -120px;
}
.icon.shopping-cart {
background-position: -360px -120px;
}
.icon.folder-close {
background-position: -384px -120px;
}
.icon.folder-open {
background-position: -408px -120px;
}
.icon.resize-vertical {
background-position: -432px -119px;
}
.icon.resize-horizontal {
background-position: -456px -118px;
}
.tooltip {
position: absolute;
z-index: 1020;
display: block;
visibility: visible;
padding: 5px;
font-size: 11px;
opacity: 0;
filter: alpha(opacity=0);
}
.tooltip.in {
opacity: 0.8;
filter: alpha(opacity=80);
}
.tooltip.top {
margin-top: -2px;
}
.tooltip.right {
margin-left: 2px;
}
.tooltip.bottom {
margin-top: 2px;
}
.tooltip.left {
margin-left: -2px;
}
.tooltip.top .tooltip-arrow {
bottom: 0;
left: 50%;
margin-left: -5px;
border-left: 5px solid transparent;
border-right: 5px solid transparent;
border-top: 5px solid #000000;
}
.tooltip.left .tooltip-arrow {
top: 50%;
right: 0;
margin-top: -5px;
border-top: 5px solid transparent;
border-bottom: 5px solid transparent;
border-left: 5px solid #000000;
}
.tooltip.bottom .tooltip-arrow {
top: 0;
left: 50%;
margin-left: -5px;
border-left: 5px solid transparent;
border-right: 5px solid transparent;
border-bottom: 5px solid #000000;
}
.tooltip.right .tooltip-arrow {
top: 50%;
left: 0;
margin-top: -5px;
border-top: 5px solid transparent;
border-bottom: 5px solid transparent;
border-right: 5px solid #000000;
}
.tooltip-inner {
max-width: 200px;
padding: 3px 8px;
color: #ffffff;
text-align: center;
text-decoration: none;
background-color: #000000;
-webkit-border-radius: 4px;
-moz-border-radius: 4px;
border-radius: 4px;
}
.tooltip-arrow {
position: absolute;
width: 0;
height: 0;
}
.popover {
position: absolute;
top: 0;
left: 0;
z-index: 1010;
display: none;
padding: 5px;
}
.popover.top {
margin-top: -5px;
}
.popover.right {
margin-left: 5px;
}
.popover.bottom {
margin-top: 5px;
}
.popover.left {
margin-left: -5px;
}
.popover.top .arrow {
bottom: 0;
left: 50%;
margin-left: -5px;
border-left: 5px solid transparent;
border-right: 5px solid transparent;
border-top: 5px solid #000000;
}
.popover.right .arrow {
top: 50%;
left: 0;
margin-top: -5px;
border-top: 5px solid transparent;
border-bottom: 5px solid transparent;
border-right: 5px solid #000000;
}
.popover.bottom .arrow {
top: 0;
left: 50%;
margin-left: -5px;
border-left: 5px solid transparent;
border-right: 5px solid transparent;
border-bottom: 5px solid #000000;
}
.popover.left .arrow {
top: 50%;
right: 0;
margin-top: -5px;
border-top: 5px solid transparent;
border-bottom: 5px solid transparent;
border-left: 5px solid #000000;
}
.popover .arrow {
position: absolute;
width: 0;
height: 0;
}
.popover .inner {
padding: 3px;
width: 280px;
overflow: hidden;
background: #000000;
background: rgba(0, 0, 0, 0.8);
-webkit-border-radius: 6px;
-moz-border-radius: 6px;
border-radius: 6px;
-webkit-box-shadow: 0 3px 7px rgba(0, 0, 0, 0.3);
-moz-box-shadow: 0 3px 7px rgba(0, 0, 0, 0.3);
box-shadow: 0 3px 7px rgba(0, 0, 0, 0.3);
}
.popover .title {
padding: 9px 15px;
line-height: 1;
background-color: #f5f5f5;
border-bottom: 1px solid #eee;
-webkit-border-radius: 3px 3px 0 0;
-moz-border-radius: 3px 3px 0 0;
border-radius: 3px 3px 0 0;
-webkit-margin-before: 0;
-webkit-margin-after: 0;
}
.popover .content {
padding: 14px;
background-color: #ffffff;
-webkit-border-radius: 0 0 3px 3px;
-moz-border-radius: 0 0 3px 3px;
border-radius: 0 0 3px 3px;
-webkit-background-clip: padding-box;
-moz-background-clip: padding-box;
background-clip: padding-box;
}
.popover .content p, .popover .content ul, .popover .content ol {
margin-bottom: 0;
}

44
app/assets/stylesheets/overrides.css.scss

@ -1,35 +1,30 @@
#main .block .content p { #main .block {
.content p {
font-size: 16px; font-size: 16px;
} }
#main .block .content h2 { .content h2 {
margin-left: 0; margin-left: 0 !important;
} }
#main .block .content .active-scaffold-header h2 { .content .active-scaffold-header h2 {
font-size: 160%; font-size: 160%;
} }
#main .block .content .active-scaffold th a { .content .active-scaffold th a {
text-shadow: none; text-shadow: none;
} }
#main .block .content .active-scaffold th p { .content .active-scaffold th p {
font: bold 11px arial, sans-serif; font: bold 11px arial, sans-serif;
text-shadow: none; text-shadow: none;
}
} }
body.errors #main .inner { body.errors #main .inner {
margin-top: 15px; margin-top: 15px;
} }
// https://github.com/activescaffold/active_scaffold/commit/686f43c1fbd76224be9b32505ecde6d553a0d26d#commitcomment-931620
.active-scaffold a,
.active-scaffold a:visited,
.active-scaffold a:hover {
color: #06c;
}
#as_domains-active-scaffold .name-column, #as_domains-active-scaffold .name-column,
#as_hosts-active-scaffold .name-column { #as_hosts-active-scaffold .name-column {
font-weight: bold; font-weight: bold;
@ -70,3 +65,18 @@ body.errors #main .inner {
border: 1px solid #bb9004; border: 1px solid #bb9004;
background: #f9c006 url(image-path("messages/warning.png")) no-repeat 10px center; background: #f9c006 url(image-path("messages/warning.png")) no-repeat 10px center;
} }
.active-scaffold {
input[type="submit"], input[type="reset"], button {
@extend .btn;
margin-top: 0;
padding-top: 2px;
padding-bottom: 1px;
}
input, select, textarea {
margin-bottom: 0;
}
a.as_cancel {
vertical-align: middle;
}
}

2
app/views/devise/confirmations/new.html.erb

@ -3,7 +3,7 @@
<%= form_for(resource, :as => resource_name, :url => confirmation_path(resource_name), :html => { :method => :post }) do |f| %> <%= form_for(resource, :as => resource_name, :url => confirmation_path(resource_name), :html => { :method => :post }) do |f| %>
<%= devise_error_messages! %> <%= devise_error_messages! %>
<div><%= f.label :email %><br /> <div><%= f.label :email %>
<%= f.email_field :email %></div> <%= f.email_field :email %></div>
<div><%= f.submit "Resend confirmation instructions" %></div> <div><%= f.submit "Resend confirmation instructions" %></div>

4
app/views/devise/passwords/edit.html.erb

@ -4,10 +4,10 @@
<%= devise_error_messages! %> <%= devise_error_messages! %>
<%= f.hidden_field :reset_password_token %> <%= f.hidden_field :reset_password_token %>
<div><%= f.label :password, "New password" %><br /> <div><%= f.label :password, "New password" %>
<%= f.password_field :password %></div> <%= f.password_field :password %></div>
<div><%= f.label :password_confirmation, "Confirm new password" %><br /> <div><%= f.label :password_confirmation, "Confirm new password" %>
<%= f.password_field :password_confirmation %></div> <%= f.password_field :password_confirmation %></div>
<div><%= f.submit "Change my password" %></div> <div><%= f.submit "Change my password" %></div>

2
app/views/devise/passwords/new.html.erb

@ -3,7 +3,7 @@
<%= form_for(resource, :as => resource_name, :url => password_path(resource_name), :html => { :method => :post }) do |f| %> <%= form_for(resource, :as => resource_name, :url => password_path(resource_name), :html => { :method => :post }) do |f| %>
<%= devise_error_messages! %> <%= devise_error_messages! %>
<div><%= f.label :email %><br /> <div><%= f.label :email %>
<%= f.email_field :email %></div> <%= f.email_field :email %></div>
<div><%= f.submit "Send me reset password instructions" %></div> <div><%= f.submit "Send me reset password instructions" %></div>

8
app/views/devise/registrations/edit.html.erb

@ -7,19 +7,19 @@
<%= form_for(resource, :as => resource_name, :url => registration_path(resource_name), :html => { :method => :put }) do |f| %> <%= form_for(resource, :as => resource_name, :url => registration_path(resource_name), :html => { :method => :put }) do |f| %>
<%= devise_error_messages! %> <%= devise_error_messages! %>
<div><%= f.label :first_name %><br /> <div><%= f.label :first_name %>
<%= f.text_field :first_name %></div> <%= f.text_field :first_name %></div>
<div><%= f.label :last_name %><br /> <div><%= f.label :last_name %>
<%= f.text_field :last_name %></div> <%= f.text_field :last_name %></div>
<div><%= f.label :email %><br /> <div><%= f.label :email %>
<%= f.email_field :email %></div> <%= f.email_field :email %></div>
<div><%= f.label :password %> <i>(leave blank if you don't want to change it)</i><br /> <div><%= f.label :password %> <i>(leave blank if you don't want to change it)</i><br />
<%= f.password_field :password %></div> <%= f.password_field :password %></div>
<div><%= f.label :password_confirmation %><br /> <div><%= f.label :password_confirmation %>
<%= f.password_field :password_confirmation %></div> <%= f.password_field :password_confirmation %></div>
<div><%= f.label :current_password %> <i>(we need your current password to confirm your changes)</i><br /> <div><%= f.label :current_password %> <i>(we need your current password to confirm your changes)</i><br />

13
app/views/devise/registrations/new.html.erb

@ -3,25 +3,24 @@
<h2>Sign up</h2> <h2>Sign up</h2>
<div class="content login"> <div class="content login">
<%= form_for(resource, :as => resource_name, :url => registration_path(resource_name)) do |f| %> <%= form_for(resource, :as => resource_name, :url => registration_path(resource_name)) do |f| %>
<%= devise_error_messages! %> <%= devise_error_messages! %>
<%= honeypot %> <%= honeypot %>
<div><%= f.label :first_name %><br /> <div><%= f.label :first_name %>
<%= f.text_field :first_name %></div> <%= f.text_field :first_name %></div>
<div><%= f.label :last_name %><br /> <div><%= f.label :last_name %>
<%= f.text_field :last_name %></div> <%= f.text_field :last_name %></div>
<div><%= f.label :email %><br /> <div><%= f.label :email %>
<%= f.email_field :email %></div> <%= f.email_field :email %></div>
<div><%= f.label :password %><br /> <div><%= f.label :password %>
<%= f.password_field :password %></div> <%= f.password_field :password %>
<div><%= f.label :password_confirmation %><br /> <div><%= f.label :password_confirmation %>
<%= f.password_field :password_confirmation %></div> <%= f.password_field :password_confirmation %></div>
<div><%= f.submit "Sign up" %></div> <div><%= f.submit "Sign up" %></div>

4
app/views/devise/sessions/new.html.erb

@ -4,10 +4,10 @@
<div class="content login"> <div class="content login">
<%= form_for(resource, :as => resource_name, :url => session_path(resource_name)) do |f| %> <%= form_for(resource, :as => resource_name, :url => session_path(resource_name)) do |f| %>
<div><%= f.label :email %><br /> <div><%= f.label :email %>
<%= f.email_field :email %></div> <%= f.email_field :email %></div>
<div><%= f.label :password %><br /> <div><%= f.label :password %>
<%= f.password_field :password %></div> <%= f.password_field :password %></div>
<% if devise_mapping.rememberable? -%> <% if devise_mapping.rememberable? -%>

2
app/views/devise/unlocks/new.html.erb

@ -3,7 +3,7 @@
<%= form_for(resource, :as => resource_name, :url => unlock_path(resource_name), :html => { :method => :post }) do |f| %> <%= form_for(resource, :as => resource_name, :url => unlock_path(resource_name), :html => { :method => :post }) do |f| %>
<%= devise_error_messages! %> <%= devise_error_messages! %>
<div><%= f.label :email %><br /> <div><%= f.label :email %>
<%= f.email_field :email %></div> <%= f.email_field :email %></div>
<div><%= f.submit "Resend unlock instructions" %></div> <div><%= f.submit "Resend unlock instructions" %></div>

2
app/views/domains/_list_record_columns.html.erb

@ -16,7 +16,7 @@
end %> end %>
<% unless can_crud_permissions %> <% unless can_crud_permissions %>
<% who = "<strong>#{record.user.name}</strong> #{mail_to record.user.email}" %> <% who = "<strong>#{record.user.name}</strong> #{mail_to record.user.email}" %>
<i class="icon share" style="float: right;" rel="popover" <i class="icon-share" style="float: right;" rel="popover"
data-original-title="Shared domain" data-original-title="Shared domain"
data-content="This domain was shared with you by <%=h who %>" data-content="This domain was shared with you by <%=h who %>"
></i> ></i>

21
app/views/fragments/_top.html.erb

@ -7,12 +7,12 @@
<li><%#= link_to('Dashboard', dashboard_path, :data => {:pjax => '#main'}) %></li> <li><%#= link_to('Dashboard', dashboard_path, :data => {:pjax => '#main'}) %></li>
<li> <li>
<%= link_to domains_path, :data => {:pjax => '#main'} do %> <%= link_to domains_path, :data => {:pjax => '#main'} do %>
<i class="icon white th-list"></i> My Domains <i class="icon-white icon-th-list"></i> My Domains
<% end %> <% end %>
</li> </li>
<li> <li>
<%= link_to hosts_path, :data => {:pjax => '#main'} do %> <%= link_to hosts_path, :data => {:pjax => '#main'} do %>
<i class="icon white th"></i> Dynamic Hosts <i class="icon-white icon-th"></i> Dynamic Hosts
<% end %> <% end %>
</li> </li>
<% else %> <% else %>
@ -38,40 +38,41 @@
</li> </li>
<li> <li>
<%= link_to(Settings.news_link, :rel => 'tooltip', :title => Settings.news_link) do %> <%= link_to(Settings.news_link, :rel => 'tooltip', :title => Settings.news_link) do %>
<i class="icon white share-alt"></i> News <i class="icon-white icon-share-alt"></i> News
<% end %> <% end %>
</li> </li>
<li> <li>
<%= link_to(page_path('donate'), :class => 'highlight', :data => {:pjax => '#main'}) do %> <%= link_to(page_path('donate'), :rel => 'tooltip', :title => 'PayPal',
<i class="icon white heart"></i> Donate :class => 'highlight', :data => {:pjax => '#main'}) do %>
<i class="icon-white icon-heart"></i> Donate
<% end %> <% end %>
</li> </li>
<% if user_signed_in? %> <% if user_signed_in? %>
<li> <li>
<%= link_to(page_path('help'), :data => {:pjax => '#main'}) do %> <%= link_to(page_path('help'), :data => {:pjax => '#main'}) do %>
<i class="icon white question-sign"></i> Help & Support <i class="icon-white icon-question-sign"></i> Help & Support
<% end %> <% end %>
</li> </li>
<li> <li>
<%= link_to(edit_user_registration_path, :rel => 'tooltip', <%= link_to(edit_user_registration_path, :rel => 'tooltip',
:title => "IP: #{client_remote_ip}",:data => {:pjax => '#main'}) do %> :title => "IP: #{client_remote_ip}",:data => {:pjax => '#main'}) do %>
<i class="icon white user"></i> <%= current_user.email %> <i class="icon-white icon-user"></i> <%= current_user.email %>
<% end %> <% end %>
</li> </li>
<li> <li>
<%= link_to(destroy_user_session_path, :method => :delete) do %> <%= link_to(destroy_user_session_path, :method => :delete) do %>
<i class="icon white off"></i> Sign out <i class="icon-white icon-off"></i> Sign out
<% end %> <% end %>
</li> </li>
<% else %> <% else %>
<li> <li>
<%= link_to(new_user_registration_path, :data => {:pjax => '#main'}) do %> <%= link_to(new_user_registration_path, :data => {:pjax => '#main'}) do %>
<i class="icon white arrow-up"></i> Sign up <i class="icon-white icon-arrow-up"></i> Sign up
<% end %> <% end %>
</li> </li>
<li> <li>
<%= link_to(new_user_session_path, :data => {:pjax => '#main'}) do %> <%= link_to(new_user_session_path, :data => {:pjax => '#main'}) do %>
<i class="icon white arrow-right"></i> Sign in <i class="icon-white icon-arrow-right"></i> Sign in
<% end %> <% end %>
</li> </li>
<% end %> <% end %>

Loading…
Cancel
Save