sp-dev-fx-webparts/samples/react-rhythm-of-business-ca...
Hugo Bernier 92f0621eb2 Updated readme, sample.json, devcontainer 2024-09-28 21:42:59 -04:00
..
.devcontainer Updated readme, sample.json, devcontainer 2024-09-28 21:42:59 -04:00
assets Updated readme, sample.json, devcontainer 2024-09-28 21:42:59 -04:00
build
config fix related to description field rich text 2024-09-27 17:56:35 +05:30
documentation Fixing #3658 - RoB Calendar sample - event time changes after page refresh (#5) 2023-05-10 13:04:52 -07:00
mock_modules/@microsoft
src fix related to description field rich text 2024-09-27 17:56:35 +05:30
teams
.editorconfig
.eslintrc.js
.gitattributes
.gitignore
.nvmrc pushing the enhancement versions 2024-09-13 20:37:35 +05:30
.yo-rc.json
README.md Updated readme, sample.json, devcontainer 2024-09-28 21:42:59 -04:00
environments.json
gulpfile.js
jest.config.js
jest.setup.localization-mocks.ts
package-lock.json Updated readme, sample.json, devcontainer 2024-09-28 21:42:59 -04:00
package.json fix related to description field rich text 2024-09-27 17:56:35 +05:30
tsconfig.json

README.md

Rhythm of Business Calendar

Summary

This sample is the source code for the Rhythm of Business Calendar app and is intended to demonstrate patterns and practices for building enterprise apps on the SharePoint platform.

This application requires below Graph API Permissions-

Send Approval notifications to approvers over teams in personal chat

  1. Chat.Create - It is required for creating the chat and getting the chat id for sending an adaptive card to the approver.
  2. ChatMessage.Send - It is required for sending the adaptive card (with @mention activity feed) to all the approvers whenever any event is created with approval rule applied for any refiner.

Share event details to teams channel where the app is installed

  1. ChannelMessage.Send - It is required for sharing the event details on click of "Share" button into the same teams channel in which the app is added.

Note: Sharing events details to teams channel feature will be disabled if the web part is installed on a SharePoint page.

versions

node v16.15.1 npm 8.13.2 spfx 1.15.0 TypeScript 4.5

Rhythm of Business (RoB) Calendar keeps you on top of your business goals by managing all team and organizational events seamlessly. Simplify and expedite the coordination and planning process for your team and subgroups with the help of color-coded events, approval workflow, refiners and confidential events. Ideal for Chiefs of Staff, Executive Assistants, or anyone who manages a team calendar, you can empower your teams by enabling better insights on your business goals and team events.

Month view
Screenshot of month view

View event details
Screenshot of view event panel

Edit refiner
Screenshot of edit refiner panel

Compatibility

⚠️ Important
Every SPFx version is only compatible with specific version(s) of Node.js. In order to be able to build this sample, please ensure that the version of Node on your workstation matches one of the versions listed in this section. This sample will not work on a different version of Node.
Refer to https://aka.ms/spfx-matrix for more information on SPFx compatibility.

SPFx 1.15 Node.js v16 Compatible with SharePoint Online Does not work with SharePoint 2019 Does not work with SharePoint 2016 (Feature Pack 2) Local Workbench Unsupported Hosted Workbench Compatible Compatible with Remote Containers Teams Yes: Designed for Microsoft Teams

Applies to

Get your own free development tenant by subscribing to Microsoft 365 developer program

Contributors

Version history

Version Date Comments
1.0 September 26, 2022 Initial release
5.0.1 September 16, 2024 Enhancement release

Minimal path to awesome

  • Clone this repository (or download this solution as a .ZIP file then unzip it)
  • From your command line, change your current directory to the directory containing this sample (react-rhythm-of-business-calendar, located under samples)
  • in the command line run:
    • npm install
    • gulp serve --nobrowser

Features

This sample is a complete app that demonstrates the "SPFx Solution Accelerator" framework, along with patterns and practices for building enterprise-class apps on SharePoint. Inspired by Domain Driven Design and Onion Architecture, this accelerator has evolved since SPFx v1.0, and we want to share it with the world!

At a high-level, the accelerator includes the following features:

  • Prescribed solution structure separates web parts, components, model, services, and schema (data) layers
  • Robust entity domain model with relationships, validation, change tracking, and text search
  • Robust schema provisioning and versioning; use SharePoint lists as a simple relational database
  • Services for interacting with SharePoint, timezones, domain isolation, and users and groups, plus patterns for building custom services for app-specific logic
  • Component library with customizable wizard, panel/dialog for quickly building view/edit screens, validation, and more
  • Live Update feature ensures users are always working with the latest data without manually reloading the page
  • Built on the latest SPFx with TypeScript, React, and Fluent UI, plus PnPjs, Moment.js, Lodash, and Jest

A deep dive into the various features of the accelerator can be found in the documentation folder.

Help

We do not support samples, but this community is always willing to help, and we want to improve these samples. We use GitHub to track issues, which makes it easy for community members to volunteer their time and help resolve issues.

If you're having issues building the solution, please run spfx doctor from within the solution folder to diagnose incompatibility issues with your environment.

You can try looking at issues related to this sample to see if anybody else is having the same issues.

You can also try looking at discussions related to this sample and see what the community is saying.

If you encounter any issues using this sample, create a new issue.

For questions regarding this sample, create a new question.

Finally, if you have an idea for improvement, make a suggestion.

Disclaimer

THIS CODE IS PROVIDED AS IS WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING ANY IMPLIED WARRANTIES OF FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABILITY, OR NON-INFRINGEMENT.