biovision-base 0.22.180920.0 → 0.34.190331.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +5 -21
- data/app/assets/images/biovision/base/icons/apply.svg +4 -0
- data/app/assets/images/biovision/base/icons/components/contact.svg +26 -0
- data/app/assets/images/biovision/base/icons/components/registration.svg +17 -0
- data/app/assets/images/biovision/base/icons/destroy.svg +11 -8
- data/app/assets/images/biovision/base/icons/settings.svg +41 -0
- data/app/assets/images/biovision/base/icons/slider/arrow-left.svg +4 -0
- data/app/assets/images/biovision/base/icons/slider/arrow-right.svg +4 -0
- data/app/assets/images/biovision/base/placeholders/16x9.svg +10 -3
- data/app/assets/images/biovision/base/placeholders/1x1.svg +12 -0
- data/app/assets/images/biovision/base/placeholders/3x2.svg +10 -3
- data/app/assets/javascripts/biovision/base/biovision.js +780 -461
- data/app/assets/javascripts/biovision/base/components/carousel.js +123 -0
- data/app/assets/javascripts/biovision/base/polyfills.js +149 -0
- data/app/assets/stylesheets/biovision/base/admin.scss +85 -46
- data/app/assets/stylesheets/biovision/base/admin/components.scss +141 -0
- data/app/assets/stylesheets/biovision/base/biovision.scss +149 -33
- data/app/assets/stylesheets/biovision/base/buttons/buttons-common.scss +22 -0
- data/app/assets/stylesheets/biovision/base/default.scss +6 -6
- data/app/assets/stylesheets/biovision/base/default_admin.scss +25 -8
- data/app/assets/stylesheets/biovision/base/themes/simple-layout.scss +0 -3
- data/app/controllers/admin/editable_pages_controller.rb +6 -4
- data/app/controllers/admin/privileges_controller.rb +2 -3
- data/app/controllers/admin/settings_controller.rb +52 -0
- data/app/controllers/admin/simple_blocks_controller.rb +28 -0
- data/app/controllers/admin/users_controller.rb +1 -1
- data/app/controllers/agents_controller.rb +4 -4
- data/app/controllers/authentication_controller.rb +28 -6
- data/app/controllers/browsers_controller.rb +4 -4
- data/app/controllers/concerns/authentication.rb +8 -5
- data/app/controllers/concerns/entity_priority.rb +3 -0
- data/app/controllers/concerns/lockable_entity.rb +6 -3
- data/app/controllers/concerns/removable_image.rb +4 -5
- data/app/controllers/concerns/toggleable_entity.rb +4 -5
- data/app/controllers/editable_pages_controller.rb +14 -8
- data/app/controllers/fallback_controller.rb +7 -2
- data/app/controllers/feedback_requests_controller.rb +23 -8
- data/app/controllers/metrics_controller.rb +3 -3
- data/app/controllers/my/profiles_controller.rb +32 -15
- data/app/controllers/privilege_groups_controller.rb +4 -4
- data/app/controllers/privileges_controller.rb +7 -26
- data/app/controllers/simple_blocks_controller.rb +63 -0
- data/app/controllers/stored_values_controller.rb +4 -4
- data/app/controllers/tokens_controller.rb +4 -4
- data/app/controllers/users_controller.rb +8 -3
- data/app/helpers/biovision_users_helper.rb +60 -21
- data/app/helpers/editable_pages_helper.rb +22 -0
- data/app/helpers/languages_helper.rb +3 -0
- data/app/helpers/simple_image_helper.rb +66 -0
- data/app/mailers/application_mailer.rb +0 -2
- data/app/mailers/code_sender.rb +13 -2
- data/app/mailers/feedback_mailer.rb +5 -2
- data/app/mailers/user_mailer.rb +6 -1
- data/app/models/biovision_component.rb +43 -0
- data/app/models/biovision_parameter.rb +34 -0
- data/app/models/code.rb +22 -7
- data/app/models/code_type.rb +9 -1
- data/app/models/concerns/flat_priority.rb +50 -0
- data/app/models/concerns/nested_priority.rb +58 -0
- data/app/models/concerns/required_unique_slug.rb +5 -2
- data/app/models/editable_page.rb +49 -37
- data/app/models/foreign_site.rb +5 -3
- data/app/models/language.rb +15 -37
- data/app/models/metric.rb +2 -4
- data/app/models/privilege.rb +23 -45
- data/app/models/privilege_group.rb +6 -1
- data/app/models/simple_block.rb +66 -0
- data/app/models/user.rb +29 -26
- data/app/models/user_privilege.rb +1 -1
- data/app/services/biovision/components/base_component.rb +115 -0
- data/app/services/biovision/components/registration_component.rb +98 -0
- data/app/services/code_manager.rb +4 -1
- data/app/services/code_manager/confirmation.rb +8 -4
- data/app/services/code_manager/invitation.rb +9 -5
- data/app/services/code_manager/recovery.rb +9 -6
- data/app/services/user_manager.rb +5 -4
- data/app/services/user_profile_handler.rb +38 -11
- data/app/uploaders/avatar_uploader.rb +5 -1
- data/app/uploaders/editable_page_image_uploader.rb +4 -6
- data/app/uploaders/media_file_uploader.rb +6 -4
- data/app/uploaders/media_snapshot_uploader.rb +6 -2
- data/app/uploaders/simple_file_uploader.rb +12 -0
- data/app/uploaders/simple_image_uploader.rb +75 -0
- data/app/views/about/editable.html.erb +1 -1
- data/app/views/admin/agents/_filter.html.erb +1 -1
- data/app/views/admin/editable_pages/entity/_in_list.html.erb +16 -0
- data/app/views/admin/editable_pages/index.html.erb +8 -1
- data/app/views/admin/editable_pages/show.html.erb +21 -17
- data/app/views/admin/feedback_requests/entity/_in_list.html.erb +9 -1
- data/app/views/admin/index/_biovision_base.html.erb +5 -7
- data/app/views/admin/index/_components.html.erb +9 -0
- data/app/views/admin/index/dashboard/_editorial.html.erb +2 -2
- data/app/views/admin/index/dashboard/_settings.html.erb +2 -2
- data/app/views/admin/index/index.html.erb +2 -0
- data/app/views/admin/privileges/entity/_groups.html.erb +25 -25
- data/app/views/admin/privileges/entity/_in_list.html.erb +30 -9
- data/app/views/admin/privileges/index.html.erb +6 -1
- data/app/views/admin/privileges/show.html.erb +31 -18
- data/app/views/admin/settings/component/_new_parameter.html.erb +62 -0
- data/app/views/admin/settings/component/_parameters.html.erb +37 -0
- data/app/views/admin/settings/component/_setting.html.erb +18 -0
- data/app/views/admin/settings/component/_settings.html.erb +31 -0
- data/app/views/admin/settings/index.html.erb +27 -0
- data/app/views/admin/settings/show.html.erb +42 -0
- data/app/views/admin/simple_blocks/_nav_item.html.erb +6 -0
- data/app/views/admin/simple_blocks/entity/_in_list.html.erb +23 -0
- data/app/views/admin/simple_blocks/index.html.erb +21 -0
- data/app/views/admin/simple_blocks/show.html.erb +51 -0
- data/app/views/admin/tokens/_filter.html.erb +1 -1
- data/app/views/admin/users/_filter.html.erb +1 -1
- data/app/views/admin/users/entity/_privilege.html.erb +12 -21
- data/app/views/admin/users/entity/_privilege_tree.html.erb +17 -15
- data/app/views/admin/users/privileges.html.erb +9 -1
- data/app/views/admin/users/search.jbuilder +3 -3
- data/app/views/admin/users/show.html.erb +11 -6
- data/app/views/agents/_filter.html.erb +22 -22
- data/app/views/agents/_form.html.erb +25 -29
- data/app/views/application/forbidden.html.erb +9 -0
- data/app/views/application/forbidden.jbuilder +3 -0
- data/app/views/authentication/_form.html.erb +13 -13
- data/app/views/browsers/_form.html.erb +21 -25
- data/app/views/editable_blocks/_entity.html.erb +4 -1
- data/app/views/editable_pages/_form.html.erb +63 -62
- data/app/views/editable_pages/edit.html.erb +1 -1
- data/app/views/editable_pages/entity/_metadata.html.erb +4 -4
- data/app/views/editable_pages/new.html.erb +3 -3
- data/app/views/fallback/show.html.erb +8 -1
- data/app/views/feedback_requests/_form.html.erb +76 -52
- data/app/views/feedback_requests/create.js.erb +1 -10
- data/app/views/index/index/_editable.html.erb +0 -4
- data/app/views/metrics/_form.html.erb +38 -36
- data/app/views/my/confirmations/show.html.erb +5 -3
- data/app/views/my/profiles/closed.html.erb +7 -0
- data/app/views/my/profiles/edit/_form.html.erb +9 -9
- data/app/views/my/profiles/new.html.erb +9 -1
- data/app/views/my/profiles/new/_form.html.erb +22 -1
- data/app/views/my/recoveries/show.html.erb +2 -2
- data/app/views/privilege_groups/_form.html.erb +48 -21
- data/app/views/privileges/_form.html.erb +68 -36
- data/app/views/profiles/_profile.html.erb +3 -3
- data/app/views/shared/_pagination.jbuilder +7 -5
- data/app/views/shared/admin/_breadcrumbs.html.erb +1 -1
- data/app/views/shared/forms/_meta_texts.html.erb +3 -3
- data/app/views/shared/forms/_priority.html.erb +12 -0
- data/app/views/shared/forms/_state_container.html.erb +1 -0
- data/app/views/simple_blocks/_empty.html.erb +0 -0
- data/app/views/simple_blocks/_form.html.erb +120 -0
- data/app/views/simple_blocks/_simple_block.html.erb +26 -0
- data/app/views/simple_blocks/edit.html.erb +17 -0
- data/app/views/simple_blocks/new.html.erb +15 -0
- data/app/views/stored_values/_form.html.erb +57 -28
- data/app/views/tokens/_form.html.erb +31 -26
- data/app/views/users/_form.html.erb +1 -1
- data/config/initializers/carrierwave.rb +7 -2
- data/config/locales/common-ru.yml +5 -0
- data/config/locales/components-ru.yml +50 -0
- data/config/locales/editable-pages-en.yml +2 -0
- data/config/locales/editable-pages-ru.yml +50 -7
- data/config/locales/editable-pages-sv.yml +2 -0
- data/config/locales/feedback-ru.yml +1 -0
- data/config/locales/users-en.yml +0 -1
- data/config/locales/users-ru.yml +6 -1
- data/config/locales/users-sv.yml +0 -1
- data/config/routes.rb +32 -6
- data/db/migrate/20181217000000_create_biovision_components.rb +80 -0
- data/db/migrate/20181217000010_create_metrics.rb +40 -0
- data/db/migrate/20181217000015_create_browsers.rb +38 -0
- data/db/migrate/20181217000020_create_languages.rb +30 -0
- data/db/migrate/20181217000030_create_users.rb +118 -0
- data/db/migrate/20181217000035_create_codes.rb +51 -0
- data/db/migrate/20181217000040_create_privileges.rb +142 -0
- data/db/migrate/20181217000100_create_media_folders.rb +53 -0
- data/db/migrate/20181217000110_create_editable_pages.rb +90 -0
- data/db/migrate/20181217000200_create_feedback_requests.rb +27 -0
- data/db/migrate/20181217121211_add_uuid_to_users.rb +12 -0
- data/db/migrate/20181217121212_update_fields181217.rb +29 -0
- data/db/migrate/20190311121212_convert_json_columns.rb +47 -0
- data/db/migrate/20190324181818_add_data_to_feedback_requests.rb +14 -0
- data/db/migrate/20190326120000_create_simple_blocks.rb +31 -0
- data/db/{migrate → obsolete_migrations}/20171223333333_amend_foreign_keys.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180117151515_add_language_to_models.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180321000000_add_profile_data_to_users.rb +4 -4
- data/db/{migrate → obsolete_migrations}/20180405000000_add_consent_to_users.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180610222222_add_consent_to_feedback_requests.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180612111111_add_administrative_to_privilege.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180619121212_add_image_alt_text_to_editable_page.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180703111111_add_fields_to_editable_blocks.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180722222222_add_active_to_languages.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180725111111_add_referral_link_to_users.rb +0 -0
- data/db/obsolete_migrations/20181012222222_add_deletable_to_privileges.rb +19 -0
- data/db/obsolete_migrations/20181012222223_convert_stored_values.rb +13 -0
- data/db/obsolete_migrations/20181030080808_update_editable_pages_meta.rb +20 -0
- data/lib/biovision/base/base_methods.rb +19 -2
- data/lib/biovision/base/version.rb +3 -1
- data/lib/tasks/users.rake +19 -1
- metadata +75 -40
- data/app/views/admin/privileges/_list.html.erb +0 -15
- data/db/migrate/20170228000000_create_languages.rb +0 -23
- data/db/migrate/20170301000001_create_metrics.rb +0 -23
- data/db/migrate/20170301000002_create_metric_values.rb +0 -19
- data/db/migrate/20170301000101_create_browsers.rb +0 -22
- data/db/migrate/20170301000102_create_agents.rb +0 -22
- data/db/migrate/20170302000001_create_users.rb +0 -55
- data/db/migrate/20170302000003_create_tokens.rb +0 -23
- data/db/migrate/20170302000004_create_code_types.rb +0 -20
- data/db/migrate/20170302000005_create_codes.rb +0 -24
- data/db/migrate/20170302000101_create_privileges.rb +0 -41
- data/db/migrate/20170302000102_create_user_privileges.rb +0 -18
- data/db/migrate/20170302000103_create_privilege_groups.rb +0 -23
- data/db/migrate/20170302000104_create_privilege_group_privileges.rb +0 -24
- data/db/migrate/20170320000000_create_editable_pages.rb +0 -52
- data/db/migrate/20170425000001_create_foreign_sites.rb +0 -18
- data/db/migrate/20170425000002_create_foreign_users.rb +0 -23
- data/db/migrate/20170629120000_create_login_attempts.rb +0 -19
- data/db/migrate/20170823000001_create_stored_values.rb +0 -19
- data/db/migrate/20171202000000_create_media_folders.rb +0 -28
- data/db/migrate/20171202000001_create_media_files.rb +0 -27
- data/db/migrate/20171211000000_create_feedback_requests.rb +0 -33
- data/db/migrate/20180117160000_create_user_languages.rb +0 -17
- data/db/migrate/20180622140000_create_link_blocks.rb +0 -29
- data/db/migrate/20180622140001_create_link_block_items.rb +0 -23
- data/db/migrate/20180627190000_create_editable_blocks.rb +0 -39
@@ -0,0 +1,123 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Biovision.components.carousel = {
|
4
|
+
initialized: false,
|
5
|
+
selector: '.js-biovision-carousel',
|
6
|
+
sliders: [],
|
7
|
+
init: function () {
|
8
|
+
document.querySelectorAll(this.selector).forEach(this.apply);
|
9
|
+
this.initialized = true;
|
10
|
+
},
|
11
|
+
apply: function (element) {
|
12
|
+
const component = Biovision.components.carousel;
|
13
|
+
const slider = {
|
14
|
+
"element": element,
|
15
|
+
"container": element.querySelector(".carousel-container"),
|
16
|
+
"items": element.querySelectorAll(".carousel-item"),
|
17
|
+
"prevButton": element.querySelector("button.prev"),
|
18
|
+
"nextButton": element.querySelector("button.next"),
|
19
|
+
"current": 0
|
20
|
+
};
|
21
|
+
if (element.hasAttribute("data-type")) {
|
22
|
+
slider["type"] = element.getAttribute("data-type");
|
23
|
+
} else {
|
24
|
+
slider["type"] = "offset";
|
25
|
+
}
|
26
|
+
if (element.hasAttribute("data-timeout")) {
|
27
|
+
slider["timeout"] = parseInt(element.getAttribute("data-timeout"));
|
28
|
+
slider["timeout_handler"] = window.setInterval(component.nextItem, slider["timeout"], slider);
|
29
|
+
}
|
30
|
+
if (slider["prevButton"]) {
|
31
|
+
slider["prevButton"].addEventListener('click', component.clickedPrev);
|
32
|
+
}
|
33
|
+
if (slider["nextButton"]) {
|
34
|
+
slider["nextButton"].addEventListener('click', component.clickedNext);
|
35
|
+
}
|
36
|
+
slider["maxItem"] = slider["items"].length - 1;
|
37
|
+
component.sliders.push(slider);
|
38
|
+
component.rearrange(slider);
|
39
|
+
},
|
40
|
+
rearrange: function (slider) {
|
41
|
+
const component = Biovision.components.carousel;
|
42
|
+
switch (slider["type"]) {
|
43
|
+
case "current-item":
|
44
|
+
component.newCurrentItem(slider);
|
45
|
+
break;
|
46
|
+
case "offset":
|
47
|
+
component.setMaxItem(slider);
|
48
|
+
component.newOffset(slider);
|
49
|
+
break;
|
50
|
+
default:
|
51
|
+
console.log("Unknown carousel type: " + slider["type"]);
|
52
|
+
component.newOffset(slider);
|
53
|
+
}
|
54
|
+
},
|
55
|
+
clickedPrev: function (event) {
|
56
|
+
const component = Biovision.components.carousel;
|
57
|
+
const slider = component.sliderForButton(event.target);
|
58
|
+
component.prevItem(slider);
|
59
|
+
},
|
60
|
+
clickedNext: function (event) {
|
61
|
+
const component = Biovision.components.carousel;
|
62
|
+
const slider = component.sliderForButton(event.target);
|
63
|
+
component.nextItem(slider);
|
64
|
+
},
|
65
|
+
sliderForButton: function (button) {
|
66
|
+
const element = button.closest(this.selector);
|
67
|
+
for (let i = 0; i < this.sliders.length; i++) {
|
68
|
+
if (this.sliders[i].element === element) {
|
69
|
+
return this.sliders[i];
|
70
|
+
}
|
71
|
+
}
|
72
|
+
},
|
73
|
+
nextItem: function (slider) {
|
74
|
+
const component = Biovision.components.carousel;
|
75
|
+
|
76
|
+
slider["current"]++;
|
77
|
+
if (slider["current"] > slider["maxItem"]) {
|
78
|
+
slider["current"] = 0;
|
79
|
+
}
|
80
|
+
|
81
|
+
component.rearrange(slider);
|
82
|
+
},
|
83
|
+
prevItem: function (slider) {
|
84
|
+
const component = Biovision.components.carousel;
|
85
|
+
slider["current"]--;
|
86
|
+
if (slider["current"] < 0) {
|
87
|
+
slider["current"] = slider["maxItem"];
|
88
|
+
}
|
89
|
+
|
90
|
+
component.rearrange(slider);
|
91
|
+
},
|
92
|
+
newCurrentItem: function (slider) {
|
93
|
+
const selector = '.carousel-item:nth-of-type(' + (slider.current + 1) + ')';
|
94
|
+
const currentSlide = slider.container.querySelector('.carousel-item.current');
|
95
|
+
if (currentSlide) {
|
96
|
+
currentSlide.classList.remove('current');
|
97
|
+
}
|
98
|
+
slider.container.querySelector(selector).classList.add('current');
|
99
|
+
},
|
100
|
+
newOffset: function (slider) {
|
101
|
+
const firstSlide = slider.container.querySelector('.carousel-item:first-of-type');
|
102
|
+
const rightMargin = window.getComputedStyle(firstSlide).marginRight;
|
103
|
+
const slideWidth = firstSlide.offsetWidth + parseInt(rightMargin);
|
104
|
+
let newMargin = -(slideWidth * slider.current);
|
105
|
+
const slidesLength = slideWidth * slider.items.length;
|
106
|
+
const maxOffset = slidesLength - slider.container.offsetWidth;
|
107
|
+
const delta = newMargin + maxOffset;
|
108
|
+
|
109
|
+
if (delta < 0) {
|
110
|
+
newMargin -= delta;
|
111
|
+
slider["current"] = slider["maxItem"];
|
112
|
+
}
|
113
|
+
|
114
|
+
firstSlide.style.marginLeft = String(newMargin) + 'px';
|
115
|
+
},
|
116
|
+
setMaxItem: function (slider) {
|
117
|
+
const firstSlide = slider.container.querySelector('.carousel-item:first-of-type');
|
118
|
+
const rightMargin = window.getComputedStyle(firstSlide).marginRight;
|
119
|
+
const slideWidth = firstSlide.offsetWidth + parseInt(rightMargin);
|
120
|
+
const maxCount = slider.container.offsetWidth / slideWidth;
|
121
|
+
slider["maxItem"] = slider.items.length - Math.floor(maxCount);
|
122
|
+
}
|
123
|
+
};
|
@@ -0,0 +1,149 @@
|
|
1
|
+
/*
|
2
|
+
*************
|
3
|
+
* Polyfills *
|
4
|
+
*************
|
5
|
+
*/
|
6
|
+
|
7
|
+
/**
|
8
|
+
* Element.matches()
|
9
|
+
*
|
10
|
+
* IE 9+
|
11
|
+
*
|
12
|
+
* @see https://developer.mozilla.org/en-US/docs/Web/API/Element/matches
|
13
|
+
*/
|
14
|
+
if (!Element.prototype.matches) {
|
15
|
+
Element.prototype.matches =
|
16
|
+
Element.prototype.msMatchesSelector ||
|
17
|
+
Element.prototype.webkitMatchesSelector;
|
18
|
+
}
|
19
|
+
|
20
|
+
/**
|
21
|
+
* Element.closest()
|
22
|
+
*
|
23
|
+
* IE
|
24
|
+
*
|
25
|
+
* @see https://developer.mozilla.org/en-US/docs/Web/API/Element/closest
|
26
|
+
*/
|
27
|
+
if (!Element.prototype.closest) {
|
28
|
+
Element.prototype.closest = function (s) {
|
29
|
+
let el = this;
|
30
|
+
let ancestor = this;
|
31
|
+
|
32
|
+
if (!document.documentElement.contains(el)) {
|
33
|
+
return null;
|
34
|
+
}
|
35
|
+
do {
|
36
|
+
if (ancestor.matches(s)) {
|
37
|
+
return ancestor;
|
38
|
+
}
|
39
|
+
ancestor = ancestor.parentElement;
|
40
|
+
} while (ancestor !== null);
|
41
|
+
|
42
|
+
return null;
|
43
|
+
};
|
44
|
+
}
|
45
|
+
|
46
|
+
/**
|
47
|
+
* ParentNode.prepend()
|
48
|
+
*
|
49
|
+
* IE
|
50
|
+
*
|
51
|
+
* @see https://developer.mozilla.org/en-US/docs/Web/API/ParentNode/prepend
|
52
|
+
* @see https://github.com/jserz/js_piece/blob/master/DOM/ParentNode/prepend()/prepend().md
|
53
|
+
*/
|
54
|
+
(function (arr) {
|
55
|
+
arr.forEach(function (item) {
|
56
|
+
if (item.hasOwnProperty('prepend')) {
|
57
|
+
return;
|
58
|
+
}
|
59
|
+
Object.defineProperty(item, 'prepend', {
|
60
|
+
configurable: true,
|
61
|
+
enumerable: true,
|
62
|
+
writable: true,
|
63
|
+
value: function prepend() {
|
64
|
+
let argArr = Array.prototype.slice.call(arguments),
|
65
|
+
docFrag = document.createDocumentFragment();
|
66
|
+
|
67
|
+
argArr.forEach(function (argItem) {
|
68
|
+
let isNode = argItem instanceof Node;
|
69
|
+
docFrag.appendChild(isNode ? argItem : document.createTextNode(String(argItem)));
|
70
|
+
});
|
71
|
+
|
72
|
+
this.insertBefore(docFrag, this.firstChild);
|
73
|
+
}
|
74
|
+
});
|
75
|
+
});
|
76
|
+
})([Element.prototype, Document.prototype, DocumentFragment.prototype]);
|
77
|
+
|
78
|
+
/**
|
79
|
+
* ParentNode.append()
|
80
|
+
*
|
81
|
+
* IE
|
82
|
+
*
|
83
|
+
* @see https://developer.mozilla.org/en-US/docs/Web/API/ParentNode/append
|
84
|
+
* @see https://github.com/jserz/js_piece/blob/master/DOM/ParentNode/append()/append().md
|
85
|
+
*/
|
86
|
+
(function (arr) {
|
87
|
+
arr.forEach(function (item) {
|
88
|
+
if (item.hasOwnProperty('append')) {
|
89
|
+
return;
|
90
|
+
}
|
91
|
+
Object.defineProperty(item, 'append', {
|
92
|
+
configurable: true,
|
93
|
+
enumerable: true,
|
94
|
+
writable: true,
|
95
|
+
value: function append() {
|
96
|
+
let argArr = Array.prototype.slice.call(arguments),
|
97
|
+
docFrag = document.createDocumentFragment();
|
98
|
+
|
99
|
+
argArr.forEach(function (argItem) {
|
100
|
+
let isNode = argItem instanceof Node;
|
101
|
+
docFrag.appendChild(isNode ? argItem : document.createTextNode(String(argItem)));
|
102
|
+
});
|
103
|
+
|
104
|
+
this.appendChild(docFrag);
|
105
|
+
}
|
106
|
+
});
|
107
|
+
});
|
108
|
+
})([Element.prototype, Document.prototype, DocumentFragment.prototype]);
|
109
|
+
|
110
|
+
/**
|
111
|
+
* ChildNode.remove()
|
112
|
+
*
|
113
|
+
* IE
|
114
|
+
*
|
115
|
+
* @see https://developer.mozilla.org/en-US/docs/Web/API/ChildNode/remove
|
116
|
+
*/
|
117
|
+
(function (arr) {
|
118
|
+
arr.forEach(function (item) {
|
119
|
+
if (item.hasOwnProperty('remove')) {
|
120
|
+
return;
|
121
|
+
}
|
122
|
+
Object.defineProperty(item, 'remove', {
|
123
|
+
configurable: true,
|
124
|
+
enumerable: true,
|
125
|
+
writable: true,
|
126
|
+
value: function remove() {
|
127
|
+
if (this.parentNode !== null) {
|
128
|
+
this.parentNode.removeChild(this);
|
129
|
+
}
|
130
|
+
}
|
131
|
+
});
|
132
|
+
});
|
133
|
+
})([Element.prototype, CharacterData.prototype, DocumentType.prototype]);
|
134
|
+
|
135
|
+
/**
|
136
|
+
* NodeList.forEach()
|
137
|
+
*
|
138
|
+
* ES5
|
139
|
+
*
|
140
|
+
* @see https://developer.mozilla.org/en-US/docs/Web/API/NodeList/forEach
|
141
|
+
*/
|
142
|
+
if (window.NodeList && !NodeList.prototype.forEach) {
|
143
|
+
NodeList.prototype.forEach = function (callback, thisArg) {
|
144
|
+
thisArg = thisArg || window;
|
145
|
+
for (let i = 0; i < this.length; i++) {
|
146
|
+
callback.call(thisArg, this[i], i, this);
|
147
|
+
}
|
148
|
+
};
|
149
|
+
}
|
@@ -1,14 +1,27 @@
|
|
1
1
|
:root {
|
2
|
-
--
|
3
|
-
--
|
4
|
-
--
|
5
|
-
--
|
2
|
+
--font-size-xxxl: #{$font-size-xxxl};
|
3
|
+
--font-size-xxl: #{$font-size-xxl};
|
4
|
+
--font-size-xl: #{$font-size-xl};
|
5
|
+
--font-size-large: #{$font-size-large};
|
6
|
+
--font-size-increased: #{$font-size-increased};
|
7
|
+
--font-size-normal: #{$font-size-normal};
|
8
|
+
--font-size-decreased: #{$font-size-decreased};
|
9
|
+
--font-size-small: #{$font-size-small};
|
10
|
+
--font-size-xs: #{$font-size-xs};
|
11
|
+
|
12
|
+
--spacer-s: #{$spacer-s}; // 1.6
|
13
|
+
--spacer-xxxs: .2rem;
|
14
|
+
--spacer-xxs: calc(var(--spacer-s) / 4); // .4
|
15
|
+
--spacer-xs: calc(var(--spacer-s) / 2); // .8
|
16
|
+
--spacer-m: calc(var(--spacer-s) * 2); // 3.2
|
17
|
+
--spacer-l: calc(var(--spacer-s) * 3); // 4.8
|
18
|
+
--spacer-xl: calc(var(--spacer-s) * 4); // 6.4
|
19
|
+
--spacer-xxl: calc(var(--spacer-s) * 6); // 9.6
|
6
20
|
}
|
7
21
|
|
8
22
|
html {
|
9
23
|
background: linear-gradient(to bottom, #dedfe3 2%, #aeb3b9 95%) fixed, radial-gradient(farthest-corner at 33% 100%, rgba(255, 255, 255, .5) 0%, rgba(0, 0, 0, .5) 100%) fixed;
|
10
24
|
background-blend-mode: screen;
|
11
|
-
font: 300 10px $font-family-main;
|
12
25
|
}
|
13
26
|
|
14
27
|
a:link,
|
@@ -17,13 +30,15 @@ a:visited {
|
|
17
30
|
}
|
18
31
|
|
19
32
|
h1 {
|
20
|
-
font-size:
|
21
|
-
|
33
|
+
font-size: var(--font-size-xxl);
|
34
|
+
font-weight: 500;
|
35
|
+
margin-bottom: var(--spacer-xs);
|
22
36
|
}
|
23
37
|
|
24
38
|
h2 {
|
25
|
-
font-size:
|
26
|
-
|
39
|
+
font-size: var(--font-size-xl);
|
40
|
+
font-weight: 500;
|
41
|
+
margin-bottom: var(--spacer-xxs);
|
27
42
|
}
|
28
43
|
|
29
44
|
body {
|
@@ -31,18 +46,18 @@ body {
|
|
31
46
|
color: $text-color-primary;
|
32
47
|
display: flex;
|
33
48
|
flex-direction: column;
|
34
|
-
font-
|
49
|
+
font-weight: 300;
|
35
50
|
margin: 0 auto;
|
36
|
-
max-width:
|
51
|
+
max-width: $content-width;
|
37
52
|
min-height: 100vh;
|
38
|
-
min-width:
|
53
|
+
min-width: $content-width-min;
|
39
54
|
|
40
55
|
> header {
|
41
56
|
align-items: center;
|
42
57
|
border-bottom: $border-primary;
|
43
58
|
display: flex;
|
44
59
|
flex-wrap: wrap;
|
45
|
-
padding:
|
60
|
+
padding: var(--spacer-xs);
|
46
61
|
|
47
62
|
.logo {
|
48
63
|
margin: 0 auto 0 0;
|
@@ -60,7 +75,7 @@ body {
|
|
60
75
|
li {
|
61
76
|
display: inline-block;
|
62
77
|
list-style: none;
|
63
|
-
margin: 0
|
78
|
+
margin: 0 var(--spacer-xxs);
|
64
79
|
text-align: center;
|
65
80
|
}
|
66
81
|
}
|
@@ -73,15 +88,15 @@ body {
|
|
73
88
|
display: flex;
|
74
89
|
flex-direction: row;
|
75
90
|
flex-wrap: wrap;
|
76
|
-
font-size:
|
91
|
+
font-size: var(--font-size-decreased);
|
77
92
|
justify-content: space-between;
|
78
93
|
margin: auto 0 0 0;
|
79
|
-
padding:
|
94
|
+
padding: var(--spacer-xs);
|
80
95
|
}
|
81
96
|
}
|
82
97
|
|
83
98
|
#main {
|
84
|
-
padding:
|
99
|
+
padding: var(--spacer-xs);
|
85
100
|
width: 100%;
|
86
101
|
}
|
87
102
|
|
@@ -100,7 +115,7 @@ article {
|
|
100
115
|
}
|
101
116
|
|
102
117
|
dl {
|
103
|
-
margin: 0 0
|
118
|
+
margin: 0 0 var(--spacer-s);
|
104
119
|
padding: 0;
|
105
120
|
|
106
121
|
ul {
|
@@ -118,13 +133,26 @@ article {
|
|
118
133
|
font-weight: normal;
|
119
134
|
}
|
120
135
|
}
|
136
|
+
|
137
|
+
.text {
|
138
|
+
box-shadow: .2rem .2rem .8rem rgba(0, 0, 0, .25);
|
139
|
+
padding: var(--spacer-s);
|
140
|
+
|
141
|
+
ul {
|
142
|
+
padding-left: var(--spacer-m);
|
143
|
+
|
144
|
+
> li {
|
145
|
+
list-style: initial;
|
146
|
+
}
|
147
|
+
}
|
148
|
+
}
|
121
149
|
}
|
122
150
|
|
123
151
|
dt {
|
124
152
|
border-top: $border-secondary;
|
125
|
-
font: 400
|
126
|
-
margin:
|
127
|
-
padding:
|
153
|
+
font: 400 var(--font-size-increased) $font-family-main;
|
154
|
+
margin: var(--spacer-xs) 0 0;
|
155
|
+
padding: var(--spacer-xxs) 0;
|
128
156
|
}
|
129
157
|
|
130
158
|
dd {
|
@@ -134,7 +162,7 @@ article {
|
|
134
162
|
|
135
163
|
input,
|
136
164
|
textarea {
|
137
|
-
font-size:
|
165
|
+
font-size: var(--font-size-normal);
|
138
166
|
min-width: 1ch;
|
139
167
|
}
|
140
168
|
|
@@ -150,30 +178,31 @@ article {
|
|
150
178
|
}
|
151
179
|
|
152
180
|
> nav {
|
153
|
-
margin:
|
181
|
+
margin: var(--spacer-s) 0;
|
154
182
|
}
|
155
183
|
|
156
184
|
> section {
|
157
185
|
border-top: .1rem solid $text-color-secondary;
|
158
|
-
margin:
|
159
|
-
padding:
|
186
|
+
margin: var(--spacer-m) auto;
|
187
|
+
padding: var(--spacer-xs) 0 0;
|
160
188
|
}
|
161
189
|
}
|
162
190
|
|
163
191
|
.dashboard {
|
164
192
|
nav {
|
165
|
-
margin:
|
193
|
+
margin: var(--spacer-xxs) 0 var(--spacer-s);
|
166
194
|
max-width: 64rem;
|
167
195
|
}
|
168
196
|
|
197
|
+
h3,
|
169
198
|
.heading {
|
170
199
|
display: block;
|
171
|
-
font: 500
|
200
|
+
font: 500 var(--font-size-increased)/1.5 $font-family-heading;
|
172
201
|
}
|
173
202
|
|
174
203
|
ul {
|
175
204
|
box-shadow: $block-shadow;
|
176
|
-
margin:
|
205
|
+
margin: var(--spacer-xxs);
|
177
206
|
padding: 0;
|
178
207
|
}
|
179
208
|
|
@@ -181,7 +210,7 @@ article {
|
|
181
210
|
background: $row-background-odd;
|
182
211
|
list-style: none;
|
183
212
|
margin: 0;
|
184
|
-
padding:
|
213
|
+
padding: var(--spacer-xs);
|
185
214
|
position: relative;
|
186
215
|
|
187
216
|
&:nth-last-of-type(even) {
|
@@ -191,7 +220,7 @@ article {
|
|
191
220
|
|
192
221
|
.description {
|
193
222
|
color: $text-color-secondary;
|
194
|
-
font-size:
|
223
|
+
font-size: var(--font-size-decreased);
|
195
224
|
}
|
196
225
|
}
|
197
226
|
|
@@ -211,25 +240,15 @@ article {
|
|
211
240
|
}
|
212
241
|
}
|
213
242
|
|
214
|
-
nav.
|
215
|
-
margin-bottom:
|
216
|
-
padding:
|
217
|
-
|
218
|
-
a {
|
219
|
-
background: image_url('biovision/base/icons/breadcrumb.svg') no-repeat bottom .1rem right / .6rem 1.2rem;
|
220
|
-
padding-right: 1rem;
|
221
|
-
transition: background .25s;
|
222
|
-
|
223
|
-
&:hover {
|
224
|
-
background-image: image_url('biovision/base/icons/breadcrumb-hover.svg');
|
225
|
-
}
|
226
|
-
}
|
243
|
+
nav.breadcrumbs {
|
244
|
+
margin-bottom: var(--spacer-xs);
|
245
|
+
padding: var(--spacer-xxs);
|
227
246
|
}
|
228
247
|
|
229
248
|
.privileges {
|
230
249
|
ul {
|
231
250
|
border-left: $border-primary;
|
232
|
-
margin:
|
251
|
+
margin: var(--spacer-xs) 0 0 var(--spacer-m);
|
233
252
|
}
|
234
253
|
}
|
235
254
|
|
@@ -247,14 +266,14 @@ nav.admin-breadcrumbs {
|
|
247
266
|
li {
|
248
267
|
list-style: none;
|
249
268
|
margin: 0;
|
250
|
-
padding:
|
269
|
+
padding: var(--spacer-xxs);
|
251
270
|
position: relative;
|
252
271
|
}
|
253
272
|
|
254
273
|
label {
|
255
274
|
cursor: pointer;
|
256
275
|
display: inline-block;
|
257
|
-
padding:
|
276
|
+
padding: var(--spacer-xxxs) var(--spacer-s);
|
258
277
|
transition: .125s;
|
259
278
|
}
|
260
279
|
|
@@ -275,3 +294,23 @@ nav.admin-breadcrumbs {
|
|
275
294
|
}
|
276
295
|
}
|
277
296
|
}
|
297
|
+
|
298
|
+
.ck-content {
|
299
|
+
ul {
|
300
|
+
padding-left: var(--spacer-m);
|
301
|
+
|
302
|
+
> li {
|
303
|
+
list-style: initial;
|
304
|
+
}
|
305
|
+
}
|
306
|
+
}
|
307
|
+
|
308
|
+
.state_container {
|
309
|
+
margin-bottom: var(--spacer-s);
|
310
|
+
|
311
|
+
progress {
|
312
|
+
width: 100%;
|
313
|
+
}
|
314
|
+
}
|
315
|
+
|
316
|
+
@import "biovision/base/admin/components";
|