{"id":19081422,"url":"https://github.com/kristi11/wittyworkflow","last_synced_at":"2025-08-02T16:40:28.975Z","repository":{"id":218571903,"uuid":"737609781","full_name":"kristi11/wittyworkflow","owner":"kristi11","description":"Wittyworkflow is a dynamic web application poised to evolve into a robust platform designed to streamline business management. The application incorporates a range of features to empower users in efficiently managing their businesses.","archived":false,"fork":false,"pushed_at":"2024-08-03T06:15:18.000Z","size":2898,"stargazers_count":1,"open_issues_count":0,"forks_count":2,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-06-24T15:04:09.802Z","etag":null,"topics":["laravel","livewire","livewire3","mysql","tailwindcss"],"latest_commit_sha":null,"homepage":"https://www.wittyworkflow.com","language":"Blade","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/kristi11.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":"SECURITY.md","support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2023-12-31T18:22:49.000Z","updated_at":"2025-02-02T04:31:49.000Z","dependencies_parsed_at":"2024-01-22T21:49:36.994Z","dependency_job_id":"c23373ac-9a8f-4d6e-94f9-184ce6612a94","html_url":"https://github.com/kristi11/wittyworkflow","commit_stats":null,"previous_names":["kristi11/wittyworkflow"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/kristi11/wittyworkflow","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kristi11%2Fwittyworkflow","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kristi11%2Fwittyworkflow/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kristi11%2Fwittyworkflow/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kristi11%2Fwittyworkflow/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/kristi11","download_url":"https://codeload.github.com/kristi11/wittyworkflow/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kristi11%2Fwittyworkflow/sbom","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":261700469,"owners_count":23196501,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["laravel","livewire","livewire3","mysql","tailwindcss"],"created_at":"2024-11-09T02:35:03.131Z","updated_at":"2025-06-24T15:05:47.405Z","avatar_url":"https://github.com/kristi11.png","language":"Blade","funding_links":[],"categories":[],"sub_categories":[],"readme":"\u003c!-- PROJECT SHIELDS --\u003e\n\u003c!--\n*** I'm using markdown \"reference style\" links for readability.\n*** Reference links are enclosed in brackets [ ] instead of parentheses ( ).\n*** See the bottom of this document for the declaration of the reference variables\n*** for contributors-url, forks-url, etc. This is an optional, concise syntax you may use.\n*** https://www.markdownguide.org/basic-syntax/#reference-style-links\n--\u003e\n\n[![LinkedIn][linkedin-shield]][linkedin-url]\n\n\n\n\u003c!-- PROJECT LOGO --\u003e\n\u003cbr /\u003e\n\u003cdiv align=\"center\"\u003e\n  \u003ca href=\"https://github.com/kristi11/wittyworkflow/\"\u003e\n    \u003cimg src=\"public/android-chrome-192x192.png\" alt=\"Logo\" width=\"80\" height=\"80\"\u003e\n  \u003c/a\u003e\n\n\u003ch3 align=\"center\"\u003eWitty workflow\u003c/h3\u003e\n\n  \u003cp align=\"center\"\u003e\n    A platform for managing your business\n    \u003cbr /\u003e\n    \u003cbr /\u003e\n    \u003ca href=\"https://wittyworkflow.com/\"\u003eView Demo\u003c/a\u003e\n    ·\n    \u003ca href=\"https://github.com/kristi11/wittyworkflow/issues\"\u003eReport Bug\u003c/a\u003e\n    ·\n    \u003ca href=\"https://github.com/kristi11/wittyworkflow/issues\"\u003eRequest Feature\u003c/a\u003e\n  \u003c/p\u003e\n    \u003cb\u003ePLEASE DO KEEP IN MIND THAT THIS IS A NEW APP AND THERE WILL BE A LOT OF ROOM FOR IMPROVEMENT\u003c/b\u003e\n\u003c/div\u003e\n\n\n\n\u003c!-- TABLE OF CONTENTS --\u003e\n\u003cdetails\u003e\n  \u003csummary\u003eTable of Contents\u003c/summary\u003e\n  \u003col\u003e\n    \u003cli\u003e\n      \u003ca href=\"#about-the-project\"\u003eAbout The Project\u003c/a\u003e\n      \u003cul\u003e\n        \u003cli\u003e\u003ca href=\"#built-with\"\u003eBuilt With\u003c/a\u003e\u003c/li\u003e\n      \u003c/ul\u003e\n    \u003c/li\u003e\n    \u003cli\u003e\n      \u003ca href=\"#getting-started\"\u003eGetting Started\u003c/a\u003e\n      \u003cul\u003e\n        \u003cli\u003e\u003ca href=\"#installation\"\u003eInstallation\u003c/a\u003e\u003c/li\u003e\n      \u003c/ul\u003e\n    \u003c/li\u003e\n    \u003cli\u003e\u003ca href=\"#usage\"\u003eUsage\u003c/a\u003e\u003c/li\u003e\n    \u003cli\u003e\u003ca href=\"#roadmap\"\u003eRoadmap\u003c/a\u003e\u003c/li\u003e\n    \u003cli\u003e\u003ca href=\"#contributing\"\u003eContributing\u003c/a\u003e\u003c/li\u003e\n    \u003cli\u003e\u003ca href=\"#license\"\u003eLicense\u003c/a\u003e\u003c/li\u003e\n    \u003cli\u003e\u003ca href=\"#contact\"\u003eContact\u003c/a\u003e\u003c/li\u003e\n    \u003cli\u003e\u003ca href=\"#acknowledgments\"\u003eAcknowledgments\u003c/a\u003e\u003c/li\u003e\n  \u003c/ol\u003e\n\u003c/details\u003e\n\n\n\n\u003c!-- ABOUT THE PROJECT --\u003e\n## About The Project\n\n##### Wittyworkflow is a dynamic web application poised to evolve into a robust platform designed to streamline business management. The application incorporates a range of features to empower users in efficiently managing their businesses. Below is an overview of the key functionalities and the development journey captured in our roadmap:\n\n## Key Features:\n\n* **Dynamic Hero:** Engage your audience with a visually appealing and dynamic hero section that captures attention and communicates your brand essence.\n\n* **Realtime Validation:** Ensure data accuracy and enhance user experience with realtime validation for all components, contributing to a seamless interaction.\n\n* **Role-Based Access:** Implement a secure environment with role-based access, allowing team members exclusive access to relevant information. Non-team members are restricted from accessing team-related data.\n\n* **Lazy Image Loading:** Optimize performance by incorporating lazy image loading, particularly beneficial in the hero section for faster page rendering.\n\n* **SPA functionality with Wire:Navigate :** Enhance navigation with a SPA like menu featuring wire:navigate functionality, bringing Single Page Application (SPA) functionality to your site for smooth transitions between links.\n\n* **Laravel Jetstream Authentication:** Benefit from Laravel Jetstream authentication, including features like 2-factor authentication and browser session control. Profile information updating has been disabled for demonstration purposes but can be enabled through fortify.php with the desired features.\n\n* **Team Management:** Staff members can create teams, ensuring controlled and secure team management.\n\n* **CRUD Operations for Admins:** Enable administrators with CRUD (Create, Read, Update, Delete) operations for users, addresses, landing page heroes, appointments, services, opening hours, gallery, socials, and SEO. These functionalities empower admins with comprehensive control over critical aspects of the platform.\n\n* **Public Email Form and Footer:** Facilitate communication by implementing a public email form and completing the footer for a professional and polished user interface.\n\n* **Email Notifications on Appointment Changes:** Receive email notifications for changes in appointments, ensuring you never miss valuable information about your upcoming appointments.\n\n* **Newsletter Creation:** Planned feature (Not yet finished): Develop a newsletter system to keep users informed and engaged with your platform.\n\n* **Progressive Web App (PWA):** Planned feature (Not yet started): Transform the web app into a Progressive Web App, providing users with an enhanced offline experience and improved accessibility.\n\n* **Jetstream Configuration (jetstream.php):** Customize Jetstream features by editing the jetstream.php configuration file. Enable the desired features according to your project requirements.\n\n## About Wittyworkflow:\nWittyworkflow is designed to empower businesses through a comprehensive suite of features, combining dynamic visual elements with secure and efficient management tools. The roadmap reflects the commitment to continuous improvement and innovation. Join up on this journey as we work towards creating a platform that simplifies business operations and fosters growth.\n\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n\n\n\n### Built With\n\nThis section lists all major frameworks/libraries used to bootstrap this project.\n\n* [![Laravel][Laravel.com]][Laravel-url]\n* [![Livewire][Livewire.laravel.com]][Livewire-url]\n* [![Tailwind CSS][tailwindcss.com]][tailwindcss-url]\n* [![Amazon s3][Amazon s3]][Amazon s3-url]\n\n\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n\n\n\n\u003c!-- GETTING STARTED --\u003e\n## Getting Started\n\nThis project uses [Laravel 10.x](https://laravel.com/docs/master#install-composer) with the  [livewire 3.x](https://livewire.laravel.com/docs/quickstart) stack.\n\n### Installation\n\nTo get started clone this repository.\n1. Clone the repo\n   ```\n   git clone https://github.com/kristi11/wittyworkflow.git\n   ```\n   or if you have a different name you'd like to use for the project create an empty folder with your desired name and run the following command:\n   ```\n   git clone https://github.com/kristi11/wittyworkflow.git .\n   ```\n   this will clone all of the project's content without the project name folder.\n2. Install NPM packages\n   ```\n   npm install\n   ```\n   and run npm `npm run dev` if you're working locally or `npm run build` if you're working on production.\n3. Install the composer dependencies.\n   ```\n   composer install\n   ```\n4. Create a copy of your .env file.\n   ```\n    cp .env.example .env\n    ```\n5. Generate an app encryption key.\n   ```\n   php artisan key:generate\n   ```\n   if using laravel [forge](https://forge.laravel.com/) there's no need to generate key since when creating the server [forge](https://forge.laravel.com/) will take care  of the key generation.\n6. Create an empty database for our application. I personally like using [TablePlus](https://tableplus.com/) but you can use whatever you like.\n7. In the `.env` file, add database information to allow Laravel to connect to the database. The default database name is `wittyworkflow`. If you are using a different name, you'll need to edit the `DB_DATABASE` variable in the `.env` file with your database name.\n8. Migrate and seed the database.\n   ```\n   php artisan migrate:fresh --seed\n   ```\n10. Link the storage folder.\n    ```\n    php artisan storage:link\n    ```\n11. Run the application.\n    ```\n    php artisan serve\n    ```\n12. Visit your application in the browser.\n    ```\n    http://localhost:8000\n    ```\n13. Login to the admin dashboard with the following credentials:\n    ```\n    email: kristi@wittyworkflow.com\n    \n    password: password\n    ```\n    \nI use [Mailtrap](https://mailtrap.io/) for email testing. You can use whatever you like. If you want to use Mailtrap, create an account and add the credentials to the `.env` file. If you are using [forge](https://forge.laravel.com/) you can add the credentials to the server environment variables.\n\nIf you decide to use mailtrap, you can use the following credentials:\n```\nMAIL_MAILER=smtp\nMAIL_HOST=smtp.mailtrap.io\nMAIL_PORT=2525\nMAIL_USERNAME=your_username\nMAIL_PASSWORD=your_password\nMAIL_ENCRYPTION=tls\nMAIL_FROM_ADDRESS=your_email\nMAIL_FROM_NAME=\"${APP_NAME}\"\n```\nThis app stores files in [Amazon s3](https://aws.amazon.com/s3/). If you want to use [Amazon s3](https://aws.amazon.com/s3/) you need to add the credentials to the `.env` file.\n\n```\nAWS_ACCESS_KEY_ID=your_access_key\nAWS_SECRET_ACCESS_KEY=your_secret_key\nAWS_DEFAULT_REGION=your_region\nAWS_BUCKET=your-bucket-private\nAWS_BUCKET_PUBLIC=your-bucket-public\nAWS_USE_PATH_STYLE_ENDPOINT=false\n```\n\nTo set up your chat credentials first you have to sign up for [pusher](https://pusher.com/). \n[Here's](https://chatify.munafio.com/installation) the setup and installation video from the creator of laravel chatify .This includes the set up of pusher and the installation of chatify(which is already installed).\nThen fill the following credentials to the `.env` file with the credentials from your pusher account.\n\n```\nPUSHER_APP_ID=your-pusher-app-id\nPUSHER_APP_KEY=your-pusher-app-key\nPUSHER_APP_SECRET=your-pusher-app-secret\nPUSHER_APP_CLUSTER=your-pusher-app-cluster\n```\nalso add the following to the `.env` file\n```\nCHATIFY_STORAGE_DISK=your-s3-bucket-or-custom-driver\nCHATIFY_ROUTES_PREFIX=your-chatify-routes-prefix\nCHATIFY_NAME=Chatify-messeneger-name-here\n```\n\nThe private bucket is used to store the livewire `tmp` files and the public bucket is used to store the images accessible to everyone.\n\nTo clean up the `tmp` files uploaded on `S3` every 24 hours add the following command to your server \n```\nphp artisan livewire:configure-s3-upload-cleanup\n```\n\nFor help setting up [Amazon s3](https://aws.amazon.com/s3/) you can check out this [tutorial](https://laracasts.com/series/multitenancy-in-practice/episodes/7) by Kevin McKee, a laracasts instructor. This is a paid tutorial but it's worth it. I learned a lot from it. And, No I'm not affiliated with laracasts in any way. If you're having trouble setting up [Amazon s3](https://aws.amazon.com/s3/) you can contact me and I'll try to help you out. Or you can choose to use a different storage provider.\n\n\nIf you are using [forge](https://forge.laravel.com/) you can add the credentials to the server environment variables.\n\n\n\nYour application is now ready for use. Enjoy! To install it in production follow your servers specific needs.\n\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n\n\n\n\u003c!-- USAGE EXAMPLES --\u003e\n## Usage\n\n_For App examples, please refer to [WittyWorkflow](https://wittyworkflow.com/)_\n\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n\n\n\n\u003c!-- ROADMAP --\u003e\n## Roadmap\n\n1. [x] Create jetstream project\n2. [x] Dynamic hero\n3. [x] Realtime validation for all components\n4. [x] Lazy image loading on hero\n5. [x] Create role based access to team members.Non-team members do not have access to teams\n6. [x] Add wire:navigate to links for SPA functionality.\n7. [x] Staff members can create their own teams but cannot modify teams they belong to teams disabled momentarily\n8. [x] Above functionality for responsive menu\n9. [x] Disable making a user an administrator on JetstreamServiceProvider\n10. [x] Create CRUD for users. Only admin can access it\n11. [x] Create CRUD for address. Only admin can access it\n12. [x] Create CRUD for landingpage hero. Only admin can access it\n13. [x] Create appointments component\n14. [x] Create CRUD for appointments. Only admin can access it\n15. [x] Create CRUD for services. Only admin can access it\n16. [x] Create CRUD for opening hours. Only admin can access it\n17. [x] Create CRUD for gallery. Only admin can access it\n18. [x] Create CRUD for socials. Only admin can access it\n19. [x] complete public email form\n20. [x] complete footer\n22. [x] create newsletter (newsletter created but needs changes to be made)\n23. [x] make CRUD for SEO\n24. [x] install Schema.org for better SEO\n25. [ ] make PWA for the website\n26. [ ] make a blog\n27. [ ] make a shop\n28. [ ] make a forum\n29. [x] make a chat\n30. [ ] make a calendar\n31. [ ] make a CRM\n32. [ ] make a project management tool\n33. [ ] make a time tracking tool\n34. [ ] make a billing tool\n35. [ ] make a file sharing tool\n36. [ ] make a video conferencing tool\n37. [ ] make a note taking tool\n38. [ ] make a task management tool\n39. [ ] Create AI chatbot\n40. [x] Create dark/light mode toggle\n41. [ ] Integrate google analytics\n\n\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n\n\n\n\u003c!-- CONTRIBUTING --\u003e\n## Contributing\n\nContributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are **greatly appreciated**.\n\nIf you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag \"enhancement\".\nDon't forget to give the project a star! Thanks again!\n\n1. Fork the Project\n2. Create your Feature Branch (`git checkout -b feature/AmazingFeature`)\n3. Commit your Changes (`git commit -m 'Add some AmazingFeature'`)\n4. Push to the Branch (`git push origin feature/AmazingFeature`)\n5. Open a Pull Request\n\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n\n\n\n\u003c!-- LICENSE --\u003e\n## License\n\nDistributed under the MIT License. See `LICENSE` for more information.\n\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n\n\n\n\u003c!-- CONTACT --\u003e\n## Contact\n\nKristi Tanellari - [@TanellariKristi](https://twitter.com/TanellariKristi) - tanellari@gmail.com\n\nProject Link: [https://github.com/kristi11/wittyworkflow/](https://github.com/kristi11/wittyworkflow/)\n\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n\n\n\n\u003c!-- ACKNOWLEDGMENTS --\u003e\n## Acknowledgments\n\nI've included a few of my favorite links to kick things off!\n\n* [Laravel](https://laravel.com)\n* [Livewire](https://livewire.laravel.com)\n* [Tailwind CSS](https://tailwindcss.com)\n* [README Template](https://github.com/othneildrew/Best-README-Template/)\n* [Schema.org](https://schema.org)\n* [Img Shields](https://shields.io)\n* [Choose an Open Source License](https://choosealicense.com)\n* [GitHub Emoji Cheat Sheet](https://www.webpagefx.com/tools/emoji-cheat-sheet)\n* [Malven's Flexbox Cheatsheet](https://flexbox.malven.co/)\n* [Malven's Grid Cheatsheet](https://grid.malven.co/)\n* [Img Shields](https://shields.io)\n* [GitHub Pages](https://pages.github.com)\n\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n\n\n\n\u003c!-- MARKDOWN LINKS \u0026 IMAGES --\u003e\n\u003c!-- https://www.markdownguide.org/basic-syntax/#reference-style-links --\u003e\n[linkedin-shield]: https://img.shields.io/badge/-LinkedIn-black.svg?style=for-the-badge\u0026logo=linkedin\u0026colorB=555\n[linkedin-url]: https://linkedin.com/in/othneildrew\n[product-screenshot]: public/Screenshot-wittyworkflow.png\n[Laravel.com]: https://img.shields.io/badge/Laravel-FF2D20?style=for-the-badge\u0026logo=laravel\u0026logoColor=white\n[Laravel-url]: https://laravel.com\n[Livewire.laravel.com]: https://img.shields.io/badge/Livewire-E05890?style=for-the-badge\u0026logo=livewire\u0026logoColor=white\n[Livewire-url]: https://livewire.laravel.com\n[tailwindcss.com]: https://img.shields.io/badge/Tailwind_CSS-38B2AC?style=for-the-badge\u0026logo=tailwind-css\u0026logoColor=white\n[tailwindcss-url]: https://tailwindcss.com\n[Amazon s3]: https://img.shields.io/badge/Amazon_AWS-232F3E?style=for-the-badge\u0026logo=amazon-aws\u0026logoColor=white\n[Amazon s3-url]: https://aws.amazon.com/s3/\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkristi11%2Fwittyworkflow","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fkristi11%2Fwittyworkflow","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkristi11%2Fwittyworkflow/lists"}