@compdfkit_pdf_sdk/react_native
Version:
ComPDFKit for React Native is a comprehensive SDK that allows you to quickly add PDF functionality to Android, iOS, and React Native applications.
82 lines (77 loc) • 2.46 kB
JavaScript
/**
* Copyright © 2014-2025 PDF Technologies, Inc. All Rights Reserved.
*
* THIS SOURCE CODE AND ANY ACCOMPANYING DOCUMENTATION ARE PROTECTED BY INTERNATIONAL COPYRIGHT LAW
* AND MAY NOT BE RESOLD OR REDISTRIBUTED. USAGE IS BOUND TO THE ComPDFKit LICENSE AGREEMENT.
* UNAUTHORIZED REPRODUCTION OR DISTRIBUTION IS SUBJECT TO CIVIL AND CRIMINAL PENALTIES.
* This notice may not be removed from this file.
*/
import { CPDFWidgetType } from "../../configuration/CPDFOptions";
import { NativeModules, findNodeHandle } from 'react-native';
const {
CPDFViewManager
} = NativeModules;
/**
* Base class for form widgets, storing essential form information.
*
* This class represents a form widget in a PDF document, containing basic attributes
* such as type, title, and the page it appears on.
* The `fromJson` method allows converting JSON data into form widget objects.
*
* @class CPDFWidget
* @memberof CPDFWidget
*
* @property {CPDFWidgetType} type - The type of the form widget.
* @property {string} title - The title of the form widget (default: empty string).
* @property {number} page - The page number where the form widget appears (default: 0).
*/
export class CPDFWidget {
/**
* The type of the form widget.
*/
/**
* The title of the form widget (default: empty string).
*/
/**
* The page number where the form widget appears (default: 0).
*/
constructor(viewerRef, params) {
this.type = CPDFWidget.parseType(params.type);
this.title = params.title ?? "";
this.page = params.page ?? 0;
this.uuid = params.uuid ?? "";
this._viewerRef = viewerRef;
}
static fromJson(json, viewerRef) {
return new this(viewerRef, json);
}
static fromJsonArray(jsonArray, viewerRef) {
return jsonArray.map(item => new this(viewerRef, item));
}
static parseType(type) {
return Object.values(CPDFWidgetType).includes(type) ? type : CPDFWidgetType.UNKNOWN;
}
toJSON() {
const {
_viewerRef,
...data
} = this;
return data;
}
/**
* Update the appearance of a form widget.
* @returns
*/
updateAp = () => {
const tag = findNodeHandle(this._viewerRef);
if (tag) {
try {
return CPDFViewManager.updateAp(tag, this.page, this.uuid);
} catch (error) {
console.log(error);
}
}
return Promise.reject(new Error('Unable to find the native view reference'));
};
}
//# sourceMappingURL=CPDFWidget.js.map