@flatfile/angular-sdk
Version:
Flatfile SDK for Angular
102 lines • 13.8 kB
JavaScript
import { Injectable, signal, computed } from '@angular/core';
import { createWorkbookFromSheet, initNewSpace, } from '@flatfile/embedded-utils';
import getSpace from '../../utils/getSpace';
import * as i0 from "@angular/core";
const DEFAULT_API_URL = 'https://platform.flatfile.com/api';
export class SpaceService {
constructor() {
this._loading = signal(false);
this.loading = computed(() => this._loading());
this._spaceInitialized = signal(undefined);
this.spaceInitialized = computed(() => this._spaceInitialized());
this.OpenEmbed = this.startFlatfile;
}
async getOrCreateSpace(spaceProps) {
const { publishableKey } = spaceProps;
if (!publishableKey) {
return getSpace(spaceProps);
}
const { name, namespace, languageOverride, translationsPath, workbook, document, themeConfig, sidebarConfig, userInfo, apiUrl, sheet, onSubmit, } = spaceProps;
let createdWorkbook = workbook;
const isAutoConfig = !createdWorkbook && !sheet;
if (!createdWorkbook && sheet) {
createdWorkbook = createWorkbookFromSheet(sheet, !!onSubmit);
}
return initNewSpace({
name,
namespace,
languageOverride,
translationsPath,
publishableKey,
workbook: createdWorkbook,
document,
themeConfig,
sidebarConfig,
userInfo,
isAutoConfig,
apiUrl: apiUrl || DEFAULT_API_URL,
});
}
async initSpace(spaceProps) {
if (!spaceProps) {
console.warn('spaceProps is required');
return;
}
if (this.spaceInitialized() && !this.config?.resetOnClose) {
console.warn('Space is already initialized');
return;
}
this._loading.set(true);
spaceProps.apiUrl ||= DEFAULT_API_URL;
window.CROSSENV_FLATFILE_API_URL = spaceProps.apiUrl;
this.currentSpaceProps = spaceProps;
try {
this.spaceResponse = await this.getOrCreateSpace(spaceProps);
const { space } = this.spaceResponse;
if (!space) {
throw new Error('Missing space from response');
}
const { id: spaceId, accessToken, guestLink } = space;
if (!spaceId || typeof spaceId !== 'string') {
throw new Error('Missing spaceId from space response');
}
if (!guestLink || typeof guestLink !== 'string') {
throw new Error('Missing guest link from space response');
}
if (!accessToken || typeof accessToken !== 'string') {
throw new Error('Missing access token from space response');
}
const formattedSpaceProps = {
...spaceProps,
spaceUrl: guestLink,
localAccessToken: accessToken,
apiUrl: spaceProps.apiUrl,
workbook: spaceProps.workbook || this.spaceResponse.workbooks?.[0],
};
this._spaceInitialized.set(formattedSpaceProps);
this._loading.set(false);
return formattedSpaceProps;
}
catch (error) {
console.error('Failed to initialize space:', error);
throw error;
}
}
async startFlatfile(spaceProps) {
this.currentSpaceProps = spaceProps;
return this.initSpace(this.currentSpaceProps);
}
closeEmbed() {
this._loading.set(false);
this._spaceInitialized.set(undefined);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SpaceService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SpaceService, providedIn: 'root' }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SpaceService, decorators: [{
type: Injectable,
args: [{
providedIn: 'root',
}]
}] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"space.service.js","sourceRoot":"","sources":["../../../../src/lib/sdk/space.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, signal, computed } from '@angular/core'\nimport {\n  type ISpace,\n  type ReusedSpaceWithAccessToken,\n  type SimpleOnboarding,\n  createWorkbookFromSheet,\n  initNewSpace,\n  InitialResourceData,\n} from '@flatfile/embedded-utils'\nimport getSpace, { GetSpaceReturn } from '../../utils/getSpace'\nimport { Flatfile } from '@flatfile/api'\n\ntype ReusedOrOnboarding = ReusedSpaceWithAccessToken | SimpleOnboarding\n\nconst DEFAULT_API_URL = 'https://platform.flatfile.com/api'\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class SpaceService {\n  private readonly _loading = signal(false)\n  readonly loading = computed(() => this._loading())\n\n  private readonly _spaceInitialized = signal<object | undefined>(undefined)\n  readonly spaceInitialized = computed(() => this._spaceInitialized())\n\n  private currentSpaceProps?: ISpace\n  localSpaceData: Record<string, any> | undefined\n\n  spaceResponse?: Partial<InitialResourceData> & { space: Flatfile.Space }\n\n  config?: {\n    resetOnClose: boolean\n  }\n\n  private async getOrCreateSpace(\n    spaceProps: ReusedOrOnboarding\n  ): Promise<InitialResourceData | GetSpaceReturn> {\n    const { publishableKey } = spaceProps\n    if (!publishableKey) {\n      return getSpace(spaceProps)\n    }\n\n    const {\n      name,\n      namespace,\n      languageOverride,\n      translationsPath,\n      workbook,\n      document,\n      themeConfig,\n      sidebarConfig,\n      userInfo,\n      apiUrl,\n      sheet,\n      onSubmit,\n    } = spaceProps\n\n    let createdWorkbook = workbook\n    const isAutoConfig = !createdWorkbook && !sheet\n\n    if (!createdWorkbook && sheet) {\n      createdWorkbook = createWorkbookFromSheet(sheet, !!onSubmit)\n    }\n\n    return initNewSpace({\n      name,\n      namespace,\n      languageOverride,\n      translationsPath,\n      publishableKey,\n      workbook: createdWorkbook,\n      document,\n      themeConfig,\n      sidebarConfig,\n      userInfo,\n      isAutoConfig,\n      apiUrl: apiUrl || DEFAULT_API_URL,\n    })\n  }\n\n  async initSpace(spaceProps: ISpace): Promise<any> {\n    if (!spaceProps) {\n      console.warn('spaceProps is required')\n      return\n    }\n\n    if (this.spaceInitialized() && !this.config?.resetOnClose) {\n      console.warn('Space is already initialized')\n      return\n    }\n    this._loading.set(true)\n\n    spaceProps.apiUrl ||= DEFAULT_API_URL\n    ;(window as any).CROSSENV_FLATFILE_API_URL = spaceProps.apiUrl\n\n    this.currentSpaceProps = spaceProps\n\n    try {\n      this.spaceResponse = await this.getOrCreateSpace(spaceProps)\n      const { space } = this.spaceResponse\n\n      if (!space) {\n        throw new Error('Missing space from response')\n      }\n\n      const { id: spaceId, accessToken, guestLink } = space\n\n      if (!spaceId || typeof spaceId !== 'string') {\n        throw new Error('Missing spaceId from space response')\n      }\n\n      if (!guestLink || typeof guestLink !== 'string') {\n        throw new Error('Missing guest link from space response')\n      }\n\n      if (!accessToken || typeof accessToken !== 'string') {\n        throw new Error('Missing access token from space response')\n      }\n\n      const formattedSpaceProps = {\n        ...spaceProps,\n        spaceUrl: guestLink,\n        localAccessToken: accessToken,\n        apiUrl: spaceProps.apiUrl,\n        workbook: spaceProps.workbook || this.spaceResponse.workbooks?.[0],\n      }\n      this._spaceInitialized.set(formattedSpaceProps)\n      this._loading.set(false)\n      return formattedSpaceProps\n    } catch (error) {\n      console.error('Failed to initialize space:', error)\n      throw error\n    }\n  }\n\n  OpenEmbed = this.startFlatfile\n  async startFlatfile(spaceProps: ISpace): Promise<void> {\n    this.currentSpaceProps = spaceProps\n    return this.initSpace(this.currentSpaceProps)\n  }\n\n  closeEmbed(): void {\n    this._loading.set(false)\n    this._spaceInitialized.set(undefined)\n  }\n}\n"]}