From 08bfb9210b601107d6701c77ee42e8a0686da38b Mon Sep 17 00:00:00 2001 From: TemuulenBM Date: Tue, 7 Nov 2023 10:27:17 +0800 Subject: [PATCH 1/5] Initializing and starting the development of the `` component --- addon/components/full-calendar.hbs | 1 + addon/components/full-calendar.js | 43 ++++++++++++++++ app/components/full-calendar.js | 1 + package.json | 9 ++-- pnpm-lock.yaml | 51 +++++++++++++++++++ .../components/full-calendar-test.js | 26 ++++++++++ 6 files changed, 128 insertions(+), 3 deletions(-) create mode 100644 addon/components/full-calendar.hbs create mode 100644 addon/components/full-calendar.js create mode 100644 app/components/full-calendar.js create mode 100644 tests/integration/components/full-calendar-test.js diff --git a/addon/components/full-calendar.hbs b/addon/components/full-calendar.hbs new file mode 100644 index 0000000..a8ad7e5 --- /dev/null +++ b/addon/components/full-calendar.hbs @@ -0,0 +1 @@ +
\ No newline at end of file diff --git a/addon/components/full-calendar.js b/addon/components/full-calendar.js new file mode 100644 index 0000000..88db6f2 --- /dev/null +++ b/addon/components/full-calendar.js @@ -0,0 +1,43 @@ +import Component from '@glimmer/component'; +import { tracked } from '@glimmer/tracking'; +import { action } from '@ember/object'; +import { Calendar } from '@fullcalendar/core'; +import dayGridPlugin from '@fullcalendar/daygrid'; +import interactionPlugin from '@fullcalendar/interaction'; + +export default class FullCalendarComponent extends Component { + /** + * @var {HTMLElement} calendarEl + */ + @tracked calendarEl; + + /** + * @var {Calendar} calendar + * @package @fullcalendar/core + */ + @tracked calendar; + + /** + * Initializes and renders the calendar component + * + * @param {HTMLElement} calendarEl + */ + @action setupCalendar(calendarEl) { + // track calendar htmlelement + this.calendarEl = calendarEl; + + // initialize calendar + this.calendar = new Calendar(calendarEl, { + plugins: [dayGridPlugin, interactionPlugin], + initialView: 'dayGridMonth', + headerToolbar: { + left: 'prev,next today', + center: 'title', + right: 'dayGridMonth,timeGridWeek,listWeek', + }, + }); + + // render calendar + this.calendar.render(); + } +} diff --git a/app/components/full-calendar.js b/app/components/full-calendar.js new file mode 100644 index 0000000..424bf0e --- /dev/null +++ b/app/components/full-calendar.js @@ -0,0 +1 @@ +export { default } from '@fleetbase/ember-ui/components/full-calendar'; diff --git a/package.json b/package.json index a0d7798..99f1728 100644 --- a/package.json +++ b/package.json @@ -41,9 +41,14 @@ "@fortawesome/fontawesome-svg-core": "^6.4.0", "@fortawesome/free-brands-svg-icons": "^6.4.0", "@fortawesome/free-solid-svg-icons": "^6.4.0", + "@fullcalendar/core": "^6.1.9", + "@fullcalendar/daygrid": "^6.1.9", + "@fullcalendar/interaction": "^6.1.9", "@makepanic/ember-power-calendar-date-fns": "^0.4.2", + "@tailwindcss/forms": "^0.5.3", "air-datepicker": "^3.3.5", "autonumeric": "^4.6.2", + "autoprefixer": "^10.4.15", "broccoli-funnel": "^3.0.8", "broccoli-merge-trees": "^4.2.0", "chart.js": "^4.2.1", @@ -80,15 +85,13 @@ "ember-wormhole": "^0.6.0", "imask": "^6.4.3", "intl-tel-input": "^18.1.3", - "autoprefixer": "^10.4.15", "postcss-at-rules-variables": "^0.3.0", "postcss-conditionals-renewed": "^1.0.0", "postcss-each": "^1.1.0", "postcss-import": "^15.1.0", "postcss-mixins": "^9.0.4", "postcss-preset-env": "^9.1.1", - "tailwindcss": "^3.1.8", - "@tailwindcss/forms": "^0.5.3" + "tailwindcss": "^3.1.8" }, "devDependencies": { "@ember/optional-features": "^2.0.0", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index fa03a4e..6a7efbd 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -1,5 +1,9 @@ lockfileVersion: '6.0' +settings: + autoInstallPeers: true + excludeLinksFromLockfile: false + dependencies: '@ember/render-modifiers': specifier: ^2.0.4 @@ -28,6 +32,15 @@ dependencies: '@fortawesome/free-solid-svg-icons': specifier: ^6.4.0 version: 6.4.0 + '@fullcalendar/core': + specifier: ^6.1.9 + version: 6.1.9 + '@fullcalendar/daygrid': + specifier: ^6.1.9 + version: 6.1.9(@fullcalendar/core@6.1.9) + '@fullcalendar/interaction': + specifier: ^6.1.9 + version: 6.1.9(@fullcalendar/core@6.1.9) '@makepanic/ember-power-calendar-date-fns': specifier: ^0.4.2 version: 0.4.2 @@ -2211,6 +2224,28 @@ packages: '@fortawesome/fontawesome-common-types': 6.4.0 dev: false + /@fullcalendar/core@6.1.9: + resolution: {integrity: sha512-eeG+z9BWerdsU9Ac6j16rpYpPnE0wxtnEHiHrh/u/ADbGTR3hCOjCD9PxQOfhOTHbWOVs7JQunGcksSPu5WZBQ==} + dependencies: + preact: 10.12.1 + dev: false + + /@fullcalendar/daygrid@6.1.9(@fullcalendar/core@6.1.9): + resolution: {integrity: sha512-o/6joH/7lmVHXAkbaa/tUbzWYnGp/LgfdiFyYPkqQbjKEeivNZWF1WhHqFbhx0zbFONSHtrvkjY2bjr+Ef2quQ==} + peerDependencies: + '@fullcalendar/core': ~6.1.9 + dependencies: + '@fullcalendar/core': 6.1.9 + dev: false + + /@fullcalendar/interaction@6.1.9(@fullcalendar/core@6.1.9): + resolution: {integrity: sha512-I3FGnv0kKZpIwujg3HllbKrciNjTqeTYy3oJG226oAn7lV6wnrrDYMmuGmA0jPJAGN46HKrQqKN7ItxQRDec4Q==} + peerDependencies: + '@fullcalendar/core': ~6.1.9 + dependencies: + '@fullcalendar/core': 6.1.9 + dev: false + /@glimmer/compiler@0.27.0: resolution: {integrity: sha512-SJUUEpkFCL+GTpEK6c2EhZQJant67ahGLF6M1xRmIsq6E+AtbHgu+y8mWvFbtpb7lx4gqNKpXSEwlHUTTuxVGw==} dependencies: @@ -3258,6 +3293,7 @@ packages: /async-each@1.0.6: resolution: {integrity: sha512-c646jH1avxr+aVpndVMeAfYw7wAa6idufrlN3LPA4PmKS0QEGp6PIC9nwz0WQkkvBGAMEki3pFdtxaF39J9vvg==} + requiresBuild: true dev: false optional: true @@ -3661,6 +3697,7 @@ packages: /binary-extensions@1.13.1: resolution: {integrity: sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw==} engines: {node: '>=0.10.0'} + requiresBuild: true dev: false optional: true @@ -3675,6 +3712,7 @@ packages: /bindings@1.5.0: resolution: {integrity: sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==} + requiresBuild: true dependencies: file-uri-to-path: 1.0.0 dev: false @@ -4672,6 +4710,7 @@ packages: /chokidar@2.1.8: resolution: {integrity: sha512-ZmZUazfOzf0Nve7duiCKD23PFSCs4JPoYyccjUFF3aQkQadqBhfzhjkwBH2mNOG9cTBwhamM37EIsIkZw3nRgg==} deprecated: Chokidar 2 does not receive security updates since 2019. Upgrade to chokidar 3 with 15x fewer dependencies + requiresBuild: true dependencies: anymatch: 2.0.0 async-each: 1.0.6 @@ -7834,6 +7873,7 @@ packages: /file-uri-to-path@1.0.0: resolution: {integrity: sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==} + requiresBuild: true dev: false optional: true @@ -8337,6 +8377,7 @@ packages: /glob-parent@3.1.0: resolution: {integrity: sha512-E8Ak/2+dZY6fnzlR7+ueWvhsH1SjHr4jjss4YS/h4py44jY9MhK/VFdaZJAWDz6BbL21KeteKxFSFpq8OS5gVA==} + requiresBuild: true dependencies: is-glob: 3.1.0 path-dirname: 1.0.2 @@ -8925,6 +8966,7 @@ packages: /is-binary-path@1.0.1: resolution: {integrity: sha512-9fRVlXc0uCxEDj1nQzaWONSpbTfx0FmJfzHF7pwlI8DkWGoHBBea4Pg5Ky0ojwwxQmnSifgbKkI06Qv0Ljgj+Q==} engines: {node: '>=0.10.0'} + requiresBuild: true dependencies: binary-extensions: 1.13.1 dev: false @@ -9040,6 +9082,7 @@ packages: /is-glob@3.1.0: resolution: {integrity: sha512-UFpDDrPgM6qpnFNI+rh/p3bUaq9hKLZN8bMUWzxmcnZVS3omf4IPK+BrewlnWjO1WmUsMYuSjKh4UJuV4+Lqmw==} engines: {node: '>=0.10.0'} + requiresBuild: true dependencies: is-extglob: 2.1.1 dev: false @@ -10064,6 +10107,7 @@ packages: /nan@2.18.0: resolution: {integrity: sha512-W7tfG7vMOGtD30sHoZSSc/JVYiyDPEyQVso/Zz+/uQd0B0L46gtC+pHha5FFMRpil6fm/AoEcRWyOVi4+E/f8w==} + requiresBuild: true dev: false optional: true @@ -10576,6 +10620,7 @@ packages: /path-dirname@1.0.2: resolution: {integrity: sha512-ALzNPpyNq9AqXMBjeymIjFDAkAFH06mHJH/cSBHAgU0s4vfpBn6b2nf8tiRLvagKD8RbTpq2FKTBg7cl9l3c7Q==} + requiresBuild: true dev: false optional: true @@ -11235,6 +11280,10 @@ packages: picocolors: 1.0.0 source-map-js: 1.0.2 + /preact@10.12.1: + resolution: {integrity: sha512-l8386ixSsBdbreOAkqtrwqHwdvR35ID8c3rKPa8lCWuO86dBi32QWHV4vfsZK1utLLFMvw+Z5Ad4XLkZzchscg==} + dev: false + /prelude-ls@1.2.1: resolution: {integrity: sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==} engines: {node: '>= 0.8.0'} @@ -11526,6 +11575,7 @@ packages: /readdirp@2.2.1: resolution: {integrity: sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==} engines: {node: '>=0.10'} + requiresBuild: true dependencies: graceful-fs: 4.2.11 micromatch: 3.1.10 @@ -13217,6 +13267,7 @@ packages: /upath@1.2.0: resolution: {integrity: sha512-aZwGpamFO61g3OlfT7OQCHqhGnW43ieH9WZeP7QxN/G/jS4jfqUkZxoryvJgVPEcrl5NL/ggHsSmLMHuH64Lhg==} engines: {node: '>=4'} + requiresBuild: true dev: false optional: true diff --git a/tests/integration/components/full-calendar-test.js b/tests/integration/components/full-calendar-test.js new file mode 100644 index 0000000..170cd38 --- /dev/null +++ b/tests/integration/components/full-calendar-test.js @@ -0,0 +1,26 @@ +import { module, test } from 'qunit'; +import { setupRenderingTest } from 'dummy/tests/helpers'; +import { render } from '@ember/test-helpers'; +import { hbs } from 'ember-cli-htmlbars'; + +module('Integration | Component | full-calendar', function (hooks) { + setupRenderingTest(hooks); + + test('it renders', async function (assert) { + // Set any properties with this.set('myProperty', 'value'); + // Handle any actions with this.set('myAction', function(val) { ... }); + + await render(hbs``); + + assert.dom(this.element).hasText(''); + + // Template block usage: + await render(hbs` + + template block text + + `); + + assert.dom(this.element).hasText('template block text'); + }); +}); From 183628e38e4dc430390f95bc29db2b1f89bcea65 Mon Sep 17 00:00:00 2001 From: TemuulenBM Date: Tue, 7 Nov 2023 17:37:38 +0800 Subject: [PATCH 2/5] full-calendar --- addon/components/full-calendar.hbs | 2 +- addon/components/full-calendar.js | 75 ++++++++++++++++++- addon/components/full-calendar/draggable.hbs | 3 + addon/components/full-calendar/draggable.js | 18 +++++ addon/helpers/json-hash.js | 5 +- addon/styles/addon.css | 1 + addon/styles/components/full-calendar.css | 45 +++++++++++ app/components/full-calendar/draggable.js | 1 + .../full-calendar/draggable-test.js | 26 +++++++ 9 files changed, 170 insertions(+), 6 deletions(-) create mode 100644 addon/components/full-calendar/draggable.hbs create mode 100644 addon/components/full-calendar/draggable.js create mode 100644 addon/styles/components/full-calendar.css create mode 100644 app/components/full-calendar/draggable.js create mode 100644 tests/integration/components/full-calendar/draggable-test.js diff --git a/addon/components/full-calendar.hbs b/addon/components/full-calendar.hbs index a8ad7e5..d61be8a 100644 --- a/addon/components/full-calendar.hbs +++ b/addon/components/full-calendar.hbs @@ -1 +1 @@ -
\ No newline at end of file +
\ No newline at end of file diff --git a/addon/components/full-calendar.js b/addon/components/full-calendar.js index 88db6f2..a3f1512 100644 --- a/addon/components/full-calendar.js +++ b/addon/components/full-calendar.js @@ -1,6 +1,7 @@ import Component from '@glimmer/component'; import { tracked } from '@glimmer/tracking'; import { action } from '@ember/object'; +import { classify } from '@ember/string'; import { Calendar } from '@fullcalendar/core'; import dayGridPlugin from '@fullcalendar/daygrid'; import interactionPlugin from '@fullcalendar/interaction'; @@ -17,27 +18,95 @@ export default class FullCalendarComponent extends Component { */ @tracked calendar; + /** + * Default events to trigger for + * @var {Array} + */ + @tracked events = ['dateClick', 'drop', 'eventReceive', 'eventClick', 'eventDragStop', 'eventDrop', 'eventAdd', 'eventChange', 'eventRemove']; + + /** + * Tracked calendar event listeners + * @var {Array} + */ + @tracked _listeners = []; + /** * Initializes and renders the calendar component - * - * @param {HTMLElement} calendarEl + * + * @param {HTMLElement} calendarEl */ @action setupCalendar(calendarEl) { // track calendar htmlelement this.calendarEl = calendarEl; + // get events + let events = this.args.events || []; + // initialize calendar this.calendar = new Calendar(calendarEl, { + events, plugins: [dayGridPlugin, interactionPlugin], initialView: 'dayGridMonth', + editable:true, headerToolbar: { left: 'prev,next today', center: 'title', - right: 'dayGridMonth,timeGridWeek,listWeek', + right: '', }, }); + console.log('[calender]', this.calendar); + + // trigger callback on initialize + if (typeof this.args.onInit === 'function') { + this.args.onInit(this.calendar); + } + // render calendar this.calendar.render(); + + // listen for events + this.createCalendarEventListeners(); + } + + triggerCalendarEvent(eventName, ...params) { + if (typeof this[eventName] === 'function') { + this[eventName](...params); + } + + if (typeof this.args[eventName] === 'function') { + this.args[eventName](...params); + } + } + + createCalendarEventListeners() { + for (let i = 0; i < this.events.length; i++) { + const eventName = this.events.objectAt(i); + const callbackName = `on${classify(eventName)}`; + + if (typeof this.args[callbackName] === 'function') { + // track for destroy purposes + this._listeners.pushObject({ + eventName, + callbackName, + }); + + // create listener + this.calendar.on(eventName, this.triggerCalendarEvent.bind(this, callbackName)); + } + } + + // check for custom events + // @todo + } + + destroyCalendarEventListeners() { + for (let i = 0; i < this._listeners.length; i++) { + const listener = this._listeners.objectAt(i); + const { eventName, callbackName } = listener; + + // kill listener + this.calendar.off(eventName, this.triggerCalendarEvent.bind(this, callbackName)); + } } } diff --git a/addon/components/full-calendar/draggable.hbs b/addon/components/full-calendar/draggable.hbs new file mode 100644 index 0000000..2f2af9f --- /dev/null +++ b/addon/components/full-calendar/draggable.hbs @@ -0,0 +1,3 @@ +
+ {{yield}} +
\ No newline at end of file diff --git a/addon/components/full-calendar/draggable.js b/addon/components/full-calendar/draggable.js new file mode 100644 index 0000000..d59eb5a --- /dev/null +++ b/addon/components/full-calendar/draggable.js @@ -0,0 +1,18 @@ +import Component from '@glimmer/component'; +import { tracked } from '@glimmer/tracking'; +import { action } from '@ember/object'; +import { Draggable } from '@fullcalendar/interaction'; + +export default class DraggableFullcalendarEventComponent extends Component { + @tracked draggable; + @tracked eventData = {}; + + constructor() { + super(...arguments); + this.eventData = this.args.eventData ?? {}; + } + + @action makeDraggable(element) { + this.draggable = new Draggable(element); + } +} diff --git a/addon/helpers/json-hash.js b/addon/helpers/json-hash.js index 3f470d0..739ba0e 100644 --- a/addon/helpers/json-hash.js +++ b/addon/helpers/json-hash.js @@ -1,5 +1,6 @@ import { helper } from '@ember/component/helper'; -export default helper(function jsonHash(positional /*, named*/) { - return positional; +export default helper(function jsonHash(positional, named) { + let json = JSON.stringify(named); + return json; }); diff --git a/addon/styles/addon.css b/addon/styles/addon.css index 1837c6b..70788ec 100644 --- a/addon/styles/addon.css +++ b/addon/styles/addon.css @@ -38,6 +38,7 @@ @import 'components/dashboard.css'; @import 'components/kanban.css'; @import 'components/notification-tray.css'; +@import 'components/full-calendar.css'; /** Third party */ @import 'air-datepicker/air-datepicker.css'; diff --git a/addon/styles/components/full-calendar.css b/addon/styles/components/full-calendar.css new file mode 100644 index 0000000..ade67c8 --- /dev/null +++ b/addon/styles/components/full-calendar.css @@ -0,0 +1,45 @@ +.fleetbase-full-calendar .fc-toolbar-title { + @apply text-base text-gray-900; +} + +body[data-theme='dark'] .fleetbase-full-calendar.fc .fc-toolbar-title { + @apply text-gray-200; +} + +.fleetbase-full-calendar.fc td, +.fleetbase-full-calendar.fc th { + @apply border-gray-400; +} + +body[data-theme='dark'] .fleetbase-full-calendar.fc td, +body[data-theme='dark'] .fleetbase-full-calendar.fc th { + @apply border-gray-700; +} + +.fleetbase-full-calendar.fc table.fc-scrollgrid { + @apply border-gray-400; +} + +body[data-theme='dark'] .fleetbase-full-calendar.fc table.fc-scrollgrid { + @apply border-gray-700; +} + +.fleetbase-full-calendar.fc .fc-button { + @apply inline-flex items-center px-3 py-2 text-sm font-medium leading-4 transition duration-150 ease-in-out border border-transparent rounded-md; +} + +.fleetbase-full-calendar.fc .fc-button .fc-icon { + font-size: 1rem; +} + +.fleetbase-full-calendar.fc .fc-toolbar { + justify-content: start; +} + +.fleetbase-full-calendar.fc .fc-toolbar.fc-header-toolbar { + margin-bottom: 1rem; +} + +.fleetbase-full-calendar.fc .fc-toolbar > .fc-toolbar-chunk { + margin-right: 1.25rem; +} diff --git a/app/components/full-calendar/draggable.js b/app/components/full-calendar/draggable.js new file mode 100644 index 0000000..320ca98 --- /dev/null +++ b/app/components/full-calendar/draggable.js @@ -0,0 +1 @@ +export { default } from '@fleetbase/ember-ui/components/full-calendar/draggable'; diff --git a/tests/integration/components/full-calendar/draggable-test.js b/tests/integration/components/full-calendar/draggable-test.js new file mode 100644 index 0000000..39317bf --- /dev/null +++ b/tests/integration/components/full-calendar/draggable-test.js @@ -0,0 +1,26 @@ +import { module, test } from 'qunit'; +import { setupRenderingTest } from 'dummy/tests/helpers'; +import { render } from '@ember/test-helpers'; +import { hbs } from 'ember-cli-htmlbars'; + +module('Integration | Component | full-calendar/draggable', function (hooks) { + setupRenderingTest(hooks); + + test('it renders', async function (assert) { + // Set any properties with this.set('myProperty', 'value'); + // Handle any actions with this.set('myAction', function(val) { ... }); + + await render(hbs``); + + assert.dom(this.element).hasText(''); + + // Template block usage: + await render(hbs` + + template block text + + `); + + assert.dom(this.element).hasText('template block text'); + }); +}); From 3a99ee6500936d978638652c07467b63a2789785 Mon Sep 17 00:00:00 2001 From: TemuulenBM Date: Wed, 8 Nov 2023 12:35:41 +0800 Subject: [PATCH 3/5] full-calendar restyle --- addon/styles/components/full-calendar.css | 62 +++++++++++++++++++++-- 1 file changed, 58 insertions(+), 4 deletions(-) diff --git a/addon/styles/components/full-calendar.css b/addon/styles/components/full-calendar.css index ade67c8..d7bcc80 100644 --- a/addon/styles/components/full-calendar.css +++ b/addon/styles/components/full-calendar.css @@ -1,5 +1,5 @@ .fleetbase-full-calendar .fc-toolbar-title { - @apply text-base text-gray-900; + @apply text-base text-gray-900 font-semibold; } body[data-theme='dark'] .fleetbase-full-calendar.fc .fc-toolbar-title { @@ -8,7 +8,7 @@ body[data-theme='dark'] .fleetbase-full-calendar.fc .fc-toolbar-title { .fleetbase-full-calendar.fc td, .fleetbase-full-calendar.fc th { - @apply border-gray-400; + @apply border-gray-200; } body[data-theme='dark'] .fleetbase-full-calendar.fc td, @@ -17,7 +17,7 @@ body[data-theme='dark'] .fleetbase-full-calendar.fc th { } .fleetbase-full-calendar.fc table.fc-scrollgrid { - @apply border-gray-400; + @apply border-gray-200; } body[data-theme='dark'] .fleetbase-full-calendar.fc table.fc-scrollgrid { @@ -25,7 +25,14 @@ body[data-theme='dark'] .fleetbase-full-calendar.fc table.fc-scrollgrid { } .fleetbase-full-calendar.fc .fc-button { - @apply inline-flex items-center px-3 py-2 text-sm font-medium leading-4 transition duration-150 ease-in-out border border-transparent rounded-md; + @apply inline-flex items-center px-3 py-2 text-sm font-medium leading-4 transition duration-150 ease-in-out border border-transparent rounded-md text-gray-800; + cursor: default !important; +} + +.fleetbase-full-calendar.fc .fc-button:disabled, +.fleetbase-full-calendar.fc .fc-button-primary:disabled, +body[data-theme='dark'] .fleetbase-full-calendar.fc .fc-button-primary:disabled { + @apply opacity-50 cursor-not-allowed; } .fleetbase-full-calendar.fc .fc-button .fc-icon { @@ -43,3 +50,50 @@ body[data-theme='dark'] .fleetbase-full-calendar.fc table.fc-scrollgrid { .fleetbase-full-calendar.fc .fc-toolbar > .fc-toolbar-chunk { margin-right: 1.25rem; } + +body[data-theme='dark'] .fleetbase-full-calendar.fc .fc-button-primary { + @apply text-gray-300 bg-gray-700 border-gray-900 shadow; +} + +body[data-theme='dark'] .fleetbase-full-calendar.fc .fc-button-primary:hover:not(:disabled) { + @apply text-gray-200 bg-gray-600; +} + +body[data-theme='dark'] .fleetbase-full-calendar.fc .fc-button-primary:focus { + @apply outline-0; +} + +body[data-theme='dark'] .fleetbase-full-calendar.fc .fc-button-primary:active:not(:disabled) { + @apply text-gray-300 bg-gray-600; +} + +body[data-theme='dark'] .fleetbase-full-calendar.fc .fc-button .fc-icon { + @apply text-gray-300; +} + +.fleetbase-full-calendar.fc .fc-button-primary { + @apply bg-white border-gray-300 shadow-sm text-gray-800; +} + +.fleetbase-full-calendar.fc .fc-button-primary:hover:not(:disabled) { + @apply text-gray-500 +} + +.fleetbase-full-calendar.fc .fc-button-primary:focus { + @apply border-gray-300 outline-0; +} + +.fleetbase-full-calendar.fc .fc-button-primary:active:not(:disabled) { + @apply text-gray-800 bg-gray-50; +} + +.fleetbase-full-calendar.fc .fc-button .fc-icon { + @apply text-gray-900; +} + +.fleetbase-full-calendar.fc .fc-button-primary:not(:disabled).fc-button-active:focus, +.fleetbase-full-calendar.fc .fc-button-primary:not(:disabled):active:focus, +body[data-theme='dark'] .fleetbase-full-calendar.fc .fc-button-primary:not(:disabled).fc-button-active:focus, +body[data-theme='dark'] .fleetbase-full-calendar.fc .fc-button-primary:not(:disabled):active:focus { + box-shadow: none; +} \ No newline at end of file From 26d9457adfba35e5774fa92b582762ae86de961b Mon Sep 17 00:00:00 2001 From: TemuulenBM Date: Wed, 8 Nov 2023 15:30:49 +0800 Subject: [PATCH 4/5] fixed linter issue --- addon/components/full-calendar.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/addon/components/full-calendar.js b/addon/components/full-calendar.js index a3f1512..850bad4 100644 --- a/addon/components/full-calendar.js +++ b/addon/components/full-calendar.js @@ -47,7 +47,7 @@ export default class FullCalendarComponent extends Component { events, plugins: [dayGridPlugin, interactionPlugin], initialView: 'dayGridMonth', - editable:true, + editable: true, headerToolbar: { left: 'prev,next today', center: 'title', From 02f5c15de841800c1eab23aaf83681fae269f1ef Mon Sep 17 00:00:00 2001 From: TemuulenBM Date: Wed, 8 Nov 2023 15:32:21 +0800 Subject: [PATCH 5/5] removed console log of calendar instance --- addon/components/full-calendar.js | 2 -- 1 file changed, 2 deletions(-) diff --git a/addon/components/full-calendar.js b/addon/components/full-calendar.js index 850bad4..cf97394 100644 --- a/addon/components/full-calendar.js +++ b/addon/components/full-calendar.js @@ -55,8 +55,6 @@ export default class FullCalendarComponent extends Component { }, }); - console.log('[calender]', this.calendar); - // trigger callback on initialize if (typeof this.args.onInit === 'function') { this.args.onInit(this.calendar);