@operato/popup 8.0.0-beta.0 → 8.0.0-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,42 +0,0 @@
1
- <!DOCTYPE html>
2
- <html lang="en-GB">
3
- <head>
4
- <meta charset="utf-8" />
5
- <style>
6
- body {
7
- background: #fafafa;
8
- }
9
-
10
- #demo {
11
- height: 1000px;
12
- background-color: lightgray;
13
- text-align: center;
14
- vertical-align: middle;
15
- margin: 100px;
16
- }
17
- </style>
18
- </head>
19
- <body>
20
- <div id="demo"></div>
21
-
22
- <script type="module">
23
- import { html, render } from 'lit'
24
- import '../dist/src/ox-popup.js'
25
- import { OxPopup } from '../dist/src/ox-popup.js'
26
-
27
- const parent = document.querySelector('#demo')
28
- parent.addEventListener('click', function (e) {
29
- OxPopup.open({
30
- template: html`<img
31
- src=""
32
- />`,
33
- top: e.clientY,
34
- left: e.clientX,
35
- parent
36
- })
37
- })
38
-
39
- render(html`clike anywhere in this box to popup mini.`, parent)
40
- </script>
41
- </body>
42
- </html>
package/src/index.ts DELETED
@@ -1,7 +0,0 @@
1
- export * from './ox-popup.js'
2
- export * from './ox-popup-list.js'
3
- export * from './ox-popup-menu.js'
4
- export * from './ox-popup-menuitem.js'
5
- export * from './ox-prompt.js'
6
-
7
- export * from './open-popup.js'
package/src/open-popup.ts DELETED
@@ -1,166 +0,0 @@
1
- import './ox-floating-overlay.js'
2
-
3
- import { html, render, TemplateResult } from 'lit'
4
-
5
- import { OxFloatingOverlay } from './ox-floating-overlay.js'
6
-
7
- /**
8
- * Options for popup
9
- *
10
- * @typedef {Object} PopupOptions
11
- * @property {String} [title] - popup title
12
- * @property {'center' | 'next' | 'edge'} [hovering] - hovering position (default: 'center'). 'edge' : edge of the HEADERBAR, 'next' : next of the clicked position.
13
- * @property {'large' | 'medium' | small'} [size] - popup size
14
- * @property {Boolean} [closable] - set whether the close 'X' button is shown on top-right most position (default true)
15
- * @property {Boolean} [escapable] - set whether the close popup with 'ESC' key (default true)
16
- * @property {Boolean} [backdrop] - set whether to do background masking around the pop-up. If true, it becomes modal (default true)
17
- * @property {Boolean} [movable] - set whether to be able to movable by the gesture dragging on header once the hovering option is 'center'
18
- * @property {String} [help] - inline help link
19
- */
20
- export type PopupOptions = {
21
- title?: string
22
- hovering?: 'center' | 'next' | 'edge'
23
- size?: 'large' | 'medium' | 'small'
24
- closable?: boolean
25
- escapable?: boolean
26
- backdrop?: boolean
27
- movable?: boolean
28
- help?: string
29
- search?: {
30
- value?: string
31
- handler?: (closure: any, value: string) => void
32
- placeholder?: string
33
- autofocus?: boolean
34
- }
35
- filter?: {
36
- handler?: (closure: any) => void
37
- }
38
- }
39
-
40
- /**
41
- * Popup handle object that will be returned openPopup
42
- *
43
- * @typedef {Object} PopupHandle
44
- * @property {String} [name] - popup instance name
45
- * @property {Function} [close] - call this function to close the popup.
46
- * @property {Boolean} [closed] - state telling whether the popup is closed or not.
47
- * @property {Function} [onclosed] - set callback function on close. It will be called when the popup about to close.
48
- */
49
- export type PopupHandle = {
50
- name: string
51
- close: () => void
52
- closed: boolean
53
- onclosed?: () => void
54
- }
55
-
56
- /*
57
- * popup handling
58
- *
59
- * popup은 overlay의 특별한 형태이다.
60
- * popup은 open될 때, viewpart를 append 하며, close 될 때 viewpart를 remove 한다.
61
- * - name: '$popup-${popupSequence}'
62
- * - position: VIEWPART_POSITION_HEADERBAR
63
- * - hovering: 'center' | 'next' | 'edge'
64
- */
65
- var popupSequence = 0
66
-
67
- /**
68
- * default openPopup implementation for operato application environment
69
- *
70
- * @param {*} template html template to be rendered inside the popup
71
- * @param {PopupOptions} options
72
- * @returns popup handle object. This object is used to close the popup.
73
- */
74
- function defaultOpenPopup(template: TemplateResult, options: PopupOptions = {}): PopupHandle {
75
- const {
76
- title,
77
- size = 'large',
78
- closable = false,
79
- escapable = false,
80
- help,
81
- hovering,
82
- backdrop,
83
- movable = false,
84
- search,
85
- filter
86
- } = options
87
- const name = `$popup-${popupSequence++}`
88
-
89
- render(
90
- html`
91
- <ox-floating-overlay
92
- id=${name}
93
- name=${name}
94
- .backdrop=${backdrop}
95
- direction="down"
96
- .hovering=${hovering}
97
- .title=${title || ''}
98
- .help=${help}
99
- .size=${size}
100
- .closable=${closable}
101
- .historical=${false}
102
- .movable=${movable}
103
- .search=${search}
104
- .filter=${filter}
105
- >${template}</ox-floating-overlay
106
- >
107
- `,
108
- document.body
109
- )
110
-
111
- requestAnimationFrame(() => {
112
- dispatchEvent(new Event('resize'))
113
- })
114
-
115
- const popupHandle = {
116
- name,
117
- close: () => {
118
- const popup = document.body.querySelector(`#${name}`) as OxFloatingOverlay
119
- popup?.close()
120
- popupHandle.onclosed && popupHandle.onclosed()
121
- },
122
- closed: false
123
- } as PopupHandle
124
-
125
- return popupHandle
126
- }
127
-
128
- var openPopupImpl: (template: TemplateResult, options: PopupOptions) => PopupHandle = defaultOpenPopup
129
-
130
- /**
131
- * replace default openPopup implementation
132
- *
133
- * @param {(template: TemplateResult, options: PopupOptions) => PopupHandle} implementation
134
- */
135
- export function setOpenPopupImplementation(
136
- implementation: (template: TemplateResult, options: PopupOptions) => PopupHandle
137
- ) {
138
- openPopupImpl = implementation
139
- }
140
-
141
- /**
142
- * open popup out of operato application environment
143
- *
144
- * @param {*} template html template to be rendered inside the popup
145
- * @param {PopupOptions} options
146
- * @returns popup handle object. This object is used to close the popup.
147
- */
148
- export const openPopup = (template: TemplateResult, options: PopupOptions = {}): PopupHandle => {
149
- return openPopupImpl(template, options)
150
- }
151
-
152
- /**
153
- * open popup out of operato application environment
154
- *
155
- * @param {*} template html template to be rendered inside the popup
156
- * @param {PopupOptions} options
157
- * @returns popup handle object. This object is used to close the popup.
158
- */
159
- export const closePopup = (element: HTMLElement): void => {
160
- element.dispatchEvent(
161
- new CustomEvent('close-overlay', {
162
- bubbles: true,
163
- composed: true
164
- })
165
- )
166
- }