diff --git a/.gitignore b/.gitignore index 44427323..a8c18321 100644 --- a/.gitignore +++ b/.gitignore @@ -1,2 +1,155 @@ -.DS_Store -.gitignore \ No newline at end of file + +# Created by https://www.toptal.com/developers/gitignore/api/python,jupyternotebooks +# Edit at https://www.toptal.com/developers/gitignore?templates=python,jupyternotebooks + +### JupyterNotebooks ### +# gitignore template for Jupyter Notebooks +# website: http://jupyter.org/ + +.ipynb_checkpoints +*/.ipynb_checkpoints/* + +# IPython +profile_default/ +ipython_config.py + +# Remove previous ipynb_checkpoints +# git rm -r .ipynb_checkpoints/ + +### Python ### +# Byte-compiled / optimized / DLL files +__pycache__/ +*.py[cod] +*$py.class + +# C extensions +*.so + +# Distribution / packaging +.Python +build/ +develop-eggs/ +dist/ +downloads/ +eggs/ +.eggs/ +lib/ +lib64/ +parts/ +sdist/ +var/ +wheels/ +share/python-wheels/ +*.egg-info/ +.installed.cfg +*.egg +MANIFEST + +# PyInstaller +# Usually these files are written by a python script from a template +# before PyInstaller builds the exe, so as to inject date/other infos into it. +*.manifest +*.spec + +# Installer logs +pip-log.txt +pip-delete-this-directory.txt + +# Unit test / coverage reports +htmlcov/ +.tox/ +.nox/ +.coverage +.coverage.* +.cache +nosetests.xml +coverage.xml +*.cover +*.py,cover +.hypothesis/ +.pytest_cache/ +cover/ + +# Translations +*.mo + +# Django stuff: +*.log +local_settings.py +db.sqlite3 +db.sqlite3-journal + +# Flask stuff: +instance/ +.webassets-cache + +# Scrapy stuff: +.scrapy + +# Sphinx documentation +docs/_build/ + +# PyBuilder +.pybuilder/ +target/ + +# Jupyter Notebook + +# IPython + +# pyenv +# For a library or package, you might want to ignore these files since the code is +# intended to run in multiple environments; otherwise, check them in: +# .python-version + +# pipenv +# According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control. +# However, in case of collaboration, if having platform-specific dependencies or dependencies +# having no cross-platform support, pipenv may install dependencies that don't work, or not +# install all needed dependencies. +#Pipfile.lock + +# PEP 582; used by e.g. github.com/David-OConnor/pyflow +__pypackages__/ + +# Celery stuff +celerybeat-schedule +celerybeat.pid + +# SageMath parsed files +*.sage.py + +# Environments +.env +.venv +env/ +venv/ +ENV/ +env.bak/ +venv.bak/ + +# Spyder project settings +.spyderproject +.spyproject + +# Rope project settings +.ropeproject + +# mkdocs documentation +/site + +# mypy +.mypy_cache/ +.dmypy.json +dmypy.json + +# Pyre type checker +.pyre/ + +# pytype static type analyzer +.pytype/ + +# Cython debug symbols +cython_debug/ + +# End of https://www.toptal.com/developers/gitignore/api/python,jupyternotebooks diff --git a/docs/Makefile b/docs/Makefile new file mode 100644 index 00000000..c72d8faf --- /dev/null +++ b/docs/Makefile @@ -0,0 +1,47 @@ +# Minimal makefile for Sphinx documentation +# + +# You can set these variables from the command line, and also +# from the environment for the first two. +SPHINXOPTS ?= +SPHINXBUILD ?= sphinx-build +SOURCEDIR = +BUILDDIR = build +LINKSDIR = links +LINKCHECKDIR = build/linkcheck + +# Put it first so that "make" without argument is like "make help". +help: + @$(SPHINXBUILD) -M help "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O) + +.PHONY: help Makefile + +.PHONY: link +link: + @read -p "Enter a Unique Link Name: " link_name; \ + read -p "Enter the link text the user sees: " link_text; \ + read -p "Enter the URL: " link_url; \ + read -p "Enter the .py file name (use_lower_case_and_underscore of link name): " file_name; \ + echo "The link name is: " $$link_name; \ + echo "The link text is: " $$link_text; \ + echo "The URL is: " $$link_url; \ + echo "Creating the file: " $(LINKSDIR)/$$file_name".py"; \ + echo "Enter the link in content as :xref:\`"$$link_name"\`"; \ + echo "The user will see:" $$link_text; \ + echo "Make sure you build and test the link."; \ + echo "from . import link\n\nlink_name = \"$$link_name\" \n\ +link_text = \"$$link_text\" \n\ +link_url = \"$$link_url\" \n\n\ +link.xref_links.update({link_name: (link_text, link_url)})" \ + > $(LINKSDIR)/$$file_name".py" \ + +.PHONY: checklinks +checklinks: + $(SPHINXBUILD) -b linkcheck . $(LINKCHECKDIR) + @echo + @echo "Check finished. Report is in $(LINKCHECKDIR)." + +# Catch-all target: route all unknown targets to Sphinx using the new +# "make mode" option. $(O) is meant as a shortcut for $(SPHINXOPTS). +%: Makefile + @$(SPHINXBUILD) -M $@ "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O) diff --git a/docs/_templates/layout.html b/docs/_templates/layout.html new file mode 100644 index 00000000..ebc2f04d --- /dev/null +++ b/docs/_templates/layout.html @@ -0,0 +1,2 @@ +{% extends "!layout.html" %} +{% set css_files = css_files + ["_static/tablefix.css"] %} \ No newline at end of file diff --git a/docs/about/what_is_mautic.rst b/docs/about/what_is_mautic.rst new file mode 100644 index 00000000..3adb132f --- /dev/null +++ b/docs/about/what_is_mautic.rst @@ -0,0 +1,18 @@ +What is Mautic? +############### + +Mautic is the world's first Open Source Marketing Automation platform. + +It was created by DB Hurley and launched in 2014 as an Open Source project under the GPL v3 license. You can find out more on our website, +:xref:`mautic.org`, or on the :xref:`Mautic GitHub repository`. You can :xref:`download Mautic` for free on mautic.org. + +The Mautic Community are a worldwide distributed team of volunteers who are passionate about Mautic, Marketing Automation, and Open Source technologies. + +We come together to build, improve and share Mautic, united by our belief in empowering organizations with the tools they need to deliver world-class automation and personalized experiences to their customers. + +Anybody can get involved - whether you want to organise a local meetup, contribute code, improve our documentation or translations, or help us tell others about Mautic. + +We are primarlily organized around the following channels: + +:xref:`Mautic Community Forums` +:xref:`Mautic Community Slack` diff --git a/docs/conf.py b/docs/conf.py new file mode 100644 index 00000000..89d453b0 --- /dev/null +++ b/docs/conf.py @@ -0,0 +1,60 @@ +# Configuration file for the Sphinx documentation builder. + +import sys, os +import sphinx_rtd_theme + +sys.path.append(os.path.abspath('ext')) +sys.path.append('.') + +from links.link import * +from links import * + +# -- Project information + +project = 'Mautic Community Handbook' +copyright = '2022, Mautic' +author = 'Mautic' + +release = '0.1' +version = '0.1.0' + +# -- General configuration + +source_suffix = ['.rst', '.md'] + +extensions = [ + 'xref', + 'sphinx.ext.duration', + 'sphinx.ext.doctest', + 'sphinx.ext.autodoc', + 'sphinx.ext.autosummary', + 'sphinx.ext.intersphinx', + 'sphinx_rtd_theme', + 'sphinx.ext.viewcode', + 'sphinx.ext.autosectionlabel', + 'myst_parser' +] + +myst_enable_extensions = [ + "linkify", +] + +intersphinx_mapping = { + 'python': ('https://docs.python.org/3/', None), + 'sphinx': ('https://www.sphinx-doc.org/en/master/', None), +} +intersphinx_disabled_domains = ['std'] + +templates_path = ['_templates'] + +html_static_path = ['css'] + +# -- Options for HTML output + +# The theme to use for HTML and HTML Help pages. See the documentation for +# a list of builtin themes. +# +html_theme = 'sphinx_rtd_theme' + +# -- Options for EPUB output +epub_show_urls = 'footnote' diff --git a/docs/css/tablefix.css b/docs/css/tablefix.css new file mode 100644 index 00000000..8d367b00 --- /dev/null +++ b/docs/css/tablefix.css @@ -0,0 +1,14 @@ +/* override table width restrictions */ +.wy-table-responsive table td, .wy-table-responsive table th { + white-space: normal; +} + +.wy-table-responsive { + margin-bottom: 24px; + max-width: 100%; + overflow: visible; +} + +.wy-table-responsive th p { + margin-bottom: unset; +} \ No newline at end of file diff --git a/docs/ext/xref.py b/docs/ext/xref.py new file mode 100644 index 00000000..5cc286b6 --- /dev/null +++ b/docs/ext/xref.py @@ -0,0 +1,40 @@ +# -*- coding: utf-8 -*- + +from docutils import nodes +from sphinx.util import caption_ref_re + +def xref( typ, rawtext, text, lineno, inliner, options={}, content=[] ): + + title = target = text + titleistarget = True + # look if explicit title and target are given with `foo ` syntax + brace = text.find('<') + if brace != -1: + titleistarget = False + m = caption_ref_re.match(text) + if m: + target = m.group(2) + title = m.group(1) + else: + # fallback: everything after '<' is the target + target = text[brace+1:] + title = text[:brace] + + link = xref.links[target] + + if brace != -1: + pnode = nodes.reference(target, title, refuri=link[1]) + else: + pnode = nodes.reference(target, link[0], refuri=link[1]) + + return [pnode], [] + +def get_refs(app): + + xref.links = app.config.xref_links + +def setup(app): + + app.add_config_value('xref_links', {}, True) + app.add_role('xref', xref) + app.connect("builder-inited", get_refs) diff --git a/docs/index.rst b/docs/index.rst new file mode 100644 index 00000000..2dba04b3 --- /dev/null +++ b/docs/index.rst @@ -0,0 +1,17 @@ +Mautic Community Handbook +######################### + +This handbook is a central point of call for how the Mautic community is organised and managed. + +The vision is that it will grow over time as the teams and governance structure evolves, with team members adding useful resources and updating processes as they mature and are refined. + +.. note:: + + This project is under active development as we replatform from our old system. + +.. toctree:: + :maxdepth: 2 + :caption: About Mautic + :hidden: + + about/what_is_mautic diff --git a/docs/links/__init__.py b/docs/links/__init__.py new file mode 100644 index 00000000..9fdcb320 --- /dev/null +++ b/docs/links/__init__.py @@ -0,0 +1,6 @@ +from os.path import dirname, basename, isfile + +import glob +modules = glob.glob(dirname(__file__)+"/*.py") + +__all__ = [ basename(f)[:-3] for f in modules if isfile(f)] \ No newline at end of file diff --git a/docs/links/download_mautic.py b/docs/links/download_mautic.py new file mode 100644 index 00000000..1c62875c --- /dev/null +++ b/docs/links/download_mautic.py @@ -0,0 +1,7 @@ +from . import link + +link_name = "Download Mautic" +link_text = "Download Mautic" +link_url = "https://mautic.org/download/" + +link.xref_links.update({link_name: (link_text, link_url)}) \ No newline at end of file diff --git a/docs/links/link.py b/docs/links/link.py new file mode 100644 index 00000000..8f4cd594 --- /dev/null +++ b/docs/links/link.py @@ -0,0 +1,3 @@ + + +xref_links = {"key" : ("link text", "URL")} \ No newline at end of file diff --git a/docs/links/mautic_forums.py b/docs/links/mautic_forums.py new file mode 100644 index 00000000..0ab7e903 --- /dev/null +++ b/docs/links/mautic_forums.py @@ -0,0 +1,7 @@ +from . import link + +link_name = "Mautic Community Forums" +link_text = "Mautic Community Forums" +link_url = "https://forum.mautic.org/c/support" + +link.xref_links.update({link_name: (link_text, link_url)}) \ No newline at end of file diff --git a/docs/links/mautic_github.py b/docs/links/mautic_github.py new file mode 100644 index 00000000..6989ce20 --- /dev/null +++ b/docs/links/mautic_github.py @@ -0,0 +1,7 @@ +from . import link + +link_name = "Mautic GitHub repository" +link_text = "Mautic GitHub repository" +link_url = "https://github.com/mautic/mautic" + +link.xref_links.update({link_name: (link_text, link_url)}) \ No newline at end of file diff --git a/docs/links/mautic_org.py b/docs/links/mautic_org.py new file mode 100644 index 00000000..068f87eb --- /dev/null +++ b/docs/links/mautic_org.py @@ -0,0 +1,7 @@ +from . import link + +link_name = "mautic_org" +link_text = "mautic.org" +link_url = "https://mautic.org" + +link.xref_links.update({link_name: (link_text, link_url)}) \ No newline at end of file diff --git a/docs/links/mautic_slack.py b/docs/links/mautic_slack.py new file mode 100644 index 00000000..c8f95cb3 --- /dev/null +++ b/docs/links/mautic_slack.py @@ -0,0 +1,7 @@ +from . import link + +link_name = "Mautic Community Slack" +link_text = "Mautic Community Slack" +link_url = "https://mautic.org/slack" + +link.xref_links.update({link_name: (link_text, link_url)}) \ No newline at end of file diff --git a/docs/make.bat b/docs/make.bat new file mode 100644 index 00000000..6247f7e2 --- /dev/null +++ b/docs/make.bat @@ -0,0 +1,35 @@ +@ECHO OFF + +pushd %~dp0 + +REM Command file for Sphinx documentation + +if "%SPHINXBUILD%" == "" ( + set SPHINXBUILD=sphinx-build +) +set SOURCEDIR=source +set BUILDDIR=build + +if "%1" == "" goto help + +%SPHINXBUILD% >NUL 2>NUL +if errorlevel 9009 ( + echo. + echo.The 'sphinx-build' command was not found. Make sure you have Sphinx + echo.installed, then set the SPHINXBUILD environment variable to point + echo.to the full path of the 'sphinx-build' executable. Alternatively you + echo.may add the Sphinx directory to PATH. + echo. + echo.If you don't have Sphinx installed, grab it from + echo.http://sphinx-doc.org/ + exit /b 1 +) + +%SPHINXBUILD% -M %1 %SOURCEDIR% %BUILDDIR% %SPHINXOPTS% %O% +goto end + +:help +%SPHINXBUILD% -M help %SOURCEDIR% %BUILDDIR% %SPHINXOPTS% %O% + +:end +popd diff --git a/docs/requirements.txt b/docs/requirements.txt new file mode 100644 index 00000000..97456aaf --- /dev/null +++ b/docs/requirements.txt @@ -0,0 +1,11 @@ +# File: requirements.txt + +# Defining the exact version will make sure things don't break +sphinx==4.2.0 +sphinx_rtd_theme==1.0.0 +readthedocs-sphinx-search==0.1.0 +rstcheck==3.3.1 +myst-parser==0.16.1 +linkify-it-py==1.0.3 +esbonio==0.13.0 +attrs==21.4.0