remotes/origin/setup
Mukhtar 10 years ago
commit 9a872ea173
  1. 6
      assets/css/main.css
  2. 16
      projects/forms.py
  3. 6
      projects/templates/project_detail.html
  4. 7
      projects/urls.py
  5. 79
      projects/views.py

@ -35,9 +35,9 @@ body, html {
position: relative;
}
input[type=checkbox], input[type=radio] {
opacity: 0;
}
/*input[type=checkbox], input[type=radio] {
opacity: 0; / * Блядь, какого ХУЯ????? * /
}*/
a, a:hover, a:focus, a:active {
text-decoration: none !important;

@ -194,14 +194,18 @@ class ContractorProjectAnswerForm(forms.ModelForm):
'text',
'secure_deal_only',
# 'portfolios',
# 'files',
'portfolios',
# 'files', # Doesn't work for some fucked up reason
)
# widgets = {
# 'currency': forms.Select(attrs={'class': 'selectpicker'}),
# 'term_type': forms.Select(attrs={'class': 'selectpicker'}),
# }
widgets = {
'currency': forms.Select(attrs={'class': 'selectpicker'}),
'term_type': forms.Select(attrs={'class': 'selectpicker'}),
}
def __init__(self, *args, **kwargs):
self.request = kwargs.pop('request')
super().__init__(*args, **kwargs)
class StageForm(forms.ModelForm):

@ -164,7 +164,7 @@
{% if request.user.is_contractor and True %}
<form action="{% url 'projects:contractor-project-answer' pk=project.pk %}" method="POST" novalidate>
<form action="{% url 'projects:detail' pk=project.pk %}" method="POST" novalidate>
{% csrf_token %}
<input type="hidden" name="next" value="{% url 'projects:detail' pk=project.pk %}">
@ -212,7 +212,7 @@
<ul>
{% for p in request.user.portfolios.all %}
<li><input type="checkbox" style="opacity: 1"> {{ p.name }}</li>
<li><input type="checkbox" name="{{ form.portfolios.html_name }}" value="{{ p.pk }}"> {{ p.name }}</li>
{% endfor %}
</ul>
</div>
@ -226,7 +226,7 @@
<div class="a polsF1 disTab searchF1">
<div class="col-lg-9">
<input type="checkbox" style="opacity: 1"> Работаю только по безопасной сделке
{{ form.secure_deal_only }} Работаю только по безопасной сделке
</div>
</div>

@ -5,7 +5,6 @@ from .views import (
add_candidate,
contractor_portfolio_create,
ContractorPortfolioUpdateView,
ContractorProjectAnswerView,
CustomerProjectCreateView,
CustomerProjectDeleteView,
CustomerProjectEditView,
@ -14,14 +13,14 @@ from .views import (
OfferOrderView,
ProjectComparisonView,
ProjectFilterView,
ProjectView,
ProjectDetailWithContractorAnswerView,
)
app_name = 'projects'
urlpatterns = [
urls.url(r'^$', ProjectFilterView.as_view(), name='project-filter'),
urls.url(r'^(?P<pk>\d+)/$', ProjectView.as_view(), name='detail'),
urls.url(r'^(?P<pk>\d+)/$', ProjectDetailWithContractorAnswerView.as_view(), name='detail'),
urls.url(r'^create/$', CustomerProjectCreateView.as_view(), name='customer-project-create'),
urls.url(r'^(?P<pk>\d+)/edit/$', CustomerProjectEditView.as_view(), name='customer-project-edit'),
@ -29,8 +28,6 @@ urlpatterns = [
urls.url(r'^(?P<pk>\d+)/restore/$', CustomerProjectRestoreView.as_view(), name='customer-project-restore'),
urls.url(r'^(?P<pk>\d+)/delete/$', CustomerProjectDeleteView.as_view(), name='customer-project-delete'),
urls.url(r'^(?P<pk>\d+)/answer/$', ContractorProjectAnswerView.as_view(), name='contractor-project-answer'),
urls.url(r'^portfolio/create/$', contractor_portfolio_create, name='contractor-portfolio-create'),
urls.url(r'^portfolio/(?P<pk>\d+)/edit/$', ContractorPortfolioUpdateView.as_view(), name='contractor-portfolio-edit'),

@ -35,10 +35,10 @@ from .forms import (
)
class ProjectView(BaseMixin, View):
template_name = 'project_detail.html'
class ProjectDetailWithContractorAnswerView(BaseMixin, View):
form_class = ContractorProjectAnswerForm
template_name = 'project_detail.html'
def get(self, request, *args, **kwargs):
context = self.get_context_data(**_.merge({}, request.GET, kwargs))
@ -50,11 +50,39 @@ class ProjectView(BaseMixin, View):
# import code; code.interact(local=dict(globals(), **locals()))
if request.user.is_authenticated() and request.user.is_contractor():
form = self.form_class()
form = self.form_class(request=request)
context.update({'form': form})
return render(request, self.template_name, context)
def post(self, request, *args, **kwargs):
if request.user.is_authenticated() and request.user.is_contractor():
context = self.get_context_data(**kwargs)
form = self.form_class(request.POST, request=request)
project = get_object_or_404(Project, pk=kwargs.get('pk'))
context.update({'project': project})
if form.is_valid():
print('###############################################')
pprint(form.cleaned_data)
print('###############################################')
messages.info(request, 'Форма ОК')
redirect_to = request.POST.get('next')
return redirect(redirect_to)
else:
if form.errors:
messages.info(request, (
'<p>Произошла ошибка (form)</p>'
'<pre>{form}</pre>'
).format(form=pformat(form.errors)))
context.update({'form': form})
return render(request, self.template_name, context)
else:
return HttpResponseForbidden('403 Forbidden')
class ProjectFilterView(BaseMixin, View):
template_name = 'project_filter.html'
@ -325,49 +353,6 @@ class CustomerProjectEditView(BaseMixin, View):
return render(request, self.template_name, context)
class ContractorProjectAnswerView(BaseMixin, View):
form_class = ContractorProjectAnswerForm
def dispatch(self, request, *args, **kwargs):
if request.user.is_authenticated() and request.user.is_contractor():
return super().dispatch(request, *args, **kwargs)
else:
return HttpResponseForbidden('403 Forbidden')
def post(self, req, *args, **kwargs):
form = self.form_class(_.merge({}, req.POST, kwargs), req=req)
if form.is_valid():
project = form.cleaned_data.get('pk')
project.state = 'trashed'
project.save()
messages.info(req, 'OK')
else:
messages.info(req, 'Произошла ошибка: <pre>{msg}</pre>'.format(msg=pformat(form.errors)))
redirect_to = req.POST.get('next')
return redirect(redirect_to)
# def post(self, request, *args, **kwargs):
# form = self.form_class(request.POST)
# project = get_object_or_404(Project, pk=kwargs.get('pk'))
# if form.is_valid():
# answer = form.save(commit=False)
# answer.contractor = request.user
# answer.project = project
# answer.save()
# return HttpResponseRedirect(reverse('projects:detail', kwargs={'pk': project.pk}))
# return render(request, self.template_name, {'project': project, 'form': self.form_class})
class PortfolioTrashView(View):
pass
class CustomerProjectTrashView(View):
form_class = CustomerProjectTrashForm

Loading…
Cancel
Save