@lynx-js/web-elements 0.8.11 → 0.10.0
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.
- package/CHANGELOG.md +42 -0
- package/dist/compat/LinearContainer/LinearContainer.d.ts +8 -0
- package/dist/compat/LinearContainer/LinearContainer.js +109 -0
- package/dist/element-reactive/bindSwitchToEventListener.d.ts +1 -0
- package/dist/element-reactive/bindSwitchToEventListener.js +23 -0
- package/dist/element-reactive/bindToAttribute.d.ts +2 -0
- package/dist/element-reactive/bindToAttribute.js +27 -0
- package/dist/element-reactive/bindToStyle.d.ts +2 -0
- package/dist/element-reactive/bindToStyle.js +21 -0
- package/dist/element-reactive/boostedQueueMicrotask.d.ts +1 -0
- package/dist/element-reactive/boostedQueueMicrotask.js +20 -0
- package/dist/element-reactive/component.d.ts +43 -0
- package/dist/element-reactive/component.js +217 -0
- package/dist/element-reactive/genDomGetter.d.ts +9 -0
- package/dist/element-reactive/genDomGetter.js +18 -0
- package/dist/element-reactive/generateRegister.d.ts +6 -0
- package/dist/element-reactive/generateRegister.js +29 -0
- package/dist/element-reactive/html.d.ts +6 -0
- package/dist/element-reactive/html.js +8 -0
- package/dist/element-reactive/index.d.ts +30 -0
- package/dist/element-reactive/index.js +28 -0
- package/dist/element-reactive/registerAttributeHandler.d.ts +12 -0
- package/dist/element-reactive/registerAttributeHandler.js +11 -0
- package/dist/element-reactive/registerEventStatusChangedHandler.d.ts +11 -0
- package/dist/element-reactive/registerEventStatusChangedHandler.js +7 -0
- package/dist/element-reactive/registerStyleChangeHandler.d.ts +2 -0
- package/dist/element-reactive/registerStyleChangeHandler.js +8 -0
- package/dist/{LynxWrapper → elements/LynxWrapper}/LynxWrapper.js +1 -1
- package/dist/elements/LynxWrapper/index.d.ts +14 -0
- package/dist/elements/LynxWrapper/index.js +18 -0
- package/dist/{ScrollView → elements/ScrollView}/FadeEdgeLengthAttribute.d.ts +3 -1
- package/dist/elements/ScrollView/FadeEdgeLengthAttribute.js +42 -0
- package/dist/{ScrollView → elements/ScrollView}/ScrollAttributes.d.ts +3 -1
- package/dist/elements/ScrollView/ScrollAttributes.js +81 -0
- package/dist/{ScrollView → elements/ScrollView}/ScrollIntoView.d.ts +1 -1
- package/dist/{ScrollView → elements/ScrollView}/ScrollIntoView.js +1 -1
- package/dist/{ScrollView → elements/ScrollView}/ScrollView.js +2 -2
- package/dist/elements/ScrollView/ScrollViewEvents.d.ts +15 -0
- package/dist/elements/ScrollView/ScrollViewEvents.js +167 -0
- package/dist/elements/ScrollView/index.d.ts +32 -0
- package/dist/elements/ScrollView/index.js +36 -0
- package/dist/{XAudioTT → elements/XAudioTT}/XAudioAttribute.d.ts +4 -1
- package/dist/elements/XAudioTT/XAudioAttribute.js +90 -0
- package/dist/{XAudioTT → elements/XAudioTT}/XAudioEvents.d.ts +1 -1
- package/dist/{XAudioTT → elements/XAudioTT}/XAudioEvents.js +1 -1
- package/dist/{XAudioTT → elements/XAudioTT}/XAudioTT.js +2 -2
- package/dist/elements/XAudioTT/index.d.ts +21 -0
- package/dist/elements/XAudioTT/index.js +25 -0
- package/dist/{XCanvas → elements/XCanvas}/CanvasAttributes.d.ts +1 -1
- package/dist/{XCanvas → elements/XCanvas}/CanvasAttributes.js +1 -1
- package/dist/{XCanvas → elements/XCanvas}/XCanvas.js +1 -1
- package/dist/elements/XCanvas/index.d.ts +14 -0
- package/dist/elements/XCanvas/index.js +18 -0
- package/dist/{XFoldViewNg → elements/XFoldViewNg}/XFoldviewHeaderNg.js +1 -1
- package/dist/{XFoldViewNg → elements/XFoldViewNg}/XFoldviewNg.js +1 -1
- package/dist/{XFoldViewNg → elements/XFoldViewNg}/XFoldviewNgEvents.d.ts +3 -1
- package/dist/elements/XFoldViewNg/XFoldviewNgEvents.js +65 -0
- package/dist/{XFoldViewNg → elements/XFoldViewNg}/XFoldviewSlotDragNg.js +1 -1
- package/dist/{XFoldViewNg → elements/XFoldViewNg}/XFoldviewSlotNg.js +1 -1
- package/dist/{XFoldViewNg → elements/XFoldViewNg}/XFoldviewSlotNgTouchEventsHandler.d.ts +1 -1
- package/dist/{XFoldViewNg → elements/XFoldViewNg}/XFoldviewSlotNgTouchEventsHandler.js +0 -1
- package/dist/{XFoldViewNg → elements/XFoldViewNg}/XFoldviewToolbarNg.js +1 -1
- package/dist/elements/XFoldViewNg/index.d.ts +23 -0
- package/dist/elements/XFoldViewNg/index.js +27 -0
- package/dist/{XImage → elements/XImage}/DropShadow.d.ts +2 -1
- package/dist/elements/XImage/DropShadow.js +30 -0
- package/dist/{XImage → elements/XImage}/FilterImage.js +2 -2
- package/dist/{XImage → elements/XImage}/ImageEvents.d.ts +3 -1
- package/dist/elements/XImage/ImageEvents.js +67 -0
- package/dist/elements/XImage/ImageSrc.d.ts +12 -0
- package/dist/elements/XImage/ImageSrc.js +78 -0
- package/dist/{XImage → elements/XImage}/XImage.js +2 -2
- package/dist/elements/XImage/index.d.ts +18 -0
- package/dist/elements/XImage/index.js +22 -0
- package/dist/elements/XInput/InputBaseAttributes.d.ts +14 -0
- package/dist/elements/XInput/InputBaseAttributes.js +98 -0
- package/dist/elements/XInput/Placeholder.d.ts +11 -0
- package/dist/elements/XInput/Placeholder.js +60 -0
- package/dist/{XInput → elements/XInput}/XInput.js +2 -2
- package/dist/elements/XInput/XInputAttribute.d.ts +12 -0
- package/dist/elements/XInput/XInputAttribute.js +57 -0
- package/dist/elements/XInput/XInputEvents.d.ts +9 -0
- package/dist/{XInput → elements/XInput}/XInputEvents.js +36 -39
- package/dist/elements/XInput/index.d.ts +34 -0
- package/dist/elements/XInput/index.js +38 -0
- package/dist/{XList → elements/XList}/ListItem.js +1 -1
- package/dist/{XList → elements/XList}/ListItemAttributes.d.ts +2 -1
- package/dist/elements/XList/ListItemAttributes.js +31 -0
- package/dist/{XList → elements/XList}/XList.js +2 -2
- package/dist/{XList → elements/XList}/XListAttributes.d.ts +3 -1
- package/dist/{XList → elements/XList}/XListAttributes.js +14 -14
- package/dist/elements/XList/XListEvents.d.ts +14 -0
- package/dist/{XList → elements/XList}/XListEvents.js +78 -80
- package/dist/{XList → elements/XList}/XListWaterfall.d.ts +3 -1
- package/dist/{XList → elements/XList}/XListWaterfall.js +67 -69
- package/dist/elements/XList/index.d.ts +32 -0
- package/dist/elements/XList/index.js +36 -0
- package/dist/{XOverlayNg → elements/XOverlayNg}/XOverlayAttributes.d.ts +3 -1
- package/dist/elements/XOverlayNg/XOverlayAttributes.js +83 -0
- package/dist/{XOverlayNg → elements/XOverlayNg}/XOverlayNg.js +2 -2
- package/dist/elements/XOverlayNg/index.d.ts +14 -0
- package/dist/elements/XOverlayNg/index.js +18 -0
- package/dist/{XRefreshView → elements/XRefreshView}/XRefreshFooter.js +1 -1
- package/dist/{XRefreshView → elements/XRefreshView}/XRefreshHeader.js +1 -1
- package/dist/{XRefreshView → elements/XRefreshView}/XRefreshSubElementIntersectionObserver.d.ts +1 -1
- package/dist/{XRefreshView → elements/XRefreshView}/XRefreshView.js +2 -2
- package/dist/{XRefreshView → elements/XRefreshView}/XRefreshViewEventsEmitter.d.ts +3 -1
- package/dist/{XRefreshView → elements/XRefreshView}/XRefreshViewEventsEmitter.js +36 -39
- package/dist/elements/XRefreshView/index.d.ts +26 -0
- package/dist/elements/XRefreshView/index.js +30 -0
- package/dist/{XSvg → elements/XSvg}/XSvg.d.ts +4 -1
- package/dist/elements/XSvg/XSvg.js +96 -0
- package/dist/elements/XSvg/index.d.ts +13 -0
- package/dist/elements/XSvg/index.js +17 -0
- package/dist/{XSwiper → elements/XSwiper}/SwiperItem.js +1 -1
- package/dist/{XSwiper → elements/XSwiper}/XSwiper.js +2 -2
- package/dist/{XSwiper → elements/XSwiper}/XSwiperAutoScroll.d.ts +3 -1
- package/dist/elements/XSwiper/XSwiperAutoScroll.js +74 -0
- package/dist/{XSwiper → elements/XSwiper}/XSwiperCircular.d.ts +3 -1
- package/dist/{XSwiper → elements/XSwiper}/XSwiperCircular.js +24 -26
- package/dist/{XSwiper → elements/XSwiper}/XSwiperEvents.d.ts +3 -1
- package/dist/{XSwiper → elements/XSwiper}/XSwiperEvents.js +21 -22
- package/dist/elements/XSwiper/XSwiperIndicator.d.ts +14 -0
- package/dist/elements/XSwiper/XSwiperIndicator.js +117 -0
- package/dist/elements/XSwiper/index.d.ts +29 -0
- package/dist/elements/XSwiper/index.js +33 -0
- package/dist/{XText → elements/XText}/InlineImage.d.ts +2 -1
- package/dist/{XText → elements/XText}/InlineImage.js +12 -13
- package/dist/{XText → elements/XText}/InlineText.js +1 -1
- package/dist/{XText → elements/XText}/InlineTruncation.js +1 -1
- package/dist/{XText → elements/XText}/RawText.d.ts +1 -0
- package/dist/{XText → elements/XText}/RawText.js +12 -13
- package/dist/{XText → elements/XText}/XText.js +2 -2
- package/dist/{XText → elements/XText}/XTextTruncation.d.ts +3 -1
- package/dist/{XText → elements/XText}/XTextTruncation.js +31 -33
- package/dist/elements/XText/index.d.ts +21 -0
- package/dist/elements/XText/index.js +25 -0
- package/dist/elements/XTextarea/Placeholder.d.ts +12 -0
- package/dist/elements/XTextarea/Placeholder.js +60 -0
- package/dist/elements/XTextarea/TextareaBaseAttributes.d.ts +11 -0
- package/dist/elements/XTextarea/TextareaBaseAttributes.js +70 -0
- package/dist/{XTextarea → elements/XTextarea}/XTextarea.js +2 -2
- package/dist/elements/XTextarea/XTextareaAttributes.d.ts +11 -0
- package/dist/elements/XTextarea/XTextareaAttributes.js +79 -0
- package/dist/elements/XTextarea/XTextareaEvents.d.ts +9 -0
- package/dist/{XTextarea → elements/XTextarea}/XTextareaEvents.js +36 -39
- package/dist/elements/XTextarea/index.d.ts +35 -0
- package/dist/elements/XTextarea/index.js +39 -0
- package/dist/{XView → elements/XView}/BlurRadius.d.ts +2 -1
- package/dist/elements/XView/BlurRadius.js +37 -0
- package/dist/{XView → elements/XView}/XBlurView.js +1 -1
- package/dist/{XView → elements/XView}/XView.js +1 -1
- package/dist/elements/XView/index.d.ts +8 -0
- package/dist/elements/XView/index.js +12 -0
- package/dist/{XViewpagerNg → elements/XViewpagerNg}/XViewpagerItemNg.js +1 -1
- package/dist/{XViewpagerNg → elements/XViewpagerNg}/XViewpagerNg.js +2 -2
- package/dist/{XViewpagerNg → elements/XViewpagerNg}/XViewpagerNgEvents.d.ts +3 -1
- package/dist/{XViewpagerNg → elements/XViewpagerNg}/XViewpagerNgEvents.js +17 -19
- package/dist/elements/XViewpagerNg/index.d.ts +20 -0
- package/dist/elements/XViewpagerNg/index.js +24 -0
- package/dist/{common → elements/common}/CommonEventsAndMethods.d.ts +1 -0
- package/dist/{common → elements/common}/CommonEventsAndMethods.js +6 -2
- package/dist/elements/htmlTemplates.d.ts +20 -0
- package/dist/elements/htmlTemplates.js +332 -0
- package/dist/elements/index.d.ts +12 -0
- package/dist/elements/index.js +16 -0
- package/elements.css +18 -0
- package/index.css +2 -15
- package/package.json +84 -42
- package/src/compat/LinearContainer/linear-compat.css +124 -0
- package/src/{XInput → elements/XInput}/x-input.css +1 -1
- package/src/{common-css → elements/common-css}/linear.css +9 -4
- package/dist/LynxWrapper/index.d.ts +0 -1
- package/dist/LynxWrapper/index.js +0 -2
- package/dist/ScrollView/FadeEdgeLengthAttribute.js +0 -43
- package/dist/ScrollView/ScrollAttributes.js +0 -83
- package/dist/ScrollView/ScrollViewEvents.d.ts +0 -9
- package/dist/ScrollView/ScrollViewEvents.js +0 -167
- package/dist/ScrollView/index.d.ts +0 -1
- package/dist/ScrollView/index.js +0 -2
- package/dist/XAudioTT/XAudioAttribute.js +0 -93
- package/dist/XAudioTT/index.d.ts +0 -1
- package/dist/XAudioTT/index.js +0 -2
- package/dist/XCanvas/index.d.ts +0 -1
- package/dist/XCanvas/index.js +0 -2
- package/dist/XFoldViewNg/XFoldviewNgEvents.js +0 -67
- package/dist/XFoldViewNg/index.d.ts +0 -5
- package/dist/XFoldViewNg/index.js +0 -6
- package/dist/XImage/DropShadow.js +0 -30
- package/dist/XImage/ImageEvents.js +0 -69
- package/dist/XImage/ImageSrc.d.ts +0 -7
- package/dist/XImage/ImageSrc.js +0 -79
- package/dist/XImage/index.d.ts +0 -2
- package/dist/XImage/index.js +0 -3
- package/dist/XInput/InputBaseAttributes.d.ts +0 -9
- package/dist/XInput/InputBaseAttributes.js +0 -100
- package/dist/XInput/Placeholder.d.ts +0 -6
- package/dist/XInput/Placeholder.js +0 -60
- package/dist/XInput/XInputAttribute.d.ts +0 -9
- package/dist/XInput/XInputAttribute.js +0 -58
- package/dist/XInput/XInputEvents.d.ts +0 -6
- package/dist/XInput/index.d.ts +0 -1
- package/dist/XInput/index.js +0 -2
- package/dist/XList/ListItemAttributes.js +0 -32
- package/dist/XList/XListEvents.d.ts +0 -7
- package/dist/XList/index.d.ts +0 -2
- package/dist/XList/index.js +0 -3
- package/dist/XOverlayNg/XOverlayAttributes.js +0 -85
- package/dist/XOverlayNg/index.d.ts +0 -1
- package/dist/XOverlayNg/index.js +0 -2
- package/dist/XRefreshView/index.d.ts +0 -3
- package/dist/XRefreshView/index.js +0 -4
- package/dist/XSvg/XSvg.js +0 -99
- package/dist/XSvg/index.d.ts +0 -1
- package/dist/XSvg/index.js +0 -2
- package/dist/XSwiper/XSwiperAutoScroll.js +0 -76
- package/dist/XSwiper/XSwiperIndicator.d.ts +0 -9
- package/dist/XSwiper/XSwiperIndicator.js +0 -117
- package/dist/XSwiper/index.d.ts +0 -2
- package/dist/XSwiper/index.js +0 -3
- package/dist/XText/index.d.ts +0 -5
- package/dist/XText/index.js +0 -6
- package/dist/XTextarea/Placeholder.d.ts +0 -7
- package/dist/XTextarea/Placeholder.js +0 -60
- package/dist/XTextarea/TextareaBaseAttributes.d.ts +0 -6
- package/dist/XTextarea/TextareaBaseAttributes.js +0 -70
- package/dist/XTextarea/XTextareaAttributes.d.ts +0 -6
- package/dist/XTextarea/XTextareaAttributes.js +0 -81
- package/dist/XTextarea/XTextareaEvents.d.ts +0 -6
- package/dist/XTextarea/index.d.ts +0 -1
- package/dist/XTextarea/index.js +0 -2
- package/dist/XView/BlurRadius.js +0 -38
- package/dist/XView/index.d.ts +0 -2
- package/dist/XView/index.js +0 -3
- package/dist/XViewpagerNg/index.d.ts +0 -2
- package/dist/XViewpagerNg/index.js +0 -3
- package/dist/index.d.ts +0 -4
- package/dist/index.js +0 -8
- /package/dist/{LynxWrapper → elements/LynxWrapper}/LynxWrapper.d.ts +0 -0
- /package/dist/{ScrollView → elements/ScrollView}/ScrollView.d.ts +0 -0
- /package/dist/{XAudioTT → elements/XAudioTT}/XAudioTT.d.ts +0 -0
- /package/dist/{XAudioTT → elements/XAudioTT}/utils.d.ts +0 -0
- /package/dist/{XAudioTT → elements/XAudioTT}/utils.js +0 -0
- /package/dist/{XCanvas → elements/XCanvas}/XCanvas.d.ts +0 -0
- /package/dist/{XFoldViewNg → elements/XFoldViewNg}/XFoldviewHeaderNg.d.ts +0 -0
- /package/dist/{XFoldViewNg → elements/XFoldViewNg}/XFoldviewNg.d.ts +0 -0
- /package/dist/{XFoldViewNg → elements/XFoldViewNg}/XFoldviewSlotDragNg.d.ts +0 -0
- /package/dist/{XFoldViewNg → elements/XFoldViewNg}/XFoldviewSlotNg.d.ts +0 -0
- /package/dist/{XFoldViewNg → elements/XFoldViewNg}/XFoldviewToolbarNg.d.ts +0 -0
- /package/dist/{XImage → elements/XImage}/FilterImage.d.ts +0 -0
- /package/dist/{XImage → elements/XImage}/XImage.d.ts +0 -0
- /package/dist/{XInput → elements/XInput}/XInput.d.ts +0 -0
- /package/dist/{XList → elements/XList}/ListItem.d.ts +0 -0
- /package/dist/{XList → elements/XList}/XList.d.ts +0 -0
- /package/dist/{XOverlayNg → elements/XOverlayNg}/XOverlayNg.d.ts +0 -0
- /package/dist/{XRefreshView → elements/XRefreshView}/XRefreshFooter.d.ts +0 -0
- /package/dist/{XRefreshView → elements/XRefreshView}/XRefreshHeader.d.ts +0 -0
- /package/dist/{XRefreshView → elements/XRefreshView}/XRefreshSubElementIntersectionObserver.js +0 -0
- /package/dist/{XRefreshView → elements/XRefreshView}/XRefreshView.d.ts +0 -0
- /package/dist/{XSwiper → elements/XSwiper}/SwiperItem.d.ts +0 -0
- /package/dist/{XSwiper → elements/XSwiper}/XSwiper.d.ts +0 -0
- /package/dist/{XText → elements/XText}/InlineText.d.ts +0 -0
- /package/dist/{XText → elements/XText}/InlineTruncation.d.ts +0 -0
- /package/dist/{XText → elements/XText}/XText.d.ts +0 -0
- /package/dist/{XTextarea → elements/XTextarea}/XTextarea.d.ts +0 -0
- /package/dist/{XView → elements/XView}/XBlurView.d.ts +0 -0
- /package/dist/{XView → elements/XView}/XView.d.ts +0 -0
- /package/dist/{XViewpagerNg → elements/XViewpagerNg}/XViewpagerItemNg.d.ts +0 -0
- /package/dist/{XViewpagerNg → elements/XViewpagerNg}/XViewpagerNg.d.ts +0 -0
- /package/dist/{all.d.ts → elements/all.d.ts} +0 -0
- /package/dist/{all.js → elements/all.js} +0 -0
- /package/dist/{common → elements/common}/bindToIntersectionObserver.d.ts +0 -0
- /package/dist/{common → elements/common}/bindToIntersectionObserver.js +0 -0
- /package/dist/{common → elements/common}/commonEventInitConfiguration.d.ts +0 -0
- /package/dist/{common → elements/common}/commonEventInitConfiguration.js +0 -0
- /package/dist/{common → elements/common}/constants.d.ts +0 -0
- /package/dist/{common → elements/common}/constants.js +0 -0
- /package/dist/{common → elements/common}/getCombinedParentElement.d.ts +0 -0
- /package/dist/{common → elements/common}/getCombinedParentElement.js +0 -0
- /package/dist/{common → elements/common}/renameEvent.d.ts +0 -0
- /package/dist/{common → elements/common}/renameEvent.js +0 -0
- /package/dist/{common → elements/common}/throttle.d.ts +0 -0
- /package/dist/{common → elements/common}/throttle.js +0 -0
- /package/src/{LynxWrapper → elements/LynxWrapper}/lynx-wrapper.css +0 -0
- /package/src/{ScrollView → elements/ScrollView}/scroll-view.css +0 -0
- /package/src/{XAudioTT → elements/XAudioTT}/x-audio-tt.css +0 -0
- /package/src/{XCanvas → elements/XCanvas}/x-canvas.css +0 -0
- /package/src/{XFoldViewNg → elements/XFoldViewNg}/x-foldview-ng.css +0 -0
- /package/src/{XImage → elements/XImage}/x-image.css +0 -0
- /package/src/{XList → elements/XList}/x-list.css +0 -0
- /package/src/{XOverlayNg → elements/XOverlayNg}/x-overlay-ng.css +0 -0
- /package/src/{XRefreshView → elements/XRefreshView}/x-refresh-view.css +0 -0
- /package/src/{XSvg → elements/XSvg}/x-svg.css +0 -0
- /package/src/{XSwiper → elements/XSwiper}/x-swiper.css +0 -0
- /package/src/{XText → elements/XText}/x-text.css +0 -0
- /package/src/{XTextarea → elements/XTextarea}/x-textarea.css +0 -0
- /package/src/{XViewpagerNg → elements/XViewpagerNg}/x-viewpager-ng.css +0 -0
|
@@ -1,44 +1,24 @@
|
|
|
1
|
-
import { __esDecorate, __runInitializers
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
2
|
/*
|
|
3
3
|
// Copyright 2024 The Lynx Authors. All rights reserved.
|
|
4
4
|
// Licensed under the Apache License Version 2.0 that can be found in the
|
|
5
5
|
// LICENSE file in the root directory of this source tree.
|
|
6
6
|
*/
|
|
7
|
-
import { boostedQueueMicrotask, genDomGetter, registerAttributeHandler, } from '
|
|
7
|
+
import { boostedQueueMicrotask, genDomGetter, registerAttributeHandler, } from '../../element-reactive/index.js';
|
|
8
8
|
import { commonComponentEventSetting } from '../common/commonEventInitConfiguration.js';
|
|
9
|
-
import { registerEventEnableStatusChangeHandler } from '
|
|
9
|
+
import { registerEventEnableStatusChangeHandler } from '../../element-reactive/index.js';
|
|
10
10
|
let XTextTruncation = (() => {
|
|
11
11
|
var _a;
|
|
12
12
|
let _instanceExtraInitializers = [];
|
|
13
|
-
let
|
|
14
|
-
let
|
|
15
|
-
let _private_handleEnableLayoutEvent_decorators;
|
|
16
|
-
let _private_handleEnableLayoutEvent_descriptor;
|
|
13
|
+
let __handleAttributeChange_decorators;
|
|
14
|
+
let __handleEnableLayoutEvent_decorators;
|
|
17
15
|
return class XTextTruncation {
|
|
18
16
|
static {
|
|
19
17
|
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
__esDecorate(this,
|
|
23
|
-
|
|
24
|
-
this.#maxLine = parseFloat(this.#dom.getAttribute('text-maxline') ?? '');
|
|
25
|
-
this.#tailColorConvert =
|
|
26
|
-
this.#dom.getAttribute('tail-color-convert') !== 'false';
|
|
27
|
-
if (this.#maxLength < 0)
|
|
28
|
-
this.#maxLength = NaN;
|
|
29
|
-
if (this.#maxLine < 1)
|
|
30
|
-
this.#maxLine = NaN;
|
|
31
|
-
if (!isNaN(this.#maxLine)) {
|
|
32
|
-
this.#getInnerBox().style.webkitLineClamp = this.#maxLine.toString();
|
|
33
|
-
}
|
|
34
|
-
else {
|
|
35
|
-
this.#getInnerBox().style.removeProperty('-webkit-line-clamp');
|
|
36
|
-
}
|
|
37
|
-
this.#layoutText();
|
|
38
|
-
}, "#handleAttributeChange") }, _private_handleAttributeChange_decorators, { kind: "method", name: "#handleAttributeChange", static: false, private: true, access: { has: obj => #handleAttributeChange in obj, get: obj => obj.#handleAttributeChange }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
39
|
-
__esDecorate(this, _private_handleEnableLayoutEvent_descriptor = { value: __setFunctionName(function (status) {
|
|
40
|
-
this.#enableLayoutEvent = status;
|
|
41
|
-
}, "#handleEnableLayoutEvent") }, _private_handleEnableLayoutEvent_decorators, { kind: "method", name: "#handleEnableLayoutEvent", static: false, private: true, access: { has: obj => #handleEnableLayoutEvent in obj, get: obj => obj.#handleEnableLayoutEvent }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
18
|
+
__handleAttributeChange_decorators = [registerAttributeHandler('text-maxlength', true), registerAttributeHandler('text-maxline', true), registerAttributeHandler('tail-color-convert', true)];
|
|
19
|
+
__handleEnableLayoutEvent_decorators = [registerEventEnableStatusChangeHandler('layout')];
|
|
20
|
+
__esDecorate(this, null, __handleAttributeChange_decorators, { kind: "method", name: "_handleAttributeChange", static: false, private: false, access: { has: obj => "_handleAttributeChange" in obj, get: obj => obj._handleAttributeChange }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
21
|
+
__esDecorate(this, null, __handleEnableLayoutEvent_decorators, { kind: "method", name: "_handleEnableLayoutEvent", static: false, private: false, access: { has: obj => "_handleEnableLayoutEvent" in obj, get: obj => obj._handleEnableLayoutEvent }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
42
22
|
if (_metadata) Object.defineProperty(this, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
43
23
|
}
|
|
44
24
|
static exceedMathLengthAttribute = 'x-text-clipped';
|
|
@@ -280,8 +260,26 @@ let XTextTruncation = (() => {
|
|
|
280
260
|
this.#resizeObserver?.disconnect();
|
|
281
261
|
this.#resizeObserver = undefined;
|
|
282
262
|
}
|
|
283
|
-
|
|
284
|
-
|
|
263
|
+
_handleAttributeChange() {
|
|
264
|
+
this.#maxLength = parseFloat(this.#dom.getAttribute('text-maxlength') ?? '');
|
|
265
|
+
this.#maxLine = parseFloat(this.#dom.getAttribute('text-maxline') ?? '');
|
|
266
|
+
this.#tailColorConvert =
|
|
267
|
+
this.#dom.getAttribute('tail-color-convert') !== 'false';
|
|
268
|
+
if (this.#maxLength < 0)
|
|
269
|
+
this.#maxLength = NaN;
|
|
270
|
+
if (this.#maxLine < 1)
|
|
271
|
+
this.#maxLine = NaN;
|
|
272
|
+
if (!isNaN(this.#maxLine)) {
|
|
273
|
+
this.#getInnerBox().style.webkitLineClamp = this.#maxLine.toString();
|
|
274
|
+
}
|
|
275
|
+
else {
|
|
276
|
+
this.#getInnerBox().style.removeProperty('-webkit-line-clamp');
|
|
277
|
+
}
|
|
278
|
+
this.#layoutText();
|
|
279
|
+
}
|
|
280
|
+
_handleEnableLayoutEvent(status) {
|
|
281
|
+
this.#enableLayoutEvent = status;
|
|
282
|
+
}
|
|
285
283
|
#sendLayoutEvent(truncateAt) {
|
|
286
284
|
if (!this.#enableLayoutEvent)
|
|
287
285
|
return;
|
|
@@ -336,8 +334,8 @@ let XTextTruncation = (() => {
|
|
|
336
334
|
}
|
|
337
335
|
connectedCallback() {
|
|
338
336
|
this.#componentConnected = true;
|
|
339
|
-
this
|
|
340
|
-
this
|
|
337
|
+
this._handleEnableLayoutEvent(this.#enableLayoutEvent);
|
|
338
|
+
this._handleAttributeChange();
|
|
341
339
|
boostedQueueMicrotask(() => {
|
|
342
340
|
this.#sendLayoutEvent();
|
|
343
341
|
});
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export { InlineImage } from './InlineImage.js';
|
|
2
|
+
export { InlineText } from './InlineText.js';
|
|
3
|
+
export { InlineTruncation } from './InlineTruncation.js';
|
|
4
|
+
export { RawText } from './RawText.js';
|
|
5
|
+
/**
|
|
6
|
+
* @module elements/XText
|
|
7
|
+
*
|
|
8
|
+
* `x-text` displays text content, supporting truncation and rich text.
|
|
9
|
+
*
|
|
10
|
+
* Attributes:
|
|
11
|
+
* - `text-maxlength`: Max characters to show.
|
|
12
|
+
* - `text-maxline`: Max lines to show (ellipsis).
|
|
13
|
+
* - `tail-color-convert`: 'true' | 'false', whether to apply color to truncation ellipsis.
|
|
14
|
+
*
|
|
15
|
+
* Events:
|
|
16
|
+
* - `layout`: Fired when text layout happens (if enabled). Detail provides line info.
|
|
17
|
+
*
|
|
18
|
+
* CSS Variables:
|
|
19
|
+
* - `--lynx-text-bg-color`: Inherited background color for nested text elements.
|
|
20
|
+
*/
|
|
21
|
+
export { XText } from './XText.js';
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
// Copyright 2024 The Lynx Authors. All rights reserved.
|
|
2
|
+
// Licensed under the Apache License Version 2.0 that can be found in the
|
|
3
|
+
// LICENSE file in the root directory of this source tree.
|
|
4
|
+
export { InlineImage } from './InlineImage.js';
|
|
5
|
+
export { InlineText } from './InlineText.js';
|
|
6
|
+
export { InlineTruncation } from './InlineTruncation.js';
|
|
7
|
+
export { RawText } from './RawText.js';
|
|
8
|
+
/**
|
|
9
|
+
* @module elements/XText
|
|
10
|
+
*
|
|
11
|
+
* `x-text` displays text content, supporting truncation and rich text.
|
|
12
|
+
*
|
|
13
|
+
* Attributes:
|
|
14
|
+
* - `text-maxlength`: Max characters to show.
|
|
15
|
+
* - `text-maxline`: Max lines to show (ellipsis).
|
|
16
|
+
* - `tail-color-convert`: 'true' | 'false', whether to apply color to truncation ellipsis.
|
|
17
|
+
*
|
|
18
|
+
* Events:
|
|
19
|
+
* - `layout`: Fired when text layout happens (if enabled). Detail provides line info.
|
|
20
|
+
*
|
|
21
|
+
* CSS Variables:
|
|
22
|
+
* - `--lynx-text-bg-color`: Inherited background color for nested text elements.
|
|
23
|
+
*/
|
|
24
|
+
export { XText } from './XText.js';
|
|
25
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { type AttributeReactiveClass } from '../../element-reactive/index.js';
|
|
2
|
+
import { XTextarea } from './XTextarea.js';
|
|
3
|
+
export declare class Placeholder implements InstanceType<AttributeReactiveClass<typeof XTextarea>> {
|
|
4
|
+
#private;
|
|
5
|
+
static observedAttributes: readonly ["placeholder", "placeholder-color", "placeholder-font-size", "placeholder-font-weight", "placeholder-font-family"];
|
|
6
|
+
_updatePlaceholderColor: (this: void, newVal: string | null) => void;
|
|
7
|
+
_updatePlaceholderFontSize: (this: void, newVal: string | null) => void;
|
|
8
|
+
_updatePlaceholderFontWeight: (this: void, newVal: string | null) => void;
|
|
9
|
+
_updatePlaceholderFontFamily: (this: void, newVal: string | null) => void;
|
|
10
|
+
_handlePlaceholder: (this: void, newVal: string | null) => void;
|
|
11
|
+
constructor(dom: HTMLElement);
|
|
12
|
+
}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
/*
|
|
3
|
+
// Copyright 2024 The Lynx Authors. All rights reserved.
|
|
4
|
+
// Licensed under the Apache License Version 2.0 that can be found in the
|
|
5
|
+
// LICENSE file in the root directory of this source tree.
|
|
6
|
+
*/
|
|
7
|
+
import { bindToAttribute, bindToStyle, genDomGetter, registerAttributeHandler, } from '../../element-reactive/index.js';
|
|
8
|
+
import { XTextarea } from './XTextarea.js';
|
|
9
|
+
let Placeholder = (() => {
|
|
10
|
+
let __updatePlaceholderColor_decorators;
|
|
11
|
+
let __updatePlaceholderColor_initializers = [];
|
|
12
|
+
let __updatePlaceholderColor_extraInitializers = [];
|
|
13
|
+
let __updatePlaceholderFontSize_decorators;
|
|
14
|
+
let __updatePlaceholderFontSize_initializers = [];
|
|
15
|
+
let __updatePlaceholderFontSize_extraInitializers = [];
|
|
16
|
+
let __updatePlaceholderFontWeight_decorators;
|
|
17
|
+
let __updatePlaceholderFontWeight_initializers = [];
|
|
18
|
+
let __updatePlaceholderFontWeight_extraInitializers = [];
|
|
19
|
+
let __updatePlaceholderFontFamily_decorators;
|
|
20
|
+
let __updatePlaceholderFontFamily_initializers = [];
|
|
21
|
+
let __updatePlaceholderFontFamily_extraInitializers = [];
|
|
22
|
+
let __handlePlaceholder_decorators;
|
|
23
|
+
let __handlePlaceholder_initializers = [];
|
|
24
|
+
let __handlePlaceholder_extraInitializers = [];
|
|
25
|
+
return class Placeholder {
|
|
26
|
+
static {
|
|
27
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
|
|
28
|
+
__updatePlaceholderColor_decorators = [registerAttributeHandler('placeholder-color', true)];
|
|
29
|
+
__updatePlaceholderFontSize_decorators = [registerAttributeHandler('placeholder-font-size', true)];
|
|
30
|
+
__updatePlaceholderFontWeight_decorators = [registerAttributeHandler('placeholder-font-weight', true)];
|
|
31
|
+
__updatePlaceholderFontFamily_decorators = [registerAttributeHandler('placeholder-font-family', true)];
|
|
32
|
+
__handlePlaceholder_decorators = [registerAttributeHandler('placeholder', true)];
|
|
33
|
+
__esDecorate(null, null, __updatePlaceholderColor_decorators, { kind: "field", name: "_updatePlaceholderColor", static: false, private: false, access: { has: obj => "_updatePlaceholderColor" in obj, get: obj => obj._updatePlaceholderColor, set: (obj, value) => { obj._updatePlaceholderColor = value; } }, metadata: _metadata }, __updatePlaceholderColor_initializers, __updatePlaceholderColor_extraInitializers);
|
|
34
|
+
__esDecorate(null, null, __updatePlaceholderFontSize_decorators, { kind: "field", name: "_updatePlaceholderFontSize", static: false, private: false, access: { has: obj => "_updatePlaceholderFontSize" in obj, get: obj => obj._updatePlaceholderFontSize, set: (obj, value) => { obj._updatePlaceholderFontSize = value; } }, metadata: _metadata }, __updatePlaceholderFontSize_initializers, __updatePlaceholderFontSize_extraInitializers);
|
|
35
|
+
__esDecorate(null, null, __updatePlaceholderFontWeight_decorators, { kind: "field", name: "_updatePlaceholderFontWeight", static: false, private: false, access: { has: obj => "_updatePlaceholderFontWeight" in obj, get: obj => obj._updatePlaceholderFontWeight, set: (obj, value) => { obj._updatePlaceholderFontWeight = value; } }, metadata: _metadata }, __updatePlaceholderFontWeight_initializers, __updatePlaceholderFontWeight_extraInitializers);
|
|
36
|
+
__esDecorate(null, null, __updatePlaceholderFontFamily_decorators, { kind: "field", name: "_updatePlaceholderFontFamily", static: false, private: false, access: { has: obj => "_updatePlaceholderFontFamily" in obj, get: obj => obj._updatePlaceholderFontFamily, set: (obj, value) => { obj._updatePlaceholderFontFamily = value; } }, metadata: _metadata }, __updatePlaceholderFontFamily_initializers, __updatePlaceholderFontFamily_extraInitializers);
|
|
37
|
+
__esDecorate(null, null, __handlePlaceholder_decorators, { kind: "field", name: "_handlePlaceholder", static: false, private: false, access: { has: obj => "_handlePlaceholder" in obj, get: obj => obj._handlePlaceholder, set: (obj, value) => { obj._handlePlaceholder = value; } }, metadata: _metadata }, __handlePlaceholder_initializers, __handlePlaceholder_extraInitializers);
|
|
38
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
39
|
+
}
|
|
40
|
+
static observedAttributes = [
|
|
41
|
+
'placeholder',
|
|
42
|
+
'placeholder-color',
|
|
43
|
+
'placeholder-font-size',
|
|
44
|
+
'placeholder-font-weight',
|
|
45
|
+
'placeholder-font-family',
|
|
46
|
+
];
|
|
47
|
+
#getTextarea = genDomGetter(() => this.#dom.shadowRoot, '#textarea');
|
|
48
|
+
_updatePlaceholderColor = __runInitializers(this, __updatePlaceholderColor_initializers, bindToStyle(this.#getTextarea, '--placeholder-color', undefined, true));
|
|
49
|
+
_updatePlaceholderFontSize = (__runInitializers(this, __updatePlaceholderColor_extraInitializers), __runInitializers(this, __updatePlaceholderFontSize_initializers, bindToStyle(this.#getTextarea, '--placeholder-font-size', undefined, true)));
|
|
50
|
+
_updatePlaceholderFontWeight = (__runInitializers(this, __updatePlaceholderFontSize_extraInitializers), __runInitializers(this, __updatePlaceholderFontWeight_initializers, bindToStyle(this.#getTextarea, '--placeholder-font-weight', undefined, true)));
|
|
51
|
+
_updatePlaceholderFontFamily = (__runInitializers(this, __updatePlaceholderFontWeight_extraInitializers), __runInitializers(this, __updatePlaceholderFontFamily_initializers, bindToStyle(this.#getTextarea, '--placeholder-font-family', undefined, true)));
|
|
52
|
+
_handlePlaceholder = (__runInitializers(this, __updatePlaceholderFontFamily_extraInitializers), __runInitializers(this, __handlePlaceholder_initializers, bindToAttribute(this.#getTextarea, 'placeholder')));
|
|
53
|
+
#dom = __runInitializers(this, __handlePlaceholder_extraInitializers);
|
|
54
|
+
constructor(dom) {
|
|
55
|
+
this.#dom = dom;
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
})();
|
|
59
|
+
export { Placeholder };
|
|
60
|
+
//# sourceMappingURL=Placeholder.js.map
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { type AttributeReactiveClass } from '../../element-reactive/index.js';
|
|
2
|
+
export declare class TextareaBaseAttributes implements InstanceType<AttributeReactiveClass<typeof HTMLElement>> {
|
|
3
|
+
#private;
|
|
4
|
+
static observedAttributes: string[];
|
|
5
|
+
_handlerConfirmType: (this: void, newVal: string | null) => void;
|
|
6
|
+
_handlerMaxlength: (this: void, newVal: string | null) => void;
|
|
7
|
+
_handleReadonly: (this: void, newVal: string | null) => void;
|
|
8
|
+
_handleSpellCheck: (this: void, newVal: string | null) => void;
|
|
9
|
+
_handleShowSoftInputOnfocus: (this: void, newVal: string | null) => void;
|
|
10
|
+
constructor(dom: HTMLElement);
|
|
11
|
+
}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
/*
|
|
3
|
+
// Copyright 2024 The Lynx Authors. All rights reserved.
|
|
4
|
+
// Licensed under the Apache License Version 2.0 that can be found in the
|
|
5
|
+
// LICENSE file in the root directory of this source tree.
|
|
6
|
+
*/
|
|
7
|
+
import { bindToAttribute, genDomGetter, registerAttributeHandler, } from '../../element-reactive/index.js';
|
|
8
|
+
let TextareaBaseAttributes = (() => {
|
|
9
|
+
let __handlerConfirmType_decorators;
|
|
10
|
+
let __handlerConfirmType_initializers = [];
|
|
11
|
+
let __handlerConfirmType_extraInitializers = [];
|
|
12
|
+
let __handlerMaxlength_decorators;
|
|
13
|
+
let __handlerMaxlength_initializers = [];
|
|
14
|
+
let __handlerMaxlength_extraInitializers = [];
|
|
15
|
+
let __handleReadonly_decorators;
|
|
16
|
+
let __handleReadonly_initializers = [];
|
|
17
|
+
let __handleReadonly_extraInitializers = [];
|
|
18
|
+
let __handleSpellCheck_decorators;
|
|
19
|
+
let __handleSpellCheck_initializers = [];
|
|
20
|
+
let __handleSpellCheck_extraInitializers = [];
|
|
21
|
+
let __handleShowSoftInputOnfocus_decorators;
|
|
22
|
+
let __handleShowSoftInputOnfocus_initializers = [];
|
|
23
|
+
let __handleShowSoftInputOnfocus_extraInitializers = [];
|
|
24
|
+
return class TextareaBaseAttributes {
|
|
25
|
+
static {
|
|
26
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
|
|
27
|
+
__handlerConfirmType_decorators = [registerAttributeHandler('confirm-type', true)];
|
|
28
|
+
__handlerMaxlength_decorators = [registerAttributeHandler('maxlength', true)];
|
|
29
|
+
__handleReadonly_decorators = [registerAttributeHandler('readonly', true)];
|
|
30
|
+
__handleSpellCheck_decorators = [registerAttributeHandler('ios-spell-check', true)];
|
|
31
|
+
__handleShowSoftInputOnfocus_decorators = [registerAttributeHandler('show-soft-input-onfocus', true)];
|
|
32
|
+
__esDecorate(null, null, __handlerConfirmType_decorators, { kind: "field", name: "_handlerConfirmType", static: false, private: false, access: { has: obj => "_handlerConfirmType" in obj, get: obj => obj._handlerConfirmType, set: (obj, value) => { obj._handlerConfirmType = value; } }, metadata: _metadata }, __handlerConfirmType_initializers, __handlerConfirmType_extraInitializers);
|
|
33
|
+
__esDecorate(null, null, __handlerMaxlength_decorators, { kind: "field", name: "_handlerMaxlength", static: false, private: false, access: { has: obj => "_handlerMaxlength" in obj, get: obj => obj._handlerMaxlength, set: (obj, value) => { obj._handlerMaxlength = value; } }, metadata: _metadata }, __handlerMaxlength_initializers, __handlerMaxlength_extraInitializers);
|
|
34
|
+
__esDecorate(null, null, __handleReadonly_decorators, { kind: "field", name: "_handleReadonly", static: false, private: false, access: { has: obj => "_handleReadonly" in obj, get: obj => obj._handleReadonly, set: (obj, value) => { obj._handleReadonly = value; } }, metadata: _metadata }, __handleReadonly_initializers, __handleReadonly_extraInitializers);
|
|
35
|
+
__esDecorate(null, null, __handleSpellCheck_decorators, { kind: "field", name: "_handleSpellCheck", static: false, private: false, access: { has: obj => "_handleSpellCheck" in obj, get: obj => obj._handleSpellCheck, set: (obj, value) => { obj._handleSpellCheck = value; } }, metadata: _metadata }, __handleSpellCheck_initializers, __handleSpellCheck_extraInitializers);
|
|
36
|
+
__esDecorate(null, null, __handleShowSoftInputOnfocus_decorators, { kind: "field", name: "_handleShowSoftInputOnfocus", static: false, private: false, access: { has: obj => "_handleShowSoftInputOnfocus" in obj, get: obj => obj._handleShowSoftInputOnfocus, set: (obj, value) => { obj._handleShowSoftInputOnfocus = value; } }, metadata: _metadata }, __handleShowSoftInputOnfocus_initializers, __handleShowSoftInputOnfocus_extraInitializers);
|
|
37
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
38
|
+
}
|
|
39
|
+
static observedAttributes = [
|
|
40
|
+
'confirm-type',
|
|
41
|
+
'maxlength',
|
|
42
|
+
'readonly',
|
|
43
|
+
'type',
|
|
44
|
+
'ios-spell-check',
|
|
45
|
+
'spell-check',
|
|
46
|
+
'show-soft-input-onfocus',
|
|
47
|
+
];
|
|
48
|
+
#dom;
|
|
49
|
+
#getTextareaElement = genDomGetter(() => this.#dom.shadowRoot, '#textarea');
|
|
50
|
+
_handlerConfirmType = __runInitializers(this, __handlerConfirmType_initializers, bindToAttribute(this.#getTextareaElement, 'enterkeyhint', (val) => {
|
|
51
|
+
if (val === null)
|
|
52
|
+
return 'send';
|
|
53
|
+
return val;
|
|
54
|
+
}));
|
|
55
|
+
_handlerMaxlength = (__runInitializers(this, __handlerConfirmType_extraInitializers), __runInitializers(this, __handlerMaxlength_initializers, bindToAttribute(this.#getTextareaElement, 'maxlength', (val) => {
|
|
56
|
+
if (val === null)
|
|
57
|
+
return '140';
|
|
58
|
+
return val;
|
|
59
|
+
})));
|
|
60
|
+
_handleReadonly = (__runInitializers(this, __handlerMaxlength_extraInitializers), __runInitializers(this, __handleReadonly_initializers, bindToAttribute(this.#getTextareaElement, 'readonly', (value) => (value !== null ? '' : null))));
|
|
61
|
+
_handleSpellCheck = (__runInitializers(this, __handleReadonly_extraInitializers), __runInitializers(this, __handleSpellCheck_initializers, bindToAttribute(this.#getTextareaElement, 'spellcheck', (value) => (value === null ? 'false' : 'true'))));
|
|
62
|
+
_handleShowSoftInputOnfocus = (__runInitializers(this, __handleSpellCheck_extraInitializers), __runInitializers(this, __handleShowSoftInputOnfocus_initializers, bindToAttribute(this.#getTextareaElement, 'virtualkeyboardpolicy', (value) => (value === null ? 'manual' : 'auto'))));
|
|
63
|
+
constructor(dom) {
|
|
64
|
+
__runInitializers(this, __handleShowSoftInputOnfocus_extraInitializers);
|
|
65
|
+
this.#dom = dom;
|
|
66
|
+
}
|
|
67
|
+
};
|
|
68
|
+
})();
|
|
69
|
+
export { TextareaBaseAttributes };
|
|
70
|
+
//# sourceMappingURL=TextareaBaseAttributes.js.map
|
|
@@ -4,13 +4,13 @@ import { __esDecorate, __runInitializers } from "tslib";
|
|
|
4
4
|
// Licensed under the Apache License Version 2.0 that can be found in the
|
|
5
5
|
// LICENSE file in the root directory of this source tree.
|
|
6
6
|
*/
|
|
7
|
-
import { Component, genDomGetter } from '
|
|
7
|
+
import { Component, genDomGetter } from '../../element-reactive/index.js';
|
|
8
8
|
import { Placeholder } from './Placeholder.js';
|
|
9
9
|
import { TextareaBaseAttributes } from './TextareaBaseAttributes.js';
|
|
10
10
|
import { XTextareaAttributes } from './XTextareaAttributes.js';
|
|
11
11
|
import { XTextareaEvents } from './XTextareaEvents.js';
|
|
12
12
|
import { CommonEventsAndMethods } from '../common/CommonEventsAndMethods.js';
|
|
13
|
-
import { templateXTextarea } from '
|
|
13
|
+
import { templateXTextarea } from '../htmlTemplates.js';
|
|
14
14
|
// x-textarea
|
|
15
15
|
let XTextarea = (() => {
|
|
16
16
|
let _classDecorators = [Component('x-textarea', [
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { type AttributeReactiveClass } from '../../element-reactive/index.js';
|
|
2
|
+
export declare class XTextareaAttributes implements InstanceType<AttributeReactiveClass<typeof HTMLElement>> {
|
|
3
|
+
#private;
|
|
4
|
+
static observedAttributes: string[];
|
|
5
|
+
_handleConfirmEnter(newVal: string | null): void;
|
|
6
|
+
_handleDisabled: (this: void, newVal: string | null) => void;
|
|
7
|
+
_handleMaxHeight: (this: void, newVal: string | null) => void;
|
|
8
|
+
_handleMinHeight: (this: void, newVal: string | null) => void;
|
|
9
|
+
_handleValue(newValue: string | null): void;
|
|
10
|
+
constructor(dom: HTMLElement);
|
|
11
|
+
}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
/*
|
|
3
|
+
// Copyright 2024 The Lynx Authors. All rights reserved.
|
|
4
|
+
// Licensed under the Apache License Version 2.0 that can be found in the
|
|
5
|
+
// LICENSE file in the root directory of this source tree.
|
|
6
|
+
*/
|
|
7
|
+
import { bindToAttribute, genDomGetter, registerAttributeHandler, bindToStyle, } from '../../element-reactive/index.js';
|
|
8
|
+
let XTextareaAttributes = (() => {
|
|
9
|
+
let _instanceExtraInitializers = [];
|
|
10
|
+
let __handleConfirmEnter_decorators;
|
|
11
|
+
let __handleDisabled_decorators;
|
|
12
|
+
let __handleDisabled_initializers = [];
|
|
13
|
+
let __handleDisabled_extraInitializers = [];
|
|
14
|
+
let __handleMaxHeight_decorators;
|
|
15
|
+
let __handleMaxHeight_initializers = [];
|
|
16
|
+
let __handleMaxHeight_extraInitializers = [];
|
|
17
|
+
let __handleMinHeight_decorators;
|
|
18
|
+
let __handleMinHeight_initializers = [];
|
|
19
|
+
let __handleMinHeight_extraInitializers = [];
|
|
20
|
+
let __handleValue_decorators;
|
|
21
|
+
return class XTextareaAttributes {
|
|
22
|
+
static {
|
|
23
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
|
|
24
|
+
__handleConfirmEnter_decorators = [registerAttributeHandler('confirm-enter', true)];
|
|
25
|
+
__handleDisabled_decorators = [registerAttributeHandler('disabled', true)];
|
|
26
|
+
__handleMaxHeight_decorators = [registerAttributeHandler('max-height', true)];
|
|
27
|
+
__handleMinHeight_decorators = [registerAttributeHandler('min-height', true)];
|
|
28
|
+
__handleValue_decorators = [registerAttributeHandler('value', false)];
|
|
29
|
+
__esDecorate(this, null, __handleConfirmEnter_decorators, { kind: "method", name: "_handleConfirmEnter", static: false, private: false, access: { has: obj => "_handleConfirmEnter" in obj, get: obj => obj._handleConfirmEnter }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
30
|
+
__esDecorate(this, null, __handleValue_decorators, { kind: "method", name: "_handleValue", static: false, private: false, access: { has: obj => "_handleValue" in obj, get: obj => obj._handleValue }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
31
|
+
__esDecorate(null, null, __handleDisabled_decorators, { kind: "field", name: "_handleDisabled", static: false, private: false, access: { has: obj => "_handleDisabled" in obj, get: obj => obj._handleDisabled, set: (obj, value) => { obj._handleDisabled = value; } }, metadata: _metadata }, __handleDisabled_initializers, __handleDisabled_extraInitializers);
|
|
32
|
+
__esDecorate(null, null, __handleMaxHeight_decorators, { kind: "field", name: "_handleMaxHeight", static: false, private: false, access: { has: obj => "_handleMaxHeight" in obj, get: obj => obj._handleMaxHeight, set: (obj, value) => { obj._handleMaxHeight = value; } }, metadata: _metadata }, __handleMaxHeight_initializers, __handleMaxHeight_extraInitializers);
|
|
33
|
+
__esDecorate(null, null, __handleMinHeight_decorators, { kind: "field", name: "_handleMinHeight", static: false, private: false, access: { has: obj => "_handleMinHeight" in obj, get: obj => obj._handleMinHeight, set: (obj, value) => { obj._handleMinHeight = value; } }, metadata: _metadata }, __handleMinHeight_initializers, __handleMinHeight_extraInitializers);
|
|
34
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
35
|
+
}
|
|
36
|
+
static observedAttributes = [
|
|
37
|
+
'confirm-enter',
|
|
38
|
+
'disabled',
|
|
39
|
+
'max-height',
|
|
40
|
+
'min-height',
|
|
41
|
+
'value',
|
|
42
|
+
];
|
|
43
|
+
#dom = __runInitializers(this, _instanceExtraInitializers);
|
|
44
|
+
#getTextareaElement = genDomGetter(() => this.#dom.shadowRoot, '#textarea');
|
|
45
|
+
#getFormElement = genDomGetter(() => this.#dom.shadowRoot, '#form');
|
|
46
|
+
#confirmEnter = false;
|
|
47
|
+
_handleConfirmEnter(newVal) {
|
|
48
|
+
this.#confirmEnter = newVal !== null;
|
|
49
|
+
}
|
|
50
|
+
_handleDisabled = __runInitializers(this, __handleDisabled_initializers, bindToAttribute(this.#getTextareaElement, 'disabled', (value) => (value !== null ? '' : null)));
|
|
51
|
+
_handleMaxHeight = (__runInitializers(this, __handleDisabled_extraInitializers), __runInitializers(this, __handleMaxHeight_initializers, bindToStyle(this.#getTextareaElement, 'max-height')));
|
|
52
|
+
_handleMinHeight = (__runInitializers(this, __handleMaxHeight_extraInitializers), __runInitializers(this, __handleMinHeight_initializers, bindToStyle(this.#getTextareaElement, 'min-height')));
|
|
53
|
+
_handleValue(newValue) {
|
|
54
|
+
if (newValue) {
|
|
55
|
+
const maxlength = parseFloat(this.#dom.getAttribute('maxlength') ?? '');
|
|
56
|
+
if (!isNaN(maxlength))
|
|
57
|
+
newValue = newValue.substring(0, maxlength);
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
newValue = '';
|
|
61
|
+
}
|
|
62
|
+
const textarea = this.#getTextareaElement();
|
|
63
|
+
if (textarea.value !== newValue) {
|
|
64
|
+
textarea.value = newValue;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
#handleKeyEvent = (__runInitializers(this, __handleMinHeight_extraInitializers), (event) => {
|
|
68
|
+
if (this.#confirmEnter && event.key === 'Enter') {
|
|
69
|
+
this.#getFormElement().dispatchEvent(new SubmitEvent('submit'));
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
constructor(dom) {
|
|
73
|
+
this.#dom = dom;
|
|
74
|
+
this.#getTextareaElement().addEventListener('keyup', this.#handleKeyEvent);
|
|
75
|
+
}
|
|
76
|
+
};
|
|
77
|
+
})();
|
|
78
|
+
export { XTextareaAttributes };
|
|
79
|
+
//# sourceMappingURL=XTextareaAttributes.js.map
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { type AttributeReactiveClass } from '../../element-reactive/index.js';
|
|
2
|
+
export declare class XTextareaEvents implements InstanceType<AttributeReactiveClass<typeof HTMLElement>> {
|
|
3
|
+
#private;
|
|
4
|
+
static observedAttributes: string[];
|
|
5
|
+
_handleEnableConfirmEvent(status: string | boolean | null): void;
|
|
6
|
+
_handleSendComposingInput(newVal: string | null): void;
|
|
7
|
+
_handleEnableSelectionEvent(status: boolean): void;
|
|
8
|
+
constructor(dom: HTMLElement);
|
|
9
|
+
}
|
|
@@ -1,51 +1,27 @@
|
|
|
1
|
-
import { __esDecorate, __runInitializers
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
2
|
/*
|
|
3
3
|
// Copyright 2024 The Lynx Authors. All rights reserved.
|
|
4
4
|
// Licensed under the Apache License Version 2.0 that can be found in the
|
|
5
5
|
// LICENSE file in the root directory of this source tree.
|
|
6
6
|
*/
|
|
7
|
-
import { genDomGetter, registerAttributeHandler, } from '
|
|
7
|
+
import { genDomGetter, registerAttributeHandler, } from '../../element-reactive/index.js';
|
|
8
8
|
import { commonComponentEventSetting } from '../common/commonEventInitConfiguration.js';
|
|
9
9
|
import { renameEvent } from '../common/renameEvent.js';
|
|
10
|
-
import { registerEventEnableStatusChangeHandler } from '
|
|
10
|
+
import { registerEventEnableStatusChangeHandler } from '../../element-reactive/index.js';
|
|
11
11
|
let XTextareaEvents = (() => {
|
|
12
12
|
let _instanceExtraInitializers = [];
|
|
13
|
-
let
|
|
14
|
-
let
|
|
15
|
-
let
|
|
16
|
-
let _private_handleSendComposingInput_descriptor;
|
|
17
|
-
let _private_handleEnableSelectionEvent_decorators;
|
|
18
|
-
let _private_handleEnableSelectionEvent_descriptor;
|
|
13
|
+
let __handleEnableConfirmEvent_decorators;
|
|
14
|
+
let __handleSendComposingInput_decorators;
|
|
15
|
+
let __handleEnableSelectionEvent_decorators;
|
|
19
16
|
return class XTextareaEvents {
|
|
20
17
|
static {
|
|
21
18
|
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
__esDecorate(this,
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
textareaElement.addEventListener('input', this.#teleportInput, { passive: true });
|
|
29
|
-
textareaElement.addEventListener('compositionend', this.#teleportCompositionendInput, { passive: true });
|
|
30
|
-
}
|
|
31
|
-
else {
|
|
32
|
-
textareaElement.removeEventListener('input', this.#teleportInput);
|
|
33
|
-
textareaElement.removeEventListener('compositionend', this.#teleportCompositionendInput);
|
|
34
|
-
}
|
|
35
|
-
}, "#handleEnableConfirmEvent") }, _private_handleEnableConfirmEvent_decorators, { kind: "method", name: "#handleEnableConfirmEvent", static: false, private: true, access: { has: obj => #handleEnableConfirmEvent in obj, get: obj => obj.#handleEnableConfirmEvent }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
36
|
-
__esDecorate(this, _private_handleSendComposingInput_descriptor = { value: __setFunctionName(function (newVal) {
|
|
37
|
-
this.#sendComposingInput = newVal !== null;
|
|
38
|
-
}, "#handleSendComposingInput") }, _private_handleSendComposingInput_decorators, { kind: "method", name: "#handleSendComposingInput", static: false, private: true, access: { has: obj => #handleSendComposingInput in obj, get: obj => obj.#handleSendComposingInput }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
39
|
-
__esDecorate(this, _private_handleEnableSelectionEvent_descriptor = { value: __setFunctionName(function (status) {
|
|
40
|
-
if (status) {
|
|
41
|
-
this.#getTextareaElement().addEventListener('select', this.#selectEvent, {
|
|
42
|
-
passive: true,
|
|
43
|
-
});
|
|
44
|
-
}
|
|
45
|
-
else {
|
|
46
|
-
this.#getTextareaElement().removeEventListener('select', this.#selectEvent);
|
|
47
|
-
}
|
|
48
|
-
}, "#handleEnableSelectionEvent") }, _private_handleEnableSelectionEvent_decorators, { kind: "method", name: "#handleEnableSelectionEvent", static: false, private: true, access: { has: obj => #handleEnableSelectionEvent in obj, get: obj => obj.#handleEnableSelectionEvent }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
19
|
+
__handleEnableConfirmEvent_decorators = [registerAttributeHandler('input-filter', true), registerEventEnableStatusChangeHandler('lynxinput')];
|
|
20
|
+
__handleSendComposingInput_decorators = [registerAttributeHandler('send-composing-input', true)];
|
|
21
|
+
__handleEnableSelectionEvent_decorators = [registerEventEnableStatusChangeHandler('selection')];
|
|
22
|
+
__esDecorate(this, null, __handleEnableConfirmEvent_decorators, { kind: "method", name: "_handleEnableConfirmEvent", static: false, private: false, access: { has: obj => "_handleEnableConfirmEvent" in obj, get: obj => obj._handleEnableConfirmEvent }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
23
|
+
__esDecorate(this, null, __handleSendComposingInput_decorators, { kind: "method", name: "_handleSendComposingInput", static: false, private: false, access: { has: obj => "_handleSendComposingInput" in obj, get: obj => obj._handleSendComposingInput }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
24
|
+
__esDecorate(this, null, __handleEnableSelectionEvent_decorators, { kind: "method", name: "_handleEnableSelectionEvent", static: false, private: false, access: { has: obj => "_handleEnableSelectionEvent" in obj, get: obj => obj._handleEnableSelectionEvent }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
49
25
|
if (_metadata) Object.defineProperty(this, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
50
26
|
}
|
|
51
27
|
static observedAttributes = ['send-composing-input', 'input-filter'];
|
|
@@ -53,8 +29,20 @@ let XTextareaEvents = (() => {
|
|
|
53
29
|
#sendComposingInput = false;
|
|
54
30
|
#getTextareaElement = genDomGetter(() => this.#dom.shadowRoot, '#textarea');
|
|
55
31
|
#getFormElement = genDomGetter(() => this.#dom.shadowRoot, '#form');
|
|
56
|
-
|
|
57
|
-
|
|
32
|
+
_handleEnableConfirmEvent(status) {
|
|
33
|
+
const textareaElement = this.#getTextareaElement();
|
|
34
|
+
if (status) {
|
|
35
|
+
textareaElement.addEventListener('input', this.#teleportInput, { passive: true });
|
|
36
|
+
textareaElement.addEventListener('compositionend', this.#teleportCompositionendInput, { passive: true });
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
textareaElement.removeEventListener('input', this.#teleportInput);
|
|
40
|
+
textareaElement.removeEventListener('compositionend', this.#teleportCompositionendInput);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
_handleSendComposingInput(newVal) {
|
|
44
|
+
this.#sendComposingInput = newVal !== null;
|
|
45
|
+
}
|
|
58
46
|
#teleportEvent = (event) => {
|
|
59
47
|
const eventType = renameEvent[event.type] ?? event.type;
|
|
60
48
|
this.#dom.dispatchEvent(new CustomEvent(eventType, {
|
|
@@ -112,7 +100,16 @@ let XTextareaEvents = (() => {
|
|
|
112
100
|
}));
|
|
113
101
|
}
|
|
114
102
|
};
|
|
115
|
-
|
|
103
|
+
_handleEnableSelectionEvent(status) {
|
|
104
|
+
if (status) {
|
|
105
|
+
this.#getTextareaElement().addEventListener('select', this.#selectEvent, {
|
|
106
|
+
passive: true,
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
else {
|
|
110
|
+
this.#getTextareaElement().removeEventListener('select', this.#selectEvent);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
116
113
|
#selectEvent = () => {
|
|
117
114
|
const input = this.#getTextareaElement();
|
|
118
115
|
this.#dom.dispatchEvent(new CustomEvent('selection', {
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @module elements/XTextarea
|
|
3
|
+
*
|
|
4
|
+
* `x-textarea` provides a multi-line input field.
|
|
5
|
+
*
|
|
6
|
+
* Attributes:
|
|
7
|
+
* - `value`: Input value.
|
|
8
|
+
* - `disabled`: 'true' | 'false'.
|
|
9
|
+
* - `placeholder`: Placeholder text.
|
|
10
|
+
* - `maxlength`: Max character length (default 140).
|
|
11
|
+
* - `auto-height`: 'true' | 'false', auto resize height.
|
|
12
|
+
* - `confirm-type`: 'send' | 'search' | 'next' | 'go' | 'done'.
|
|
13
|
+
* - `confirm-enter`: 'true' | 'false', trigger confirm event on enter.
|
|
14
|
+
* - `max-height`: Max height style.
|
|
15
|
+
* - `min-height`: Min height style.
|
|
16
|
+
* - `placeholder-color`: Color of the placeholder text.
|
|
17
|
+
* - `placeholder-font-weight`: Font weight of the placeholder.
|
|
18
|
+
* - `placeholder-font-size`: Font size of the placeholder.
|
|
19
|
+
* - `placeholder-font-family`: Font family of the placeholder.
|
|
20
|
+
*
|
|
21
|
+
* Events:
|
|
22
|
+
* - `input`: Fired on input.
|
|
23
|
+
* - `focus`: Fired on focus.
|
|
24
|
+
* - `blur`: Fired on blur.
|
|
25
|
+
* - `confirm`: Fired on confirm/enter.
|
|
26
|
+
* - `linechange`: Fired when line count changes.
|
|
27
|
+
*
|
|
28
|
+
* Methods:
|
|
29
|
+
* - `addText({ text })`: Inserts text.
|
|
30
|
+
* - `setValue({ value, index })`: Sets value and cursor.
|
|
31
|
+
* - `getValue()`: Returns value and selection.
|
|
32
|
+
* - `select()`: Selects all text.
|
|
33
|
+
* - `setSelectionRange({ selectionStart, selectionEnd })`: Sets selection.
|
|
34
|
+
*/
|
|
35
|
+
export { XTextarea } from './XTextarea.js';
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
// Copyright 2024 The Lynx Authors. All rights reserved.
|
|
2
|
+
// Licensed under the Apache License Version 2.0 that can be found in the
|
|
3
|
+
// LICENSE file in the root directory of this source tree.
|
|
4
|
+
/**
|
|
5
|
+
* @module elements/XTextarea
|
|
6
|
+
*
|
|
7
|
+
* `x-textarea` provides a multi-line input field.
|
|
8
|
+
*
|
|
9
|
+
* Attributes:
|
|
10
|
+
* - `value`: Input value.
|
|
11
|
+
* - `disabled`: 'true' | 'false'.
|
|
12
|
+
* - `placeholder`: Placeholder text.
|
|
13
|
+
* - `maxlength`: Max character length (default 140).
|
|
14
|
+
* - `auto-height`: 'true' | 'false', auto resize height.
|
|
15
|
+
* - `confirm-type`: 'send' | 'search' | 'next' | 'go' | 'done'.
|
|
16
|
+
* - `confirm-enter`: 'true' | 'false', trigger confirm event on enter.
|
|
17
|
+
* - `max-height`: Max height style.
|
|
18
|
+
* - `min-height`: Min height style.
|
|
19
|
+
* - `placeholder-color`: Color of the placeholder text.
|
|
20
|
+
* - `placeholder-font-weight`: Font weight of the placeholder.
|
|
21
|
+
* - `placeholder-font-size`: Font size of the placeholder.
|
|
22
|
+
* - `placeholder-font-family`: Font family of the placeholder.
|
|
23
|
+
*
|
|
24
|
+
* Events:
|
|
25
|
+
* - `input`: Fired on input.
|
|
26
|
+
* - `focus`: Fired on focus.
|
|
27
|
+
* - `blur`: Fired on blur.
|
|
28
|
+
* - `confirm`: Fired on confirm/enter.
|
|
29
|
+
* - `linechange`: Fired when line count changes.
|
|
30
|
+
*
|
|
31
|
+
* Methods:
|
|
32
|
+
* - `addText({ text })`: Inserts text.
|
|
33
|
+
* - `setValue({ value, index })`: Sets value and cursor.
|
|
34
|
+
* - `getValue()`: Returns value and selection.
|
|
35
|
+
* - `select()`: Selects all text.
|
|
36
|
+
* - `setSelectionRange({ selectionStart, selectionEnd })`: Sets selection.
|
|
37
|
+
*/
|
|
38
|
+
export { XTextarea } from './XTextarea.js';
|
|
39
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
import { type AttributeReactiveClass } from '
|
|
1
|
+
import { type AttributeReactiveClass } from '../../element-reactive/index.js';
|
|
2
2
|
import type { XBlurView } from './XBlurView.js';
|
|
3
3
|
export declare class BlurRadius implements InstanceType<AttributeReactiveClass<typeof XBlurView>> {
|
|
4
4
|
#private;
|
|
5
5
|
static observedAttributes: string[];
|
|
6
|
+
_handleBlurRadius(newVal: string | null): void;
|
|
6
7
|
constructor(dom: HTMLElement);
|
|
7
8
|
}
|