whydcl section style fix, footer style fix
This commit is contained in:
parent
a895f7caa7
commit
883118e050
7 changed files with 76 additions and 43 deletions
|
@ -47,6 +47,8 @@ class DCLSectionPluginModel(CMSPlugin):
|
||||||
extra_classes += ' section-sm-center'
|
extra_classes += ' section-sm-center'
|
||||||
if self.background_gradient:
|
if self.background_gradient:
|
||||||
extra_classes += ' section-gradient'
|
extra_classes += ' section-gradient'
|
||||||
|
if self.plain_heading:
|
||||||
|
extra_classes += ' split-section-plain'
|
||||||
return extra_classes
|
return extra_classes
|
||||||
|
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
|
|
|
@ -8,6 +8,7 @@ from .cms_models import (
|
||||||
DCLSectionIconPluginModel, DCLSectionImagePluginModel,
|
DCLSectionIconPluginModel, DCLSectionImagePluginModel,
|
||||||
DCLSectionPluginModel,
|
DCLSectionPluginModel,
|
||||||
)
|
)
|
||||||
|
from .models import VMTemplate
|
||||||
|
|
||||||
|
|
||||||
@plugin_pool.register_plugin
|
@plugin_pool.register_plugin
|
||||||
|
@ -49,6 +50,13 @@ class DCLCalculatorPlugin(CMSPluginBase):
|
||||||
render_template = "datacenterlight/cms/calculator.html"
|
render_template = "datacenterlight/cms/calculator.html"
|
||||||
cache = False
|
cache = False
|
||||||
|
|
||||||
|
def render(self, context, instance, placeholder):
|
||||||
|
context = super(DCLCalculatorPlugin, self).render(
|
||||||
|
context, instance, placeholder
|
||||||
|
)
|
||||||
|
context['templates'] = VMTemplate.objects.all()
|
||||||
|
return context
|
||||||
|
|
||||||
|
|
||||||
@plugin_pool.register_plugin
|
@plugin_pool.register_plugin
|
||||||
class DCLBannerListPlugin(CMSPluginBase):
|
class DCLBannerListPlugin(CMSPluginBase):
|
||||||
|
|
|
@ -52,7 +52,10 @@
|
||||||
|
|
||||||
/* only for editing mode */
|
/* only for editing mode */
|
||||||
.section-figure .cms-plugin {
|
.section-figure .cms-plugin {
|
||||||
padding: 10px;
|
|
||||||
flex-basis: 50%;
|
flex-basis: 50%;
|
||||||
flex-grow: 1;
|
flex-grow: 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.split-section-plain .section-figure .cms-plugin {
|
||||||
|
flex-grow: 0;
|
||||||
|
}
|
|
@ -436,11 +436,29 @@ textarea {
|
||||||
}
|
}
|
||||||
|
|
||||||
.section-figure .section-image {
|
.section-figure .section-image {
|
||||||
padding: 10px;
|
padding: 25px 15px;
|
||||||
flex-basis: 50%;
|
flex-basis: 50%;
|
||||||
flex-grow: 1;
|
flex-grow: 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.split-section-plain .section-figure .section-image {
|
||||||
|
flex-grow: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.split-section-plain .section-figure {
|
||||||
|
justify-content: flex-start;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 768px) {
|
||||||
|
.split-section-plain .split-figure {
|
||||||
|
width: 41.66666667%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.split-section-plain .split-text {
|
||||||
|
width: 58.33333333%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.section-image img {
|
.section-image img {
|
||||||
margin: auto;
|
margin: auto;
|
||||||
}
|
}
|
||||||
|
@ -1236,12 +1254,12 @@ footer .dcl-link-separator::before {
|
||||||
content: "";
|
content: "";
|
||||||
position: absolute;
|
position: absolute;
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
top: 8px;
|
top: 9px;
|
||||||
bottom: 0;
|
bottom: 0;
|
||||||
left: -3px;
|
left: -2px;
|
||||||
right: 0;
|
right: 0;
|
||||||
width: 4px;
|
width: 2px;
|
||||||
height: 4px;
|
height: 2px;
|
||||||
border-radius: 100%;
|
border-radius: 100%;
|
||||||
background: #777;
|
background: #777;
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,17 +3,14 @@
|
||||||
<div class="split-section {{ instance.get_extra_classes }}" id="{{ instance.html_id }}">
|
<div class="split-section {{ instance.get_extra_classes }}" id="{{ instance.html_id }}">
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-sm-6 {% if instance.text_direction == 'left' %}col-sm-push-6{% endif %}">
|
<div class="col-sm-6 {% if instance.text_direction == 'left' %}col-sm-push-6{% endif %} split-figure">
|
||||||
{% block section-feature %}
|
|
||||||
<div class="section-figure">
|
<div class="section-figure">
|
||||||
{% for plugin in instance.child_plugin_instances %}
|
{% for plugin in instance.child_plugin_instances %}
|
||||||
{% render_plugin plugin %}
|
{% render_plugin plugin %}
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</div>
|
</div>
|
||||||
{% endblock section-feature %}
|
|
||||||
</div>
|
</div>
|
||||||
<div class="col-sm-6 {% if instance.text_direction == 'left' %}col-sm-pull-6{% endif %}">
|
<div class="col-sm-6 {% if instance.text_direction == 'left' %}col-sm-pull-6{% endif %} split-text">
|
||||||
<div class="split-text">
|
|
||||||
<div class="{% if not instance.plain_heading %}split-title{% endif %}">
|
<div class="{% if not instance.plain_heading %}split-title{% endif %}">
|
||||||
<h2>{{ instance.heading }}</h2>
|
<h2>{{ instance.heading }}</h2>
|
||||||
</div>
|
</div>
|
||||||
|
@ -26,4 +23,3 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
|
|
@ -1,5 +1,5 @@
|
||||||
{% load staticfiles i18n%}
|
{% load staticfiles i18n%}
|
||||||
<form id="order_form" method="POST" action="" data-toggle="validator" role="form">
|
<form id="order_form" method="POST" action="{% url 'datacenterlight:index' %}" data-toggle="validator" role="form">
|
||||||
{% csrf_token %}
|
{% csrf_token %}
|
||||||
<div class="title">
|
<div class="title">
|
||||||
<h3>{% trans "VM hosting" %} </h3>
|
<h3>{% trans "VM hosting" %} </h3>
|
||||||
|
|
|
@ -112,37 +112,41 @@ class IndexView(CreateView):
|
||||||
storage_field = forms.IntegerField(validators=[self.validate_storage])
|
storage_field = forms.IntegerField(validators=[self.validate_storage])
|
||||||
template_id = int(request.POST.get('config'))
|
template_id = int(request.POST.get('config'))
|
||||||
template = VMTemplate.objects.filter(
|
template = VMTemplate.objects.filter(
|
||||||
opennebula_vm_template_id=template_id).first()
|
opennebula_vm_template_id=template_id
|
||||||
|
).first()
|
||||||
template_data = VMTemplateSerializer(template).data
|
template_data = VMTemplateSerializer(template).data
|
||||||
|
referer_url = request.META['HTTP_REFERER']
|
||||||
|
|
||||||
try:
|
try:
|
||||||
cores = cores_field.clean(cores)
|
cores = cores_field.clean(cores)
|
||||||
except ValidationError as err:
|
except ValidationError as err:
|
||||||
msg = '{} : {}.'.format(cores, str(err))
|
msg = '{} : {}.'.format(cores, str(err))
|
||||||
messages.add_message(self.request, messages.ERROR, msg,
|
messages.add_message(
|
||||||
extra_tags='cores')
|
self.request, messages.ERROR, msg, extra_tags='cores'
|
||||||
return HttpResponseRedirect(
|
)
|
||||||
reverse('datacenterlight:index') + "#order_form")
|
return HttpResponseRedirect(referer_url + "#order_form")
|
||||||
|
|
||||||
try:
|
try:
|
||||||
memory = memory_field.clean(memory)
|
memory = memory_field.clean(memory)
|
||||||
except ValidationError as err:
|
except ValidationError as err:
|
||||||
msg = '{} : {}.'.format(memory, str(err))
|
msg = '{} : {}.'.format(memory, str(err))
|
||||||
messages.add_message(self.request, messages.ERROR, msg,
|
messages.add_message(
|
||||||
extra_tags='memory')
|
self.request, messages.ERROR, msg, extra_tags='memory'
|
||||||
return HttpResponseRedirect(
|
)
|
||||||
reverse('datacenterlight:index') + "#order_form")
|
return HttpResponseRedirect(referer_url + "#order_form")
|
||||||
|
|
||||||
try:
|
try:
|
||||||
storage = storage_field.clean(storage)
|
storage = storage_field.clean(storage)
|
||||||
except ValidationError as err:
|
except ValidationError as err:
|
||||||
msg = '{} : {}.'.format(storage, str(err))
|
msg = '{} : {}.'.format(storage, str(err))
|
||||||
messages.add_message(self.request, messages.ERROR, msg,
|
messages.add_message(
|
||||||
extra_tags='storage')
|
self.request, messages.ERROR, msg, extra_tags='storage'
|
||||||
return HttpResponseRedirect(
|
)
|
||||||
reverse('datacenterlight:index') + "#order_form")
|
return HttpResponseRedirect(referer_url + "#order_form")
|
||||||
amount_to_be_charged = get_vm_price(cpu=cores, memory=memory,
|
|
||||||
disk_size=storage)
|
amount_to_be_charged = get_vm_price(
|
||||||
|
cpu=cores, memory=memory, disk_size=storage
|
||||||
|
)
|
||||||
specs = {
|
specs = {
|
||||||
'cpu': cores,
|
'cpu': cores,
|
||||||
'memory': memory,
|
'memory': memory,
|
||||||
|
@ -161,8 +165,9 @@ class IndexView(CreateView):
|
||||||
def get_context_data(self, **kwargs):
|
def get_context_data(self, **kwargs):
|
||||||
context = super(IndexView, self).get_context_data(**kwargs)
|
context = super(IndexView, self).get_context_data(**kwargs)
|
||||||
context.update({
|
context.update({
|
||||||
'base_url': "{0}://{1}".format(self.request.scheme,
|
'base_url': "{0}://{1}".format(
|
||||||
self.request.get_host()),
|
self.request.scheme, self.request.get_host()
|
||||||
|
),
|
||||||
'contact_form': ContactForm
|
'contact_form': ContactForm
|
||||||
})
|
})
|
||||||
return context
|
return context
|
||||||
|
@ -231,8 +236,9 @@ class PaymentOrderView(FormView):
|
||||||
|
|
||||||
def post(self, request, *args, **kwargs):
|
def post(self, request, *args, **kwargs):
|
||||||
if 'login_form' in request.POST:
|
if 'login_form' in request.POST:
|
||||||
login_form = HostingUserLoginForm(data=request.POST,
|
login_form = HostingUserLoginForm(
|
||||||
prefix='login_form')
|
data=request.POST, prefix='login_form'
|
||||||
|
)
|
||||||
if login_form.is_valid():
|
if login_form.is_valid():
|
||||||
email = login_form.cleaned_data.get('email')
|
email = login_form.cleaned_data.get('email')
|
||||||
password = login_form.cleaned_data.get('password')
|
password = login_form.cleaned_data.get('password')
|
||||||
|
|
Loading…
Reference in a new issue