-
Notifications
You must be signed in to change notification settings - Fork 0
Development Quick Start
This page describes how to develop a DjangoCMS app.
- applicable to any Django project
- originally intended for https://github.com/TACC/Core-CMS (large proprietary project)
- testable via https://github.com/wesleyboar/django-cms-quickstart (small community project)
Follow GitHub documentation.
Details (for a TACC/Core-CMS Django app)
-
Match the repository naming pattern:
Core-CMS-______
(for websites) orCore-CMS-Plugin-______
(for plugins)Guidance
For websites, the
______
should match the "App Name" if it has no spaces (e.g. "Frontera", "UTRC", "A2CPS"). Do not replace spaces with dashes (dashes would undesirably allow parts of the website the name to be interpreted as a hierarchy).For plugins, the
______
may match the "App Name" if it has no spaces (e.g. "Callout"), or the "App Name" with dashes for spaces if the name has an adjective re-usable for other plugins (e.g. "System Monitor", "System Specs"). -
Describe the the repository using this template:
For websites, "The website for ______".
For plugins, "A DjangoCMS plugin (for TACC/Core-CMS) to ______". -
Use relevant Topics (tags) from this template repository:
tacc
,django-cms
, (if a website)website
, (if a plugin)plugin
-
Include the same features on the home page as this template repository:
- Releases
Complete the README.md
's heading, description, and formatted names.
Details (for a TACC/Core-CMS Django app)
This [website|plugin] [provides something].
__dist-name__
:djangocms-tacc-the-example
__package_name__
:djangocms_tacc_the_example
__ClassName__
:TaccsiteTheExample
- "App Name": "The Example"
Details (for any Django app)
This [app|website|plugin] [provides something].
__dist-name__
:django-tacc-the-example
__package_name__
:django_tacc_the_example
__ClassName__
:TheExample
- "App Name": "The Example"
The name should match the __package_name__
value (from README.md
).
-
Update placeholder values to be accurate to your website/plugin.
-
name
= (__dist-name__
) -
description
= (the repository description) -
url
= (the repository URL)
-
-
Add any relevant
classifiers
. For options, https://pypi.org/classifiers/.- The
License :: OSI Approved :: …
must match theLICENSE
used. For help, see section 6.
- The
Details (for a TACC/Core-CMS Django app)
For websites:
-
do add
taccsite-cms
dependency and version appropriately﹡
For plugins:
- for dependencies shared with Core, you may reference TACC/Core-CMS:
pyproject.toml
for versions -
avoid
taccsite-cms
dependency unless necessary; and, if so, then version appropriately﹡
﹡ Get version from https://github.com/TACC/Core-CMS/releases (minus the v
) until proper Python-based version exists.
Details (for any Django app)
For websites:
-
do add any CMS dependency e.g.
django-cms
and version﹡
For plugins:
- for dependencies shared with another project, you can reference that project's
pyproject.toml
for versions - avoid excess dependencies
- Change
__package_name__
to the name of the directory that has your app's files. - Remove/Add entries to accurately define what must be in the distribution. For help, see Python's guide.
Change the following names to the correct name based on your project's README.md
:
__package_name__
__ClassName__
App Name
Note
After more research, this step should be updated or removed.
Resources
- https://guides.lib.utexas.edu/copyright/implementpolicy
- https://research.utexas.edu/otc/for-inventors/software-open-source-copyright-licensing/
- https://www.utsystem.edu/offices/general-counsel/intellectual-property
- https://www.utsystem.edu/documents/docs/general-counsel-documents/2010/software-standard-agreements
In the README.md
, update everything after "Quick Start" step 1 to be specific to your app.
Warning
Be sure to review, and use or edit or remove, any example content (so you do not confuse users).
Tip
For websites, under "Features", list any customizations your website makes to Core.
You may use https://github.com/tacc-wbomar/django-cms-quickstart to test (example) and request a review.