remotes/origin/setup
ArturBaybulatov 10 years ago
parent 7ff07860db
commit 3a5ba497f3
  1. 6
      assets/css/main.css
  2. 16
      projects/forms.py
  3. 6
      projects/templates/project_detail.html
  4. 7
      projects/urls.py
  5. 73
      projects/views.py

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

@ -194,14 +194,18 @@ class ContractorProjectAnswerForm(forms.ModelForm):
'text', 'text',
'secure_deal_only', 'secure_deal_only',
# 'portfolios', 'portfolios',
# 'files', # 'files', # Doesn't work for some fucked up reason
) )
# widgets = { widgets = {
# 'currency': forms.Select(attrs={'class': 'selectpicker'}), 'currency': forms.Select(attrs={'class': 'selectpicker'}),
# 'term_type': 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): class StageForm(forms.ModelForm):

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

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

@ -32,9 +32,9 @@ from .forms import (
) )
class ProjectView(BaseMixin, View): class ProjectDetailWithContractorAnswerView(BaseMixin, View):
template_name = 'project_detail.html'
form_class = ContractorProjectAnswerForm form_class = ContractorProjectAnswerForm
template_name = 'project_detail.html'
def get(self, request, *args, **kwargs): def get(self, request, *args, **kwargs):
context = self.get_context_data(**_.merge({}, request.GET, kwargs)) context = self.get_context_data(**_.merge({}, request.GET, kwargs))
@ -47,11 +47,39 @@ class ProjectView(BaseMixin, View):
# import code; code.interact(local=dict(globals(), **locals())) # import code; code.interact(local=dict(globals(), **locals()))
if request.user.is_authenticated() and request.user.is_contractor(): if request.user.is_authenticated() and request.user.is_contractor():
form = self.form_class() form = self.form_class(request=request)
context.update({'form': form}) context.update({'form': form})
return render(request, self.template_name, context) 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): class ProjectFilterView(BaseMixin, View):
template_name = 'project_filter.html' template_name = 'project_filter.html'
@ -322,45 +350,6 @@ class CustomerProjectEditView(BaseMixin, View):
return render(request, self.template_name, context) 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 CustomerProjectTrashView(View): class CustomerProjectTrashView(View):
form_class = CustomerProjectTrashForm form_class = CustomerProjectTrashForm

Loading…
Cancel
Save