new navbar manager from file tyto.navbar. Form: question to use sidebar
This commit is contained in:
parent
aef44c86ef
commit
2db9fa9af8
6 changed files with 179 additions and 83 deletions
|
@ -26,7 +26,7 @@
|
|||
import sys
|
||||
sys.path.insert(0, '/var/lib/tyto/program')
|
||||
|
||||
import check, domain, wip, sidebar
|
||||
import check, domain, wip, navbars
|
||||
|
||||
#====================#
|
||||
# MAIN #
|
||||
|
@ -42,11 +42,12 @@ option = ''
|
|||
|
||||
# Command start argument
|
||||
actions = {
|
||||
'check' : check.manage_check,
|
||||
'wip' : wip.manage_wip,
|
||||
'domain' : domain.manage_domain,
|
||||
'sidebar' : sidebar.manage_sidebar
|
||||
}
|
||||
'check' : check.manage_check,
|
||||
'wip' : wip.manage_wip,
|
||||
'domain' : domain.manage_domain,
|
||||
'sidebar' : navbars.manage_navbars,
|
||||
'navbar' : navbars.manage_navbars
|
||||
}
|
||||
|
||||
# Dict for Options
|
||||
options = {
|
||||
|
|
|
@ -22,6 +22,7 @@ import sys, os, re, datetime
|
|||
from datetime import datetime
|
||||
from time import gmtime, strftime
|
||||
import time
|
||||
|
||||
import tyto
|
||||
|
||||
# Load domain configuration if exists
|
||||
|
|
|
@ -18,6 +18,7 @@
|
|||
#**********************************************************************
|
||||
|
||||
import os, locale
|
||||
|
||||
import tyto
|
||||
|
||||
#==========================#
|
||||
|
@ -106,12 +107,16 @@ def create_domain(target, option):
|
|||
|
||||
|
||||
db_dir = '%s/.local/tyto/%s/'%(tyto.home_dir, domain_short)
|
||||
navbars_conf= '%sarticles/navbars/'%tyto.conf_dir
|
||||
conf_domain = 'domain_dir = "%s"\n'%tyto.conf_dir + \
|
||||
'domain_conf = "%s"\n'%tyto.domain_conf + \
|
||||
'domain_articles = "%sarticles/"\n'%tyto.conf_dir + \
|
||||
'domain_files = "%sarticles/files/"\n'%tyto.conf_dir + \
|
||||
'domain_images = "%sarticles/images/"\n'%tyto.conf_dir + \
|
||||
'domain_db = "%sarticles/"\n'%(db_dir) + \
|
||||
'navbars_dir = "%s"\n'%navbars_conf + \
|
||||
'navbar_load = "%styto.navbar"\n'%navbars_conf + \
|
||||
'sidebar_load = "%styto.sidebar"\n'%navbars_conf + \
|
||||
'\ndomain_short = "%s"\n'%domain_short + \
|
||||
'domain_url = "%s"\n'%domain_url + \
|
||||
'domain_wipurl = "%s"\n'%domain_wipurl
|
||||
|
@ -284,53 +289,72 @@ def create_domain(target, option):
|
|||
'domain_relme = "%s"'%domain_relme)
|
||||
|
||||
|
||||
# Activate menu bar from root articles folders ?
|
||||
#-----------------------------------------------
|
||||
# Activate menu bar from tyto.navbar ?
|
||||
#-------------------------------------
|
||||
try: domain_menubar = tyto.domain_menubar
|
||||
except: domain_menubar = 'False'
|
||||
|
||||
ask = ''
|
||||
ask = input(' ├ Use sub-folders as menu bar ? (%s) '%domain_menubar)
|
||||
ask = input(' ├ Create menu bar from tyto.navbar file ? (%s) '%(
|
||||
domain_menubar
|
||||
)
|
||||
)
|
||||
|
||||
if ask in ['y', 'Y']: domain_menubar = "True"
|
||||
else: domain_menubar = 'False'
|
||||
if ask in ['y', 'Y']: domain_menubar = 'True'
|
||||
else: domain_menubar = domain_menubar
|
||||
|
||||
tyto.set_file(tyto.domain_conf, False,
|
||||
'domain_menubar = %s'%(domain_menubar))
|
||||
|
||||
|
||||
# Activate side bar from tyto.sidebar ?
|
||||
#--------------------------------------
|
||||
try: domain_sidebar = tyto.domain_sidebar
|
||||
except: domain_sidebar = 'False'
|
||||
|
||||
ask = ''
|
||||
ask = input(' ├ Create article\'s list from tyto.sidebar file ? (%s) '%(
|
||||
domain_sidebar
|
||||
)
|
||||
)
|
||||
|
||||
if ask in ['y', 'Y']: domain_sidebar = 'True'
|
||||
else: domain_sidebar = domain_sidebar
|
||||
|
||||
tyto.set_file(tyto.domain_conf, False,
|
||||
'domain_sidebar = %s'%(domain_sidebar))
|
||||
|
||||
|
||||
# Sidebar Title
|
||||
#--------------
|
||||
try: sidebar_title = tyto.sidebar_title
|
||||
except: sidebar_title = tyto.trans[0][tyto.n]
|
||||
|
||||
ask = ''
|
||||
ask = input(' ├ Sidebar title ? ("%s") '%sidebar_title)
|
||||
if ask: sidebar_title = ask
|
||||
if '"' in sidebar_title:
|
||||
sidebar_title = sidebar_title.replace('"', '')
|
||||
|
||||
sidebar_conf = '%sarticles/sidebar/'%tyto.conf_dir
|
||||
sidebar_datas = '\nsidebar_dir = "%s"\n'%sidebar_conf + \
|
||||
'sidebar_load = "%styto.sidebar"\n'%sidebar_conf + \
|
||||
'sidebar_title = "%s"'%sidebar_title
|
||||
|
||||
tyto.set_file(tyto.domain_conf, False, sidebar_datas)
|
||||
|
||||
if domain_sidebar:
|
||||
ask = ''
|
||||
ask = input(' ├ Sidebar title ? ("%s") '%sidebar_title)
|
||||
if ask: sidebar_title = ask
|
||||
if '"' in sidebar_title:
|
||||
sidebar_title = sidebar_title.replace('"', '')
|
||||
|
||||
tyto.set_file(tyto.domain_conf, False,
|
||||
'sidebar_title = "%s"'%(sidebar_title))
|
||||
|
||||
|
||||
# Sidebar Items
|
||||
#--------------
|
||||
try: sidebar_items = tyto.sidebar_items
|
||||
except: sidebar_items = "6"
|
||||
|
||||
ask = ''
|
||||
ask = input(' ├ [max=16] Sidebar Items ? ("%s") '%sidebar_items)
|
||||
if ask:
|
||||
if not ask.isdigit(): tyto.exiting("3", ask, True)
|
||||
elif int(ask) in range(1,17): sidebar_items = int(ask)
|
||||
if domain_sidebar:
|
||||
ask = ''
|
||||
ask = input(' ├ [max=16] Sidebar Items ? ("%s") '%sidebar_items)
|
||||
if ask:
|
||||
if not ask.isdigit(): tyto.exiting("3", ask, True)
|
||||
elif int(ask) in range(1,17): sidebar_items = int(ask)
|
||||
|
||||
tyto.set_file(tyto.domain_conf, False,
|
||||
'sidebar_items = "%s"'%int(sidebar_items))
|
||||
'sidebar_items = %s'%(sidebar_items))
|
||||
|
||||
|
||||
# Get srv root
|
||||
|
@ -391,7 +415,7 @@ def create_domain(target, option):
|
|||
folders = (
|
||||
srv_wip_tpl, srv_wip_images, srv_wip_files,
|
||||
srv_www_tpl, srv_www_images, srv_www_files,
|
||||
domain_files, domain_images, sidebar_dir,
|
||||
domain_files, domain_images, navbars_dir,
|
||||
domain_db,
|
||||
)
|
||||
|
||||
|
@ -404,7 +428,8 @@ def create_domain(target, option):
|
|||
|
||||
# Create tyto.sidebar and metas.html
|
||||
print(' │')
|
||||
create_sidebar(option, sidebar_dir)
|
||||
create_sidebar(option, navbars_dir)
|
||||
create_navbar(option, navbars_dir)
|
||||
create_metas_file(srv_wip_tpl)
|
||||
|
||||
print(' │')
|
||||
|
@ -463,16 +488,18 @@ def create_metas_file(srv_wip_tpl):
|
|||
#==============================#
|
||||
# sidebar load file translated #
|
||||
#------------------------------#
|
||||
def create_sidebar(opt, sidebar_dir):
|
||||
def create_sidebar(opt, navbars_dir):
|
||||
try: sidebar_load
|
||||
except: sidebar_load = "%styto.sidebar"%sidebar_dir
|
||||
except: sidebar_load = "%styto.sidebar"%navbars_dir
|
||||
|
||||
sdb_load_fr = '# Pour : Tyto - Littérateur\n' + \
|
||||
'# Type : fichier texte\n' + \
|
||||
'# Description : Fichier appelé par : tyto sidebar\n' + \
|
||||
'# Description : Fichier appelé par "tyto sidebar"\n' + \
|
||||
'# (Liste d\'articles)\n' + \
|
||||
'# Fichier : tyto.sidebar\n' + \
|
||||
'# Dossier : %s\n'%sidebar_dir + \
|
||||
'# Dossier : %s\n'%navbars_dir + \
|
||||
'# Comment : 1 URI de l\'article par ligne\n' + \
|
||||
'# (depuis articles/)\n' + \
|
||||
'# Ne commence pas par "/"\n' + \
|
||||
'# L\'ordre définit la position\n' + \
|
||||
'\n# %s\n'%(15 * "-") +\
|
||||
|
@ -483,10 +510,12 @@ def create_sidebar(opt, sidebar_dir):
|
|||
|
||||
sdb_load_en = '# For: Tyto - Littérateur\n' + \
|
||||
'# Type: Text file\n' + \
|
||||
'# Description: file called with: tyto sidebar\n' + \
|
||||
'# Description: file called with "tyto sidebar"\n' + \
|
||||
'# (articles\'s list)\n' + \
|
||||
'# File: tyto.sidebar\n' + \
|
||||
'# Directory: %s\n'%sidebar_dir + \
|
||||
'# Directory: %s\n'%navbars_dir + \
|
||||
'# Comment: 1 article URI per line\n' + \
|
||||
'# (from articles/)\n' + \
|
||||
'# not begining with "/"\n' + \
|
||||
'# Order in sidebar position\n' + \
|
||||
'\n# %s\n'%(15 * "-") +\
|
||||
|
@ -506,3 +535,63 @@ def create_sidebar(opt, sidebar_dir):
|
|||
|
||||
tyto.set_file(sidebar_load, 'new', sdb_load)
|
||||
print(' ├ Create file: %s'%sidebar_load)
|
||||
|
||||
|
||||
#=============================#
|
||||
# navbar load file translated #
|
||||
#-----------------------------#
|
||||
def create_navbar(opt, navbars_dir):
|
||||
try: navbar_load
|
||||
except: navbar_load = "%styto.navbar"%navbars_dir
|
||||
|
||||
nav_load_fr = '# Pour : Tyto - Littérateur\n' + \
|
||||
'# Type : fichier texte\n' + \
|
||||
'# Description : Fichier utilisé par "tyto wip"\n' + \
|
||||
'# (Liste des catégories)\n' + \
|
||||
'# Fichier : tyto.navbar\n' + \
|
||||
'# Dossier : %s\n'%navbars_dir + \
|
||||
'# Comment : 1 nom de dossier par ligne\n' + \
|
||||
'# (depuis articles/)\n' + \
|
||||
'# Ne commence pas par "/"\n' + \
|
||||
'# L\'ordre définit la position\n' + \
|
||||
'# Note: Pour éviter l\'erreur 404 :\n' + \
|
||||
'# - ajouter un article index.{ext}\n' + \
|
||||
'# dans le dossier mentionné\n' + \
|
||||
'# - utiliser check et wip dessus' + \
|
||||
'\n# %s\n'%(15 * "-") +\
|
||||
'# Exemples :\n' + \
|
||||
'# documentation\n' + \
|
||||
'# a-propos\n' + \
|
||||
'# %s\n\n'%(15 * "-")
|
||||
|
||||
nav_load_en = '# For: Tyto - Littérateur\n' + \
|
||||
'# Type: Text file\n' + \
|
||||
'# Description: file used with "tyto wip"\n' + \
|
||||
'# (categories\'s list)\n' + \
|
||||
'# File: tyto.navbar\n' + \
|
||||
'# Directory: %s\n'%navbars_dir + \
|
||||
'# Comment: 1 folder name per line\n' + \
|
||||
'# (from articles/)\n' + \
|
||||
'# not begining with "/"\n' + \
|
||||
'# Order in sidebar position\n' + \
|
||||
'# Remember: To avoid 404 error, you must:\n' + \
|
||||
'# - add index.{ext} file article\n' + \
|
||||
'# in set folder\n' + \
|
||||
'# - check and wip it' + \
|
||||
'\n# %s\n'%(15 * "-") +\
|
||||
'# Examples :\n' + \
|
||||
'# documentation\n' + \
|
||||
'# about\n' + \
|
||||
'# %s\n\n'%(15 * "-")
|
||||
|
||||
if tyto.n == 0: nav_load = nav_load_fr
|
||||
elif tyto.n == 1: nav_load = nav_load_en
|
||||
|
||||
if not opt == 'Remove' and os.path.exists(navbar_load):
|
||||
ask = ''
|
||||
ask = input(' ├ Initialize new navbar ? ')
|
||||
if not ask in ['y', 'Y']:
|
||||
return
|
||||
|
||||
tyto.set_file(navbar_load, 'new', nav_load)
|
||||
print(' ├ Create file: %s'%navbar_load)
|
||||
|
|
|
@ -17,6 +17,7 @@
|
|||
|
||||
#**********************************************************************
|
||||
import os
|
||||
|
||||
import tyto
|
||||
|
||||
# Load domain configuration DB
|
||||
|
@ -143,46 +144,39 @@ def create_main_page(target, article_bottom):
|
|||
#----------------------------
|
||||
# True in config
|
||||
if domain_menubar:
|
||||
# Filter these directories
|
||||
nodirs = ('files', 'images', 'sidebar')
|
||||
# Create folder links (from tyto.navbar) in navbar
|
||||
try:
|
||||
nav_file = open(navbar_load, 'r').read()
|
||||
nav_bar = True
|
||||
except:
|
||||
tyto.exiting("1", '(navbar) %s'%navbar_load, False)
|
||||
nav_bar = False
|
||||
|
||||
# Open HTML tags
|
||||
menu_html = '%s<nav id="site_menu">\n'%(6 * ' ') + \
|
||||
'%s<ul id="site_menu_items">'%(8 * ' ')
|
||||
articles_dirs = os.listdir(tyto.domain_articles)
|
||||
# Create folder links (d) in navbar
|
||||
for d in articles_dirs:
|
||||
d_uri = os.path.join(domain_articles, d)
|
||||
|
||||
# Check if d is a directory
|
||||
if not os.path.isdir(d_uri): continue
|
||||
# Filter unwanted
|
||||
|
||||
if d.startswith(nodirs): continue
|
||||
|
||||
# Must have index.* in d directory
|
||||
items_indir = os.listdir(d_uri)
|
||||
print(">>>", items_indir)
|
||||
index = True
|
||||
for item in items_indir:
|
||||
if item.startswith('index.'):
|
||||
|
||||
break
|
||||
else: index = False
|
||||
if not index: continue
|
||||
|
||||
|
||||
# Add link to HTML structure
|
||||
menu_item = '\n%s<li class="site_menu_item">'%(10 * ' ') + \
|
||||
'<a class="site_menu_link" href="/%s/">%s</a>'%(
|
||||
d, d
|
||||
) + \
|
||||
'</li>'
|
||||
menu_html = '%s%s'%(menu_html, menu_item)
|
||||
|
||||
# Close HTML tags
|
||||
menu_html = '\n%s\n%s</ul>\n%s</nav>\n'%(menu_html, 8 * ' ', 6 * ' ')
|
||||
if nav_bar:
|
||||
# Open HTML tags
|
||||
menu_html = '%s<nav id="site_menu">\n'%(6 * ' ') + \
|
||||
'%s<ul id="site_menu_items">'%(8 * ' ')
|
||||
|
||||
nolines = ('#', '/')
|
||||
for line in nav_file.rsplit('\n'):
|
||||
if not line or line.startswith(nolines): continue
|
||||
|
||||
dir_uri = os.path.join(domain_articles, line)
|
||||
if not os.path.isdir(dir_uri):
|
||||
tyto.exiting("1", dir_uri, False)
|
||||
continue
|
||||
|
||||
# Add link to HTML structure
|
||||
menu_item = '\n%s<li class="site_menu_item">'%(10 * ' ') + \
|
||||
'<a class="site_menu_link" href="/%s/">%s</a>'%(
|
||||
line, line
|
||||
) + \
|
||||
'</li>'
|
||||
menu_html = '%s%s'%(menu_html, menu_item)
|
||||
|
||||
# Close HTML tags
|
||||
menu_html = '\n%s\n%s</ul>\n%s</nav>\n'%(menu_html, 8 * ' ', 6 * ' ')
|
||||
|
||||
|
||||
#-----------------------#
|
||||
# Create main HTML Page #
|
||||
|
|
|
@ -17,6 +17,7 @@
|
|||
|
||||
#**********************************************************************
|
||||
import sys
|
||||
|
||||
import tyto
|
||||
|
||||
# Load domain configuration if exists
|
||||
|
@ -25,16 +26,25 @@ if tyto.domain_exists: exec(open(tyto.domain_conf).read())
|
|||
#==============================#
|
||||
# Manage arguments for sidebar #
|
||||
#------------------------------#
|
||||
def manage_sidebar(target, option):
|
||||
# Initialize new sidebar
|
||||
def manage_navbars(target, option):
|
||||
import domain
|
||||
actions = {
|
||||
'sidebar' : domain.create_sidebar,
|
||||
'navbar' : domain.create_navbar
|
||||
}
|
||||
|
||||
if sys.argv[1] == "sidebar": file = sidebar_load
|
||||
elif sys.argv[1] == 'navbar': file = navbar_load
|
||||
|
||||
# Initialize new file
|
||||
if not target:
|
||||
if option == "Remove":
|
||||
import domain
|
||||
domain.create_sidebar(opt, sidebar_dir)
|
||||
if option == 'Edit':
|
||||
print(":D Edit sidebar configuration file:", sidebar_load)
|
||||
tyto.edit_file(sidebar_load)
|
||||
actions[sys.argv[1]](opt, navbars_dir)
|
||||
elif option == 'Edit':
|
||||
print(":D Edit %s configuration file:"%sys.argv[1], file)
|
||||
tyto.edit_file(file)
|
||||
|
||||
else:
|
||||
db_exists = tyto.get_db_post(target) # Article exists + has DB ?
|
||||
if not db_exists: tyto.exiting("4", '') # Needs database
|
||||
|
|
@ -17,6 +17,7 @@
|
|||
|
||||
#**********************************************************************
|
||||
import os, re
|
||||
|
||||
import tyto, html
|
||||
|
||||
def manage_wip(target, option):
|
||||
|
|
Loading…
Reference in a new issue