diff options
Diffstat (limited to 'core/views/expo.py')
-rw-r--r-- | core/views/expo.py | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/core/views/expo.py b/core/views/expo.py index 7b0d283..2a4c1c7 100644 --- a/core/views/expo.py +++ b/core/views/expo.py @@ -21,7 +21,7 @@ from troggle.core.models.caves import Cave import troggle.core.views.caves import troggle.settings as settings -from troggle.lib import version_control +from troggle.core.utils import write_and_commit, WriteAndCommitError from troggle.core.views.editor_helpers import HTMLarea @@ -339,8 +339,8 @@ def editexpopage(request, path): if request.method == 'POST': # If the form has been submitted... pageform = ExpoPageForm(request.POST) # A form bound to the POST data if pageform.is_valid():# Form valid therefore write file - print("### \n", str(pageform)[0:300]) - print("### \n csrfmiddlewaretoken: ",request.POST['csrfmiddlewaretoken']) + #print("### \n", str(pageform)[0:300]) + #print("### \n csrfmiddlewaretoken: ",request.POST['csrfmiddlewaretoken']) if filefound: headmatch = re.match(r"(.*)<title>.*</title>(.*)", head, re.DOTALL + re.IGNORECASE) if headmatch: @@ -358,12 +358,13 @@ def editexpopage(request, path): body = body.replace("\r", "") result = "%s<head%s>%s</head>%s<body%s>\n%s</body>%s" % (preheader, headerargs, head, postheader, bodyargs, body, postbody) - if result != html: # Check if content changed + if result != html: # Check if content changed at all try: change_message = pageform.cleaned_data["change_message"] - version_control.write_and_commit([(filepath, result, "utf-8")], f'{change_message} - online edit of {path}') - except version_control.WriteAndCommitError as e: + write_and_commit([(filepath, result, "utf-8")], f'{change_message} - online edit of {path}') + except WriteAndCommitError as e: return render(request,'errors/generic.html', {'message': e.message}) + return HttpResponseRedirect(reverse('expopage', args=[path])) # Redirect after POST else: @@ -385,4 +386,4 @@ class ExpoPageForm(forms.Form): html = forms.CharField(widget=HTMLarea(attrs={"height":"80%", "rows":20, 'placeholder': "Enter page content (using HTML)"}, preview = True )) - change_message = forms.CharField(widget=forms.Textarea(attrs={"cols":80, "rows":3, 'placeholder': "Descibe the change made (for git)"})) + change_message = forms.CharField(widget=forms.Textarea(attrs={"cols":80, "rows":3, 'placeholder': "Describe the change made (for version control records)"})) |