spiderfw 0.6.30 → 0.6.31
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +15 -7
- data/CHANGELOG +11 -0
- data/VERSION +1 -1
- data/apps/app_server/config/options.rb +1 -1
- data/apps/core/auth/controllers/login_controller.rb +3 -0
- data/apps/core/components/assets.rb +61 -3
- data/apps/core/components/public/bootstrap_3/img/glyphicons-halflings-regular.eot +0 -0
- data/apps/core/components/public/bootstrap_3/img/glyphicons-halflings-regular.svg +229 -0
- data/apps/core/components/public/bootstrap_3/img/glyphicons-halflings-regular.ttf +0 -0
- data/apps/core/components/public/bootstrap_3/img/glyphicons-halflings-regular.woff +0 -0
- data/apps/core/components/public/bootstrap_3/js/affix.js +140 -0
- data/apps/core/components/public/bootstrap_3/js/alert.js +92 -0
- data/apps/core/components/public/bootstrap_3/js/button.js +110 -0
- data/apps/core/components/public/bootstrap_3/js/carousel.js +210 -0
- data/apps/core/components/public/bootstrap_3/js/collapse.js +180 -0
- data/apps/core/components/public/bootstrap_3/js/dropdown.js +151 -0
- data/apps/core/components/public/bootstrap_3/js/modal.js +277 -0
- data/apps/core/components/public/bootstrap_3/js/popover.js +113 -0
- data/apps/core/components/public/bootstrap_3/js/scrollspy.js +158 -0
- data/apps/core/components/public/bootstrap_3/js/tab.js +128 -0
- data/apps/core/components/public/bootstrap_3/js/tooltip.js +456 -0
- data/apps/core/components/public/bootstrap_3/js/transition.js +48 -0
- data/apps/core/components/public/bootstrap_3/scss/_alerts.scss +67 -0
- data/apps/core/components/public/bootstrap_3/scss/_badges.scss +57 -0
- data/apps/core/components/public/bootstrap_3/scss/_breadcrumbs.scss +26 -0
- data/apps/core/components/public/bootstrap_3/scss/_button-groups.scss +240 -0
- data/apps/core/components/public/bootstrap_3/scss/_buttons.scss +159 -0
- data/apps/core/components/public/bootstrap_3/scss/_carousel.scss +243 -0
- data/apps/core/components/public/bootstrap_3/scss/_close.scss +35 -0
- data/apps/core/components/public/bootstrap_3/scss/_code.scss +62 -0
- data/apps/core/components/public/bootstrap_3/scss/_component-animations.scss +35 -0
- data/apps/core/components/public/bootstrap_3/scss/_dropdowns.scss +214 -0
- data/apps/core/components/public/bootstrap_3/scss/_forms.scss +489 -0
- data/apps/core/components/public/bootstrap_3/scss/_glyphicons.scss +237 -0
- data/apps/core/components/public/bootstrap_3/scss/_grid.scss +84 -0
- data/apps/core/components/public/bootstrap_3/scss/_input-groups.scss +166 -0
- data/apps/core/components/public/bootstrap_3/scss/_jumbotron.scss +48 -0
- data/apps/core/components/public/bootstrap_3/scss/_labels.scss +66 -0
- data/apps/core/components/public/bootstrap_3/scss/_list-group.scss +129 -0
- data/apps/core/components/public/bootstrap_3/scss/_media.scss +56 -0
- data/apps/core/components/public/bootstrap_3/scss/_mixins.scss +39 -0
- data/apps/core/components/public/bootstrap_3/scss/_modals.scss +147 -0
- data/apps/core/components/public/bootstrap_3/scss/_navbar.scss +658 -0
- data/apps/core/components/public/bootstrap_3/scss/_navs.scss +242 -0
- data/apps/core/components/public/bootstrap_3/scss/_normalize.scss +425 -0
- data/apps/core/components/public/bootstrap_3/scss/_pager.scss +55 -0
- data/apps/core/components/public/bootstrap_3/scss/_pagination.scss +88 -0
- data/apps/core/components/public/bootstrap_3/scss/_panels.scss +240 -0
- data/apps/core/components/public/bootstrap_3/scss/_popovers.scss +133 -0
- data/apps/core/components/public/bootstrap_3/scss/_print.scss +101 -0
- data/apps/core/components/public/bootstrap_3/scss/_progress-bars.scss +89 -0
- data/apps/core/components/public/bootstrap_3/scss/_responsive-embed.scss +34 -0
- data/apps/core/components/public/bootstrap_3/scss/_responsive-utilities.scss +174 -0
- data/apps/core/components/public/bootstrap_3/scss/_scaffolding.scss +150 -0
- data/apps/core/components/public/bootstrap_3/scss/_tables.scss +233 -0
- data/apps/core/components/public/bootstrap_3/scss/_theme.scss +247 -0
- data/apps/core/components/public/bootstrap_3/scss/_thumbnails.scss +38 -0
- data/apps/core/components/public/bootstrap_3/scss/_tooltip.scss +95 -0
- data/apps/core/components/public/bootstrap_3/scss/_type.scss +298 -0
- data/apps/core/components/public/bootstrap_3/scss/_utilities.scss +56 -0
- data/apps/core/components/public/bootstrap_3/scss/_variables.scss +853 -0
- data/apps/core/components/public/bootstrap_3/scss/_wells.scss +29 -0
- data/apps/core/components/public/bootstrap_3/scss/bootstrap.scss +50 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_alerts.scss +14 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_background-variant.scss +11 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_border-radius.scss +18 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_buttons.scss +50 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_center-block.scss +7 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_clearfix.scss +22 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_forms.scss +84 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_gradients.scss +58 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_grid-framework.scss +87 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_grid.scss +122 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_hide-text.scss +21 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_image.scss +33 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_labels.scss +12 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_list-group.scss +31 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_nav-divider.scss +10 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_nav-vertical-align.scss +9 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_opacity.scss +8 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_pagination.scss +23 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_panels.scss +20 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_progress-bar.scss +8 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_reset-filter.scss +8 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_resize.scss +6 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_responsive-visibility.scss +21 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_size.scss +10 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_tab-focus.scss +9 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_table-row.scss +28 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_text-emphasis.scss +11 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_text-overflow.scss +8 -0
- data/apps/core/components/public/bootstrap_3/scss/mixins/_vendor-prefixes.scss +224 -0
- data/apps/core/components/public/js/jquery/plugins/bsmselect/js/jquery.bsmselect.js +1 -1
- data/apps/core/components/widgets/month_calendar/month_calendar.shtml +3 -3
- data/apps/core/components/widgets/table/table.rb +6 -2
- data/apps/core/components/widgets/table/table.shtml +4 -4
- data/apps/core/forms/widgets/form/form.rb +1 -1
- data/apps/core/forms/widgets/inputs/select/select.rb +13 -2
- data/apps/messenger/lib/backends/mobyt.rb +6 -2
- data/apps/messenger/lib/backends/skebby.rb +1 -1
- data/apps/webdav/controllers/webdav_controller.rb +16 -7
- data/lib/spiderfw/controller/http_controller.rb +4 -1
- data/lib/spiderfw/env.rb +0 -1
- data/lib/spiderfw/http/adapters/rack.rb +3 -1
- data/lib/spiderfw/model/base_model.rb +7 -3
- data/lib/spiderfw/model/storage/connection_pool.rb +6 -2
- data/lib/spiderfw/model/storage/db/db_storage.rb +25 -9
- data/lib/spiderfw/site.rb +1 -1
- metadata +308 -149
@@ -0,0 +1,129 @@
|
|
1
|
+
//
|
2
|
+
// List groups
|
3
|
+
// --------------------------------------------------
|
4
|
+
|
5
|
+
|
6
|
+
// Base class
|
7
|
+
//
|
8
|
+
// Easily usable on <ul>, <ol>, or <div>.
|
9
|
+
|
10
|
+
.list-group {
|
11
|
+
// No need to set list-style: none; since .list-group-item is block level
|
12
|
+
margin-bottom: 20px;
|
13
|
+
padding-left: 0; // reset padding because ul and ol
|
14
|
+
}
|
15
|
+
|
16
|
+
|
17
|
+
// Individual list items
|
18
|
+
//
|
19
|
+
// Use on `li`s or `div`s within the `.list-group` parent.
|
20
|
+
|
21
|
+
.list-group-item {
|
22
|
+
position: relative;
|
23
|
+
display: block;
|
24
|
+
padding: 10px 15px;
|
25
|
+
// Place the border on the list items and negative margin up for better styling
|
26
|
+
margin-bottom: -1px;
|
27
|
+
background-color: $list-group-bg;
|
28
|
+
border: 1px solid $list-group-border;
|
29
|
+
|
30
|
+
// Round the first and last items
|
31
|
+
&:first-child {
|
32
|
+
@include border-top-radius($list-group-border-radius);
|
33
|
+
}
|
34
|
+
&:last-child {
|
35
|
+
margin-bottom: 0;
|
36
|
+
@include border-bottom-radius($list-group-border-radius);
|
37
|
+
}
|
38
|
+
|
39
|
+
// Align badges within list items
|
40
|
+
> .badge {
|
41
|
+
float: right;
|
42
|
+
}
|
43
|
+
> .badge + .badge {
|
44
|
+
margin-right: 5px;
|
45
|
+
}
|
46
|
+
}
|
47
|
+
|
48
|
+
|
49
|
+
// Linked list items
|
50
|
+
//
|
51
|
+
// Use anchor elements instead of `li`s or `div`s to create linked list items.
|
52
|
+
// Includes an extra `.active` modifier class for showing selected items.
|
53
|
+
|
54
|
+
a.list-group-item {
|
55
|
+
color: $list-group-link-color;
|
56
|
+
|
57
|
+
.list-group-item-heading {
|
58
|
+
color: $list-group-link-heading-color;
|
59
|
+
}
|
60
|
+
|
61
|
+
// Hover state
|
62
|
+
&:hover,
|
63
|
+
&:focus {
|
64
|
+
text-decoration: none;
|
65
|
+
color: $list-group-link-hover-color;
|
66
|
+
background-color: $list-group-hover-bg;
|
67
|
+
}
|
68
|
+
}
|
69
|
+
|
70
|
+
.list-group-item {
|
71
|
+
// Disabled state
|
72
|
+
&.disabled,
|
73
|
+
&.disabled:hover,
|
74
|
+
&.disabled:focus {
|
75
|
+
background-color: $list-group-disabled-bg;
|
76
|
+
color: $list-group-disabled-color;
|
77
|
+
|
78
|
+
// Force color to inherit for custom content
|
79
|
+
.list-group-item-heading {
|
80
|
+
color: inherit;
|
81
|
+
}
|
82
|
+
.list-group-item-text {
|
83
|
+
color: $list-group-disabled-text-color;
|
84
|
+
}
|
85
|
+
}
|
86
|
+
|
87
|
+
// Active class on item itself, not parent
|
88
|
+
&.active,
|
89
|
+
&.active:hover,
|
90
|
+
&.active:focus {
|
91
|
+
z-index: 2; // Place active items above their siblings for proper border styling
|
92
|
+
color: $list-group-active-color;
|
93
|
+
background-color: $list-group-active-bg;
|
94
|
+
border-color: $list-group-active-border;
|
95
|
+
|
96
|
+
// Force color to inherit for custom content
|
97
|
+
.list-group-item-heading {
|
98
|
+
color: inherit;
|
99
|
+
}
|
100
|
+
.list-group-item-text {
|
101
|
+
color: $list-group-active-text-color;
|
102
|
+
}
|
103
|
+
}
|
104
|
+
}
|
105
|
+
|
106
|
+
|
107
|
+
// Contextual variants
|
108
|
+
//
|
109
|
+
// Add modifier classes to change text and background color on individual items.
|
110
|
+
// Organizationally, this must come after the `:hover` states.
|
111
|
+
|
112
|
+
@include list-group-item-variant(success, $state-success-bg, $state-success-text);
|
113
|
+
@include list-group-item-variant(info, $state-info-bg, $state-info-text);
|
114
|
+
@include list-group-item-variant(warning, $state-warning-bg, $state-warning-text);
|
115
|
+
@include list-group-item-variant(danger, $state-danger-bg, $state-danger-text);
|
116
|
+
|
117
|
+
|
118
|
+
// Custom content options
|
119
|
+
//
|
120
|
+
// Extra classes for creating well-formatted content within `.list-group-item`s.
|
121
|
+
|
122
|
+
.list-group-item-heading {
|
123
|
+
margin-top: 0;
|
124
|
+
margin-bottom: 5px;
|
125
|
+
}
|
126
|
+
.list-group-item-text {
|
127
|
+
margin-bottom: 0;
|
128
|
+
line-height: 1.3;
|
129
|
+
}
|
@@ -0,0 +1,56 @@
|
|
1
|
+
// Media objects
|
2
|
+
// Source: http://stubbornella.org/content/?p=497
|
3
|
+
// --------------------------------------------------
|
4
|
+
|
5
|
+
|
6
|
+
// Common styles
|
7
|
+
// -------------------------
|
8
|
+
|
9
|
+
// Clear the floats
|
10
|
+
.media,
|
11
|
+
.media-body {
|
12
|
+
overflow: hidden;
|
13
|
+
zoom: 1;
|
14
|
+
}
|
15
|
+
|
16
|
+
// Proper spacing between instances of .media
|
17
|
+
.media,
|
18
|
+
.media .media {
|
19
|
+
margin-top: 15px;
|
20
|
+
}
|
21
|
+
.media:first-child {
|
22
|
+
margin-top: 0;
|
23
|
+
}
|
24
|
+
|
25
|
+
// For images and videos, set to block
|
26
|
+
.media-object {
|
27
|
+
display: block;
|
28
|
+
}
|
29
|
+
|
30
|
+
// Reset margins on headings for tighter default spacing
|
31
|
+
.media-heading {
|
32
|
+
margin: 0 0 5px;
|
33
|
+
}
|
34
|
+
|
35
|
+
|
36
|
+
// Media image alignment
|
37
|
+
// -------------------------
|
38
|
+
|
39
|
+
.media {
|
40
|
+
> .pull-left {
|
41
|
+
margin-right: 10px;
|
42
|
+
}
|
43
|
+
> .pull-right {
|
44
|
+
margin-left: 10px;
|
45
|
+
}
|
46
|
+
}
|
47
|
+
|
48
|
+
|
49
|
+
// Media list variation
|
50
|
+
// -------------------------
|
51
|
+
|
52
|
+
// Undo default ul/ol styles
|
53
|
+
.media-list {
|
54
|
+
padding-left: 0;
|
55
|
+
list-style: none;
|
56
|
+
}
|
@@ -0,0 +1,39 @@
|
|
1
|
+
// Mixins
|
2
|
+
// --------------------------------------------------
|
3
|
+
|
4
|
+
// Utilities
|
5
|
+
@import "mixins/hide-text";
|
6
|
+
@import "mixins/opacity";
|
7
|
+
@import "mixins/image";
|
8
|
+
@import "mixins/labels";
|
9
|
+
@import "mixins/reset-filter";
|
10
|
+
@import "mixins/resize";
|
11
|
+
@import "mixins/responsive-visibility";
|
12
|
+
@import "mixins/size";
|
13
|
+
@import "mixins/tab-focus";
|
14
|
+
@import "mixins/text-emphasis";
|
15
|
+
@import "mixins/text-overflow";
|
16
|
+
@import "mixins/vendor-prefixes";
|
17
|
+
|
18
|
+
// Components
|
19
|
+
@import "mixins/alerts";
|
20
|
+
@import "mixins/buttons";
|
21
|
+
@import "mixins/panels";
|
22
|
+
@import "mixins/pagination";
|
23
|
+
@import "mixins/list-group";
|
24
|
+
@import "mixins/nav-divider";
|
25
|
+
@import "mixins/forms";
|
26
|
+
@import "mixins/progress-bar";
|
27
|
+
@import "mixins/table-row";
|
28
|
+
|
29
|
+
// Skins
|
30
|
+
@import "mixins/background-variant";
|
31
|
+
@import "mixins/border-radius";
|
32
|
+
@import "mixins/gradients";
|
33
|
+
|
34
|
+
// Layout
|
35
|
+
@import "mixins/clearfix";
|
36
|
+
@import "mixins/center-block";
|
37
|
+
@import "mixins/nav-vertical-align";
|
38
|
+
@import "mixins/grid-framework";
|
39
|
+
@import "mixins/grid";
|
@@ -0,0 +1,147 @@
|
|
1
|
+
//
|
2
|
+
// Modals
|
3
|
+
// --------------------------------------------------
|
4
|
+
|
5
|
+
// .modal-open - body class for killing the scroll
|
6
|
+
// .modal - container to scroll within
|
7
|
+
// .modal-dialog - positioning shell for the actual modal
|
8
|
+
// .modal-content - actual modal w/ bg and corners and shit
|
9
|
+
|
10
|
+
// Kill the scroll on the body
|
11
|
+
.modal-open {
|
12
|
+
overflow: hidden;
|
13
|
+
}
|
14
|
+
|
15
|
+
// Container that the modal scrolls within
|
16
|
+
.modal {
|
17
|
+
display: none;
|
18
|
+
overflow: auto;
|
19
|
+
overflow-y: scroll;
|
20
|
+
position: fixed;
|
21
|
+
top: 0;
|
22
|
+
right: 0;
|
23
|
+
bottom: 0;
|
24
|
+
left: 0;
|
25
|
+
z-index: $zindex-modal;
|
26
|
+
-webkit-overflow-scrolling: touch;
|
27
|
+
|
28
|
+
// Prevent Chrome on Windows from adding a focus outline. For details, see
|
29
|
+
// https://github.com/twbs/bootstrap/pull/10951.
|
30
|
+
outline: 0;
|
31
|
+
|
32
|
+
// When fading in the modal, animate it to slide down
|
33
|
+
&.fade .modal-dialog {
|
34
|
+
@include translate(0, -25%);
|
35
|
+
@include transition-transform(0.3s ease-out);
|
36
|
+
}
|
37
|
+
&.in .modal-dialog { @include translate(0, 0)}
|
38
|
+
}
|
39
|
+
|
40
|
+
// Shell div to position the modal with bottom padding
|
41
|
+
.modal-dialog {
|
42
|
+
position: relative;
|
43
|
+
width: auto;
|
44
|
+
margin: 10px;
|
45
|
+
}
|
46
|
+
|
47
|
+
// Actual modal
|
48
|
+
.modal-content {
|
49
|
+
position: relative;
|
50
|
+
background-color: $modal-content-bg;
|
51
|
+
border: 1px solid $modal-content-fallback-border-color; //old browsers fallback (ie8 etc)
|
52
|
+
border: 1px solid $modal-content-border-color;
|
53
|
+
border-radius: $border-radius-large;
|
54
|
+
@include box-shadow(0 3px 9px rgba(0,0,0,.5));
|
55
|
+
background-clip: padding-box;
|
56
|
+
// Remove focus outline from opened modal
|
57
|
+
outline: 0;
|
58
|
+
}
|
59
|
+
|
60
|
+
// Modal background
|
61
|
+
.modal-backdrop {
|
62
|
+
position: fixed;
|
63
|
+
top: 0;
|
64
|
+
right: 0;
|
65
|
+
bottom: 0;
|
66
|
+
left: 0;
|
67
|
+
z-index: $zindex-modal-background;
|
68
|
+
background-color: $modal-backdrop-bg;
|
69
|
+
// Fade for backdrop
|
70
|
+
&.fade { @include opacity(0); }
|
71
|
+
&.in { @include opacity($modal-backdrop-opacity); }
|
72
|
+
}
|
73
|
+
|
74
|
+
// Modal header
|
75
|
+
// Top section of the modal w/ title and dismiss
|
76
|
+
.modal-header {
|
77
|
+
padding: $modal-title-padding;
|
78
|
+
border-bottom: 1px solid $modal-header-border-color;
|
79
|
+
min-height: ($modal-title-padding + $modal-title-line-height);
|
80
|
+
}
|
81
|
+
// Close icon
|
82
|
+
.modal-header .close {
|
83
|
+
margin-top: -2px;
|
84
|
+
}
|
85
|
+
|
86
|
+
// Title text within header
|
87
|
+
.modal-title {
|
88
|
+
margin: 0;
|
89
|
+
line-height: $modal-title-line-height;
|
90
|
+
}
|
91
|
+
|
92
|
+
// Modal body
|
93
|
+
// Where all modal content resides (sibling of .modal-header and .modal-footer)
|
94
|
+
.modal-body {
|
95
|
+
position: relative;
|
96
|
+
padding: $modal-inner-padding;
|
97
|
+
}
|
98
|
+
|
99
|
+
// Footer (for actions)
|
100
|
+
.modal-footer {
|
101
|
+
padding: $modal-inner-padding;
|
102
|
+
text-align: right; // right align buttons
|
103
|
+
border-top: 1px solid $modal-footer-border-color;
|
104
|
+
@include clearfix(); // clear it in case folks use .pull-* classes on buttons
|
105
|
+
|
106
|
+
// Properly space out buttons
|
107
|
+
.btn + .btn {
|
108
|
+
margin-left: 5px;
|
109
|
+
margin-bottom: 0; // account for input[type="submit"] which gets the bottom margin like all other inputs
|
110
|
+
}
|
111
|
+
// but override that for button groups
|
112
|
+
.btn-group .btn + .btn {
|
113
|
+
margin-left: -1px;
|
114
|
+
}
|
115
|
+
// and override it for block buttons as well
|
116
|
+
.btn-block + .btn-block {
|
117
|
+
margin-left: 0;
|
118
|
+
}
|
119
|
+
}
|
120
|
+
|
121
|
+
// Measure scrollbar width for padding body during modal show/hide
|
122
|
+
.modal-scrollbar-measure {
|
123
|
+
position: absolute;
|
124
|
+
top: -9999px;
|
125
|
+
width: 50px;
|
126
|
+
height: 50px;
|
127
|
+
overflow: scroll;
|
128
|
+
}
|
129
|
+
|
130
|
+
// Scale up the modal
|
131
|
+
@media (min-width: $screen-sm-min) {
|
132
|
+
// Automatically set modal's width for larger viewports
|
133
|
+
.modal-dialog {
|
134
|
+
width: $modal-md;
|
135
|
+
margin: 30px auto;
|
136
|
+
}
|
137
|
+
.modal-content {
|
138
|
+
@include box-shadow(0 5px 15px rgba(0,0,0,.5));
|
139
|
+
}
|
140
|
+
|
141
|
+
// Modal sizes
|
142
|
+
.modal-sm { width: $modal-sm; }
|
143
|
+
}
|
144
|
+
|
145
|
+
@media (min-width: $screen-md-min) {
|
146
|
+
.modal-lg { width: $modal-lg; }
|
147
|
+
}
|