+
+
+ );
+
+ const { dispatch } = context.store;
+ dispatch(context.zimletRedux.actions.zimlets.addModal({ id: 'addEventModal', modal: modal }));
+ }
+
+ const handleClose = e => {
+ const { dispatch } = context.store;
+ dispatch(context.zimletRedux.actions.zimlets.addModal({ id: 'addEventModal' }));
+ }
+
+ //This shows a toaster message/notification to the user, used in case there are errors calling Google Translates
+ alert = (message) => {
+ const { dispatch } = context.store;
+ dispatch(context.zimletRedux.actions.notifications.notify({
+ message: message
+ }));
+ }
+
+ //Set bigbluebutton attendee/moderator_password on meeting and store to ldap if set-default option is checked
+ const handleSave = e => {
+ const attendeePassword = window.parent.document.getElementById('bigbluebutton_attendee_password').value;
+ const moderatorPassword = window.parent.document.getElementById('bigbluebutton_moderator_password').value;
+ const set_defaults = window.parent.document.getElementById('set_defaults').checked;
+
+ if (!moderatorPassword) {
+ alert(zimletStrings.passwordRequired);
+ return;
+ }
+ if (!attendeePassword) {
+ alert(zimletStrings.passwordRequired);
+ return;
+ }
+
+ //Update Zimlet User Properties cache in the Zimlet Context
+ zimletProperties.set('bigbluebutton_attendee_password', attendeePassword);
+ zimletProperties.set('bigbluebutton_moderator_password', moderatorPassword);
+
+ if (set_defaults) {
+ //The gql mutation that stores to ldap zimbraZimletUserProperties on the server
+ const myMutationGql = gql`
+ mutation myMutation($props: [PropertiesInput!]) {
+ modifyProps(props: $props)
+ }`;
+
+ //Use the Apollo client directly to run the query, save prop1 on the server
+ client.mutate({
+ mutation: myMutationGql,
+ variables: {
+ props: [
+ {
+ zimlet: "tk_barrydegraaff_bigbluebutton",
+ name: 'bigbluebutton_attendee_password',
+ _content: attendeePassword
+ },
+ {
+ zimlet: "tk_barrydegraaff_bigbluebutton",
+ name: 'bigbluebutton_moderator_password',
+ _content: moderatorPassword
+ }
+ ]
+ }
+ });
+ }
+
+ const { dispatch } = context.store;
+ dispatch(context.zimletRedux.actions.zimlets.addModal({ id: 'addEventModal' }));
+ }
+
+
+ return (
+
+
+
+
+
+
+
+
+
+
+
+
+
+ );
+
+}
+
+//By using compose from recompose we can apply internationalization to our Zimlet
+//https://blog.logrocket.com/using-recompose-to-write-clean-higher-order-components-3019a6daf44c/
+export default compose(
+ withIntl()
+)
+ (
+ createMore
+ )
diff --git a/src/components/more/style.less b/src/components/more/style.less
new file mode 100644
index 0000000..41d372e
--- /dev/null
+++ b/src/components/more/style.less
@@ -0,0 +1,14 @@
+.appIcon {
+ background: url() no-repeat left center;
+ padding: 5px 0 5px 25px;
+ min-height: 24px;
+ min-width: 30px;
+ background-size: 20px 20px;
+}
+
+.appLogo {
+ background: url() no-repeat left center;
+ min-width: 318px;
+ min-height: 70px;
+ background-size: 318px 70px;
+}
diff --git a/src/enhancers.js b/src/enhancers.js
new file mode 100644
index 0000000..18ef711
--- /dev/null
+++ b/src/enhancers.js
@@ -0,0 +1,16 @@
+import { withIntlWrapper } from '@zimbra-client/enhancers';
+
+/**
+ * @method withIntlWrapper
+ * accepts three arguments which can be use to load zimlet locale.
+ * @param {Object} - with following values
+ * @param {Function} importFn which returns `import` with intl locale path of the zimlet.
+ * @param {Boolean} showLoader Show loader on container or not
+ *
+ */
+export const withIntl = () => withIntlWrapper(
+ {
+ importFn: locale => import(/* webpackMode: "eager" */`./intl/${locale}.json`),
+ showLoader: false
+ }
+);
\ No newline at end of file
diff --git a/src/index.js b/src/index.js
new file mode 100644
index 0000000..1b67bb9
--- /dev/null
+++ b/src/index.js
@@ -0,0 +1,23 @@
+//Load components from Zimbra
+import { createElement } from "preact";
+import { provide } from 'preact-context-provider';
+
+//Load the createMore function from our Zimlet component
+import createMore from "./components/more";
+
+
+//Create function by Zimbra convention
+export default function Zimlet(context) {
+ //Get the 'plugins' object from context and define it in the current scope
+ const { plugins } = context;
+ const exports = {};
+
+ exports.init = function init() {
+ // The zimlet slots to load into, and what is being loaded into that slot
+ //Here we are using preact-context-provider to pass the Zimlet context to the createMore function which implements our Zimlet
+ //See: https://github.com/Zimbra/zimlet-cli/wiki/Zimlet-Context and https://github.com/synacor/preact-context-provider/
+ plugins.register('slot::calendar-appointment-edit-location', provide(context)(createMore));
+ };
+
+ return exports;
+}
diff --git a/src/intl/en_US.json b/src/intl/en_US.json
new file mode 100644
index 0000000..b905af4
--- /dev/null
+++ b/src/intl/en_US.json
@@ -0,0 +1,19 @@
+{
+ "zimbra-zimlet-bigbluebutton": {
+ "title": "BigBlueButton",
+ "dialInText": "Alternatively you can join this meeting using a telephone number and PIN. For more information visit: ",
+ "slogan": "BigBlueButton provides real-time sharing of audio, video, slides, chat, and screen.",
+ "joinHostMeeting": "Join or Host Meeting",
+ "addMeetingDetails": "Add BigBlueButton information to the Appointment",
+ "default_passwords": "Here you can set the default moderator and attendee passwords. Changes here affect only new meetings, not already planned ones.",
+ "moderator_password": "Moderator Password",
+ "attendee_password": "Attendee Password",
+ "password_required": "Please set a Moderator and Attendee Password",
+ "Meeting_Message": "To join the Meeting Online go to: [meetinglink]
You can use the following password: [passwordattendeePassword] ",
+ "set_defaults": "Set as default for future meetings",
+ "preferences": "Preferences",
+ "passwordRequired": "Please set a Moderator and Attendee Password",
+ "fail": "Failed to create BigBlueButton meeting"
+ }
+}
+
diff --git a/tsconfig.json b/tsconfig.json
new file mode 100644
index 0000000..b884ea3
--- /dev/null
+++ b/tsconfig.json
@@ -0,0 +1,6 @@
+{
+ "compilerOptions": {
+ "experimentalDecorators": true,
+ "allowJs": true
+ }
+}
diff --git a/zimlet.config.js b/zimlet.config.js
new file mode 100644
index 0000000..dae898c
--- /dev/null
+++ b/zimlet.config.js
@@ -0,0 +1,13 @@
+import path from 'path';
+
+export default function configure(config, env) {
+ //use this function to optionally mutate the webpack configuration created by zimlet-cli
+
+ //EXAMPLES
+
+ // Add a new directory Resolve "packages" as a modules directory
+ // config.resolve.modules.unshift(path.resolve(__dirname, '../../../packages'));
+
+ // Create an alias FOO to be replaced by webpack at build time from the environment variable BAR
+ // config.resolve.alias.FOO = process.env.BAR;
+}