flask adminlte
1.0.0
Шаблон Bootstrap AdminLTE, адаптированный к платформе flask с использованием flask-admin 1.5.2 и flask-security 3.0.0.
Это помогает разработать красивую и простую в использовании панель администратора для бэкэнда, написанного на flask.
http://adminlte.najdaapps.com/admin/
логин: [email protected]
пароль: admin
Скопируйте каталоги adminlte
, static
и templates
в свой проект.
from flask import Flask , url_for
from flask_security import Security
from flask_admin import helpers as admin_helpers
from adminlte . admin import AdminLte , admins_store
app = Flask ( __name__ )
security = Security ( app , admins_store )
admin = AdminLte ( app , skin = 'green' , name = 'FlaskCMS' , short_name = "<b>F</b>C" , long_name = "<b>Flask</b>CMS" )
@ security . context_processor
def security_context_processor ():
return dict (
admin_base_template = admin . base_template ,
admin_view = admin . index_view ,
h = admin_helpers ,
get_url = url_for
)
class DeviceView ( BaseAdminView ):
column_editable_list = [ 'name' , 'type' , 'rooted' ]
column_searchable_list = [ 'name' , 'type' , 'rooted' ]
column_exclude_list = None
column_details_exclude_list = None
column_filters = [ 'name' , 'type' , 'rooted' ]
can_export = True
can_view_details = False
can_create = True
can_edit = True
can_delete = True
edit_modal = True
create_modal = True
details_modal = False
admin . add_view ( DeviceView ( Device , db . session , name = "Devices" , menu_icon_value = 'fa-laptop' ))
admin . add_link ( FaLink ( name = 'Website' , url = 'http://tomasznajda.com' , icon_value = 'fa-globe' , target = "_blank" ))
admin . add_view ( DeviceView ( Device , db . session , name = "Devices" , category = 'Author' , menu_icon_value = 'fa-laptop' ))
admin . add_link ( FaLink ( name = 'Website' , category = 'Author' , url = 'http://tomasznajda.com' , icon_value = 'fa-globe' , target = "_blank" ))
admin . set_category_icon ( name = 'Author' , icon_type = 'fa' , icon_value = 'fa-address-card' )
app
-> объект приложения Flaskname
-> Например. FlaskCMS
. Имя приложения. Будет отображаться как заголовок страницы. По умолчанию «Администратор»short_name
-> Например. <b>F</b>C
. Краткое имя приложения. Будет отображаться в свернутой строке меню. По умолчанию будет использоваться значение свойства name.long_name
-> Например. <b>Flask</b>CMS
. Длинное имя приложения. Будет отображаться в расширенной строке меню и над каждой формой безопасности. По умолчанию будет использоваться значение свойства name.skin
-> Цвет кожи AdminLTE ( blue
, black
, puprle
, green
, red
, yellow
, blue-light
, black-light
, purple-light
, green-light
, red-light
, yellow-light
). По умолчанию будет использоваться blue
.url
-> Базовый URLsubdomain
-> Субдомен для использованияindex_view
-> Вид домашней страницы, который нужно использовать. По умолчанию используется AdminIndexView
.translations_path
-> Расположение каталогов сообщений перевода. По умолчанию будут использоваться переводы, поставляемые с Flask-Admin.endpoint
-> имя базовой конечной точки для индексного представления. Если вы используете несколько экземпляров класса Admin
с одним приложением Flask, вам необходимо установить уникальное имя конечной точки для каждого экземпляра.static_url_path
-> Статический URL-путь. Если указано, это указывает путь по умолчанию к каталогу статических URL-адресов для всех его представлений. Может быть переопределено в конфигурации представления.base_template
-> Переопределить базовый HTML-шаблон для всех статических представлений. По умолчанию — admin/base.html
. column_editable_list = [ 'from_user' , 'to_user' , 'subject' , 'content' , 'created_at' ]
column_searchable_list = [ 'from_user.first_name' , 'from_user.last_name' , 'from_user.email' , 'to_user.first_name' ,
'to_user.last_name' , 'to_user.email' , 'subject' , 'content' , 'created_at' ]
column_exclude_list = [ 'created_at' ]
column_details_exclude_list = [ 'created_at' ]
column_filters = [ 'subject' , 'content' , 'created_at' ]
can_export = True
can_view_details = True
can_create = True
can_edit = True
can_delete = True
edit_modal = True
create_modal = True
details_modal = True
SECURITY_REGISTERABLE = True
SECURITY_RECOVERABLE = True
SECURITY_CHANGEABLE = True