commit 6a359b1dff93264d89b663816cfbfb446343121f Author: Shariq Ansari Date: Tue Jul 18 18:02:23 2023 +0530 feat: Initialize App diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml new file mode 100644 index 00000000..1085c247 --- /dev/null +++ b/.github/workflows/ci.yml @@ -0,0 +1,98 @@ + +name: CI + +on: + push: + branches: + - develop + pull_request: + +concurrency: + group: develop-crm-${{ github.event.number }} + cancel-in-progress: true + +jobs: + tests: + runs-on: ubuntu-latest + strategy: + fail-fast: false + name: Server + + services: + redis-cache: + image: redis:alpine + ports: + - 13000:6379 + redis-queue: + image: redis:alpine + ports: + - 11000:6379 + mariadb: + image: mariadb:10.6 + env: + MYSQL_ROOT_PASSWORD: root + ports: + - 3306:3306 + options: --health-cmd="mysqladmin ping" --health-interval=5s --health-timeout=2s --health-retries=3 + + steps: + - name: Clone + uses: actions/checkout@v3 + + - name: Setup Python + uses: actions/setup-python@v4 + with: + python-version: '3.10' + + - name: Setup Node + uses: actions/setup-node@v3 + with: + node-version: 18 + check-latest: true + + - name: Cache pip + uses: actions/cache@v2 + with: + path: ~/.cache/pip + key: ${{ runner.os }}-pip-${{ hashFiles('**/*requirements.txt', '**/pyproject.toml', '**/setup.py', '**/setup.cfg') }} + restore-keys: | + ${{ runner.os }}-pip- + ${{ runner.os }}- + + - name: Get yarn cache directory path + id: yarn-cache-dir-path + run: 'echo "dir=$(yarn cache dir)" >> $GITHUB_OUTPUT' + + - uses: actions/cache@v3 + id: yarn-cache + with: + path: ${{ steps.yarn-cache-dir-path.outputs.dir }} + key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }} + restore-keys: | + ${{ runner.os }}-yarn- + + - name: Setup + run: | + pip install frappe-bench + bench init --skip-redis-config-generation --skip-assets --python "$(which python)" ~/frappe-bench + mysql --host 127.0.0.1 --port 3306 -u root -proot -e "SET GLOBAL character_set_server = 'utf8mb4'" + mysql --host 127.0.0.1 --port 3306 -u root -proot -e "SET GLOBAL collation_server = 'utf8mb4_unicode_ci'" + + - name: Install + working-directory: /home/runner/frappe-bench + run: | + bench get-app crm $GITHUB_WORKSPACE + bench setup requirements --dev + bench new-site --db-root-password root --admin-password admin test_site + bench --site test_site install-app crm + bench build + env: + CI: 'Yes' + + - name: Run Tests + working-directory: /home/runner/frappe-bench + run: | + bench --site test_site set-config allow_tests true + bench --site test_site run-tests --app crm + env: + TYPE: server diff --git a/.gitignore b/.gitignore new file mode 100644 index 00000000..e543d12a --- /dev/null +++ b/.gitignore @@ -0,0 +1,6 @@ +.DS_Store +*.pyc +*.egg-info +*.swp +tags +node_modules \ No newline at end of file diff --git a/README.md b/README.md new file mode 100644 index 00000000..049c472f --- /dev/null +++ b/README.md @@ -0,0 +1,7 @@ +## Frappe CRM + +Kick-ass Open Source CRM + +#### License + +AGPLv3 \ No newline at end of file diff --git a/crm/__init__.py b/crm/__init__.py new file mode 100644 index 00000000..7a0660b4 --- /dev/null +++ b/crm/__init__.py @@ -0,0 +1,3 @@ + +__version__ = '0.0.1' + diff --git a/crm/config/__init__.py b/crm/config/__init__.py new file mode 100644 index 00000000..e69de29b diff --git a/crm/frappe_crm/__init__.py b/crm/frappe_crm/__init__.py new file mode 100644 index 00000000..e69de29b diff --git a/crm/hooks.py b/crm/hooks.py new file mode 100644 index 00000000..01aa8197 --- /dev/null +++ b/crm/hooks.py @@ -0,0 +1,216 @@ +app_name = "crm" +app_title = "Frappe CRM" +app_publisher = "Frappe Technologies Pvt. Ltd." +app_description = "Kick-ass Open Source CRM" +app_email = "shariq@frappe.io" +app_license = "AGPLv3" +# required_apps = [] + +# Includes in +# ------------------ + +# include js, css files in header of desk.html +# app_include_css = "/assets/crm/css/crm.css" +# app_include_js = "/assets/crm/js/crm.js" + +# include js, css files in header of web template +# web_include_css = "/assets/crm/css/crm.css" +# web_include_js = "/assets/crm/js/crm.js" + +# include custom scss in every website theme (without file extension ".scss") +# website_theme_scss = "crm/public/scss/website" + +# include js, css files in header of web form +# webform_include_js = {"doctype": "public/js/doctype.js"} +# webform_include_css = {"doctype": "public/css/doctype.css"} + +# include js in page +# page_js = {"page" : "public/js/file.js"} + +# include js in doctype views +# doctype_js = {"doctype" : "public/js/doctype.js"} +# doctype_list_js = {"doctype" : "public/js/doctype_list.js"} +# doctype_tree_js = {"doctype" : "public/js/doctype_tree.js"} +# doctype_calendar_js = {"doctype" : "public/js/doctype_calendar.js"} + +# Home Pages +# ---------- + +# application home page (will override Website Settings) +# home_page = "login" + +# website user home page (by Role) +# role_home_page = { +# "Role": "home_page" +# } + +# Generators +# ---------- + +# automatically create page for each record of this doctype +# website_generators = ["Web Page"] + +# Jinja +# ---------- + +# add methods and filters to jinja environment +# jinja = { +# "methods": "crm.utils.jinja_methods", +# "filters": "crm.utils.jinja_filters" +# } + +# Installation +# ------------ + +# before_install = "crm.install.before_install" +# after_install = "crm.install.after_install" + +# Uninstallation +# ------------ + +# before_uninstall = "crm.uninstall.before_uninstall" +# after_uninstall = "crm.uninstall.after_uninstall" + +# Integration Setup +# ------------------ +# To set up dependencies/integrations with other apps +# Name of the app being installed is passed as an argument + +# before_app_install = "crm.utils.before_app_install" +# after_app_install = "crm.utils.after_app_install" + +# Integration Cleanup +# ------------------- +# To clean up dependencies/integrations with other apps +# Name of the app being uninstalled is passed as an argument + +# before_app_uninstall = "crm.utils.before_app_uninstall" +# after_app_uninstall = "crm.utils.after_app_uninstall" + +# Desk Notifications +# ------------------ +# See frappe.core.notifications.get_notification_config + +# notification_config = "crm.notifications.get_notification_config" + +# Permissions +# ----------- +# Permissions evaluated in scripted ways + +# permission_query_conditions = { +# "Event": "frappe.desk.doctype.event.event.get_permission_query_conditions", +# } +# +# has_permission = { +# "Event": "frappe.desk.doctype.event.event.has_permission", +# } + +# DocType Class +# --------------- +# Override standard doctype classes + +# override_doctype_class = { +# "ToDo": "custom_app.overrides.CustomToDo" +# } + +# Document Events +# --------------- +# Hook on document methods and events + +# doc_events = { +# "*": { +# "on_update": "method", +# "on_cancel": "method", +# "on_trash": "method" +# } +# } + +# Scheduled Tasks +# --------------- + +# scheduler_events = { +# "all": [ +# "crm.tasks.all" +# ], +# "daily": [ +# "crm.tasks.daily" +# ], +# "hourly": [ +# "crm.tasks.hourly" +# ], +# "weekly": [ +# "crm.tasks.weekly" +# ], +# "monthly": [ +# "crm.tasks.monthly" +# ], +# } + +# Testing +# ------- + +# before_tests = "crm.install.before_tests" + +# Overriding Methods +# ------------------------------ +# +# override_whitelisted_methods = { +# "frappe.desk.doctype.event.event.get_events": "crm.event.get_events" +# } +# +# each overriding function accepts a `data` argument; +# generated from the base implementation of the doctype dashboard, +# along with any modifications made in other Frappe apps +# override_doctype_dashboards = { +# "Task": "crm.task.get_dashboard_data" +# } + +# exempt linked doctypes from being automatically cancelled +# +# auto_cancel_exempted_doctypes = ["Auto Repeat"] + +# Ignore links to specified DocTypes when deleting documents +# ----------------------------------------------------------- + +# ignore_links_on_delete = ["Communication", "ToDo"] + +# Request Events +# ---------------- +# before_request = ["crm.utils.before_request"] +# after_request = ["crm.utils.after_request"] + +# Job Events +# ---------- +# before_job = ["crm.utils.before_job"] +# after_job = ["crm.utils.after_job"] + +# User Data Protection +# -------------------- + +# user_data_fields = [ +# { +# "doctype": "{doctype_1}", +# "filter_by": "{filter_by}", +# "redact_fields": ["{field_1}", "{field_2}"], +# "partial": 1, +# }, +# { +# "doctype": "{doctype_2}", +# "filter_by": "{filter_by}", +# "partial": 1, +# }, +# { +# "doctype": "{doctype_3}", +# "strict": False, +# }, +# { +# "doctype": "{doctype_4}" +# } +# ] + +# Authentication and authorization +# -------------------------------- + +# auth_hooks = [ +# "crm.auth.validate" +# ] diff --git a/crm/modules.txt b/crm/modules.txt new file mode 100644 index 00000000..cd05ee43 --- /dev/null +++ b/crm/modules.txt @@ -0,0 +1 @@ +Frappe CRM \ No newline at end of file diff --git a/crm/patches.txt b/crm/patches.txt new file mode 100644 index 00000000..f15c3a90 --- /dev/null +++ b/crm/patches.txt @@ -0,0 +1,6 @@ +[pre_model_sync] +# Patches added in this section will be executed before doctypes are migrated +# Read docs to understand patches: https://frappeframework.com/docs/v14/user/en/database-migrations + +[post_model_sync] +# Patches added in this section will be executed after doctypes are migrated \ No newline at end of file diff --git a/crm/public/.gitkeep b/crm/public/.gitkeep new file mode 100644 index 00000000..e69de29b diff --git a/crm/templates/__init__.py b/crm/templates/__init__.py new file mode 100644 index 00000000..e69de29b diff --git a/crm/templates/pages/__init__.py b/crm/templates/pages/__init__.py new file mode 100644 index 00000000..e69de29b diff --git a/license.txt b/license.txt new file mode 100644 index 00000000..2048c67b --- /dev/null +++ b/license.txt @@ -0,0 +1 @@ +License: AGPLv3 \ No newline at end of file diff --git a/pyproject.toml b/pyproject.toml new file mode 100644 index 00000000..28b65e2d --- /dev/null +++ b/pyproject.toml @@ -0,0 +1,20 @@ +[project] +name = "crm" +authors = [ + { name = "Frappe Technologies Pvt. Ltd.", email = "shariq@frappe.io"} +] +description = "Kick-ass Open Source CRM" +requires-python = ">=3.10" +readme = "README.md" +dynamic = ["version"] +dependencies = [ + # "frappe~=15.0.0" # Installed and managed by bench. +] + +[build-system] +requires = ["flit_core >=3.4,<4"] +build-backend = "flit_core.buildapi" + +# These dependencies are only installed when developer mode is enabled +[tool.bench.dev-dependencies] +# package_name = "~=1.1.0"