/** * @copyright Copyright (c) 2023 John Molakvoæ * * @author John Molakvoæ * * @license AGPL-3.0-or-later * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . * */ import type { Node } from '@nextcloud/files' import Vue from 'vue' import SetCustomReminderModal from '../components/SetCustomReminderModal.vue' const View = Vue.extend(SetCustomReminderModal) const mount = document.createElement('div') mount.id = 'set-custom-reminder-modal' document.body.appendChild(mount) // Create a new Vue instance and mount it to our modal container const CustomReminderModal = new View({ name: 'SetCustomReminderModal', el: mount, }) export const pickCustomDate = async (node: Node): Promise => { CustomReminderModal.open(node) // Wait for the modal to close return new Promise((resolve) => { CustomReminderModal.$on('close', resolve) }) }