Progress
This commit is contained in:
		
							parent
							
								
									d10768403d
								
							
						
					
					
						commit
						6948220746
					
				
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							@ -1,3 +1,4 @@
 | 
			
		||||
.r_history
 | 
			
		||||
.vscode
 | 
			
		||||
.history
 | 
			
		||||
.resources
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										14
									
								
								src/snek/form/settings/profile.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								src/snek/form/settings/profile.py
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,14 @@
 | 
			
		||||
from snek.system.form import Form, FormInputElement, FormButtonElement, HTMLElement
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class SettingsProfileForm(Form):
 | 
			
		||||
 | 
			
		||||
    nick = FormInputElement(name="nick", required=True, place_holder="Your Nickname", min_length=1, max_length=20)
 | 
			
		||||
    action = FormButtonElement(
 | 
			
		||||
        name="action", value="submit", text="Save", type="button"
 | 
			
		||||
    )
 | 
			
		||||
    title = HTMLElement(tag="h1", text="Profile")
 | 
			
		||||
    profile = FormInputElement(name="profile", place_holder="Tell about yourself.", required=False,max_length=300)
 | 
			
		||||
    action = FormButtonElement(
 | 
			
		||||
        name="action", value="submit", text="Save", type="button"
 | 
			
		||||
    )
 | 
			
		||||
							
								
								
									
										7
									
								
								src/snek/mapper/user_property.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								src/snek/mapper/user_property.py
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,7 @@
 | 
			
		||||
from snek.model.user_property import UserPropertyModel
 | 
			
		||||
from snek.system.mapper import BaseMapper
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class UserPropertyMapper(BaseMapper):
 | 
			
		||||
    table_name = "user_property"
 | 
			
		||||
    model_class = UserPropertyModel
 | 
			
		||||
							
								
								
									
										10
									
								
								src/snek/model/user_property.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								src/snek/model/user_property.py
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,10 @@
 | 
			
		||||
import mimetypes
 | 
			
		||||
 | 
			
		||||
from snek.system.model import BaseModel, ModelField
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class UserPropertyModel(BaseModel):
 | 
			
		||||
    user_uid = ModelField(name="user_uid", required=True, kind=str)
 | 
			
		||||
    name = ModelField(name="name", required=True, kind=str)
 | 
			
		||||
    value = ModelField(name="path", required=True, kind=str)
 | 
			
		||||
    
 | 
			
		||||
							
								
								
									
										13
									
								
								src/snek/templates/app_menu.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								src/snek/templates/app_menu.html
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,13 @@
 | 
			
		||||
  <div>
 | 
			
		||||
    <div class="logo no-select">Test</div>
 | 
			
		||||
    <nav class="no-select" style="float:right;overflow:hidden;scroll-behavior:smooth">
 | 
			
		||||
      <a class="no-select" href="/web.html">🏠</a>
 | 
			
		||||
      <a class="no-select" href="/search-user.html">🔍</a>
 | 
			
		||||
      <a class="no-select" style="display:none" id="install-button" href="#">📥</a>
 | 
			
		||||
      <a class="no-select" href="/threads.html">👥</a>
 | 
			
		||||
      <a class="no-select" href="#">⚙️</a>
 | 
			
		||||
      <a class="no-select" href="/logout.html">🔒</a>
 | 
			
		||||
    </nav>
 | 
			
		||||
 | 
			
		||||
  </div>
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										37
									
								
								src/snek/templates/settings/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								src/snek/templates/settings/index.html
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,37 @@
 | 
			
		||||
{% extends "app.html" %}
 | 
			
		||||
 | 
			
		||||
{% block sidebar %}
 | 
			
		||||
 | 
			
		||||
{% include "settings/sidebar.html" %}
 | 
			
		||||
 | 
			
		||||
{% endblock %}
 | 
			
		||||
 | 
			
		||||
{% block header_text %}<h2 style="color:#fff">Settings</h2>{% endblock %}
 | 
			
		||||
 | 
			
		||||
{% block head %}
 | 
			
		||||
   <link href="https://cdn.bootcdn.net/ajax/libs/monaco-editor/0.20.0/min/vs/editor/editor.main.min.css" rel="stylesheet">
 | 
			
		||||
 | 
			
		||||
    <script src="https://cdn.bootcdn.net/ajax/libs/monaco-editor/0.20.0/min/vs/loader.min.js"></script>
 | 
			
		||||
 | 
			
		||||
{% endblock %}
 | 
			
		||||
 | 
			
		||||
{% block main %}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
<div id="profile_description"></div>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
<script type="module">
 | 
			
		||||
 | 
			
		||||
        require.config({ paths: { 'vs': 'https://cdn.bootcdn.net/ajax/libs/monaco-editor/0.20.0/min/vs' } });
 | 
			
		||||
 | 
			
		||||
        require(['vs/editor/editor.main'], function () {
 | 
			
		||||
var editor = monaco.editor.create(document.getElementById('profile_description'), {
 | 
			
		||||
                value: phpCode,
 | 
			
		||||
                language: 'php'
 | 
			
		||||
            });
 | 
			
		||||
        })
 | 
			
		||||
</script>
 | 
			
		||||
 | 
			
		||||
{% endblock main %}
 | 
			
		||||
							
								
								
									
										31
									
								
								src/snek/templates/settings/profile.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								src/snek/templates/settings/profile.html
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,31 @@
 | 
			
		||||
{% extends "settings/index.html" %}
 | 
			
		||||
 | 
			
		||||
{% block header_text %}<h2 style="color:#fff">Profile</h2>{% endblock %}
 | 
			
		||||
 | 
			
		||||
{% block main %}
 | 
			
		||||
<section>
 | 
			
		||||
<form>
 | 
			
		||||
    <h2>Nickname</h2>
 | 
			
		||||
    
 | 
			
		||||
<input type="text" name="nick" placeholder="Your nickname" value="{{ user.nick.value }}" />
 | 
			
		||||
 | 
			
		||||
</form>
 | 
			
		||||
<h2>Description</h2>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
<textarea id="profile"></textarea>
 | 
			
		||||
</section>
 | 
			
		||||
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/easymde/dist/easymde.min.css">
 | 
			
		||||
<script src="https://cdn.jsdelivr.net/npm/easymde/dist/easymde.min.js"></script>
 | 
			
		||||
<script>
 | 
			
		||||
    const easyMDE = new EasyMDE({element:document.getElementById("profile")});
 | 
			
		||||
    </script>
 | 
			
		||||
<style>
 | 
			
		||||
 | 
			
		||||
.EasyMDEContainer {
 | 
			
		||||
        filter: invert(1) !important;
 | 
			
		||||
     
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
    </style>
 | 
			
		||||
{% endblock %}
 | 
			
		||||
							
								
								
									
										9
									
								
								src/snek/templates/settings/sidebar.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								src/snek/templates/settings/sidebar.html
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,9 @@
 | 
			
		||||
 | 
			
		||||
<aside class="sidebar" id="channelSidebar">
 | 
			
		||||
    <h2>You</h2>
 | 
			
		||||
    <ul>
 | 
			
		||||
        <li><a class="no-select" href="/settings/profile.html">Profile</a></li>
 | 
			
		||||
        <li><a class="no-select" href="/settings/gists.html">Gists</a></li>
 | 
			
		||||
    </ul>
 | 
			
		||||
 | 
			
		||||
  </aside>
 | 
			
		||||
							
								
								
									
										8
									
								
								src/snek/view/settings/index.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								src/snek/view/settings/index.py
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,8 @@
 | 
			
		||||
from snek.system.view import BaseView 
 | 
			
		||||
 | 
			
		||||
class SettingsIndexView(BaseView):
 | 
			
		||||
    
 | 
			
		||||
    login_required = True
 | 
			
		||||
 | 
			
		||||
    async def get(self):
 | 
			
		||||
        return await self.render_template('settings/index.html')
 | 
			
		||||
							
								
								
									
										36
									
								
								src/snek/view/settings/profile.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								src/snek/view/settings/profile.py
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,36 @@
 | 
			
		||||
from snek.system.view import BaseView,BaseFormView
 | 
			
		||||
 | 
			
		||||
from snek.form.settings.profile import SettingsProfileForm
 | 
			
		||||
from aiohttp import web
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class SettingsProfileView(BaseFormView):
 | 
			
		||||
    form = SettingsProfileForm
 | 
			
		||||
 | 
			
		||||
    login_required = True
 | 
			
		||||
 | 
			
		||||
    async def get(self):
 | 
			
		||||
        form = self.form(app=self.app)
 | 
			
		||||
            
 | 
			
		||||
        if self.request.path.endswith(".json"):
 | 
			
		||||
            form['nick'] = self.request['user']['nick']
 | 
			
		||||
            return web.json_response(await form.to_json()) 
 | 
			
		||||
        
 | 
			
		||||
        user = await self.services.user.get(uid=self.session.get("uid"))
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        return await self.render_template(
 | 
			
		||||
            "settings/profile.html", {"form": await form.to_json(), "user": user}
 | 
			
		||||
        )
 | 
			
		||||
 | 
			
		||||
    async def submit(self, form):
 | 
			
		||||
        post = await self.request.json()
 | 
			
		||||
        form.set_user_data(post["form"])
 | 
			
		||||
 | 
			
		||||
        if await form.is_valid:
 | 
			
		||||
            user = self.request['user']
 | 
			
		||||
            user["nick"] = form["nick"]
 | 
			
		||||
            await self.services.user.save(user)
 | 
			
		||||
            return {"redirect_url": "/settings/profile.html"}
 | 
			
		||||
        return {"is_valid": False}
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user