@c8y/ngx-components 1021.22.76 → 1021.22.77

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 +1 @@
1
- {"version":3,"file":"branding-import-modal.component.d.ts","sourceRoot":"","sources":["../../../../../branding/shared/lazy/branding-import-modal/branding-import-modal.component.ts"],"names":[],"mappings":"AACA,OAAO,EAAc,WAAW,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC1F,OAAO,EAAE,uBAAuB,EAAE,MAAM,6DAA6D,CAAC;AAEtG,OAAO,EAAe,mBAAmB,EAAE,MAAM,wCAAwC,CAAC;AAC1F,OAAO,EAAE,oBAAoB,EAAE,MAAM,0CAA0C,CAAC;;AAEhF,qBAMa,4BAA4B;IAcrC,OAAO,CAAC,uBAAuB;IAC/B,OAAO,CAAC,GAAG;IACX,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,SAAS;IAhB0B,KAAK,EAAE,cAAc,CAAC;IAEnE,MAAM,gBAGH;IACH,KAAK,EAAE,WAAW,EAAE,CAAM;IAC1B,OAAO,UAAS;IAEhB,OAAO,CAAC,QAAQ,CAAa;IAC7B,OAAO,CAAC,OAAO,CAAyB;gBAG9B,uBAAuB,EAAE,uBAAuB,EAChD,GAAG,EAAE,UAAU,EACf,YAAY,EAAE,mBAAmB,EACjC,SAAS,EAAE,oBAAoB;IAGnC,WAAW,CAAC,KAAK,EAAE,WAAW,EAAE;IAehC,MAAM,CAAC,IAAI,EAAE,IAAI;IAwFvB,MAAM;yCA3HK,4BAA4B;2CAA5B,4BAA4B;CA8HxC"}
1
+ {"version":3,"file":"branding-import-modal.component.d.ts","sourceRoot":"","sources":["../../../../../branding/shared/lazy/branding-import-modal/branding-import-modal.component.ts"],"names":[],"mappings":"AACA,OAAO,EAAc,WAAW,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC1F,OAAO,EAAE,uBAAuB,EAAE,MAAM,6DAA6D,CAAC;AAEtG,OAAO,EAAe,mBAAmB,EAAE,MAAM,wCAAwC,CAAC;AAC1F,OAAO,EAAE,oBAAoB,EAAE,MAAM,0CAA0C,CAAC;;AAEhF,qBAMa,4BAA4B;IAcrC,OAAO,CAAC,uBAAuB;IAC/B,OAAO,CAAC,GAAG;IACX,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,SAAS;IAhB0B,KAAK,EAAE,cAAc,CAAC;IAEnE,MAAM,gBAGH;IACH,KAAK,EAAE,WAAW,EAAE,CAAM;IAC1B,OAAO,UAAS;IAEhB,OAAO,CAAC,QAAQ,CAAa;IAC7B,OAAO,CAAC,OAAO,CAAyB;gBAG9B,uBAAuB,EAAE,uBAAuB,EAChD,GAAG,EAAE,UAAU,EACf,YAAY,EAAE,mBAAmB,EACjC,SAAS,EAAE,oBAAoB;IAGnC,WAAW,CAAC,KAAK,EAAE,WAAW,EAAE;IAehC,MAAM,CAAC,IAAI,EAAE,IAAI;IAsFvB,MAAM;yCAzHK,4BAA4B;2CAA5B,4BAA4B;CA4HxC"}
@@ -42,12 +42,9 @@ export class BrandingImportModalComponent {
42
42
  if (!versionDetails) {
43
43
  throw Error('No version details provided');
44
44
  }
45
- try {
46
- // verify if branding is already present
47
- await this.brandings.getBrandingOptionsForVersion();
48
- }
49
- catch (e) {
50
- // otherwise get started using branding
45
+ // verify if branding is already present
46
+ const { variants } = await this.brandings.loadBrandingVariants();
47
+ if (!variants?.length) {
51
48
  await this.brandings.getStartedUsingBranding();
52
49
  }
53
50
  const importedZipEntries = await firstValueFrom(this.zip.getEntries(file));
@@ -111,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
111
108
  type: ViewChild,
112
109
  args: [ModalComponent, { static: true }]
113
110
  }] } });
114
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"branding-import-modal.component.js","sourceRoot":"","sources":["../../../../../../branding/shared/lazy/branding-import-modal/branding-import-modal.component.ts","../../../../../../branding/shared/lazy/branding-import-modal/branding-import-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild } from '@angular/core';\nimport { CoreModule, DroppedFile, ModalComponent, ZipService } from '@c8y/ngx-components';\nimport { AddBrandingModalService } from '@c8y/ngx-components/branding/shared/lazy/add-branding-modal';\nimport { firstValueFrom } from 'rxjs';\nimport { StaticAsset, StaticAssetsService } from '@c8y/ngx-components/static-assets/data';\nimport { StoreBrandingService } from '@c8y/ngx-components/branding/shared/data';\n\n@Component({\n  selector: 'c8y-branding-import-modal',\n  templateUrl: './branding-import-modal.component.html',\n  standalone: true,\n  imports: [CoreModule]\n})\nexport class BrandingImportModalComponent {\n  @ViewChild(ModalComponent, { static: true }) modal: ModalComponent;\n\n  result = new Promise<void>((resolve, reject) => {\n    this._resovle = resolve;\n    this._reject = reject;\n  });\n  files: DroppedFile[] = [];\n  loading = false;\n\n  private _resovle: () => void;\n  private _reject: (reason?: any) => void;\n\n  constructor(\n    private addBrandingModalService: AddBrandingModalService,\n    private zip: ZipService,\n    private staticAssets: StaticAssetsService,\n    private brandings: StoreBrandingService\n  ) {}\n\n  async droppedFile(event: DroppedFile[]) {\n    this.loading = true;\n    try {\n      this.files = event;\n      await this.import(event[0].file);\n    } catch (e) {\n      console.error(e);\n      this.files = [];\n      this.loading = false;\n      return;\n    }\n    this.modal._close();\n    this._resovle();\n  }\n\n  async import(file: File) {\n    const versionDetails = await this.addBrandingModalService.openAddBrandingModal();\n    if (!versionDetails) {\n      throw Error('No version details provided');\n    }\n\n    try {\n      // verify if branding is already present\n      await this.brandings.getBrandingOptionsForVersion();\n    } catch (e) {\n      // otherwise get started using branding\n      await this.brandings.getStartedUsingBranding();\n    }\n\n    const importedZipEntries = await firstValueFrom(this.zip.getEntries(file));\n    const staticAssetsEntry = importedZipEntries.find(\n      entry => entry.filename === this.staticAssets.fileNames.exportZipName\n    );\n    if (!staticAssetsEntry) {\n      throw Error(\n        `Missing \"${this.staticAssets.fileNames.exportZipName}\" file in the uploaded zip.`\n      );\n    }\n    const staticAssetsZip = await firstValueFrom(this.zip.getData(staticAssetsEntry));\n    const staticAssetsZipFile = new File([staticAssetsZip], staticAssetsEntry.filename);\n    const staticAssetsZipEntries = await firstValueFrom(this.zip.getEntries(staticAssetsZipFile));\n    const filesToAdd = new Array<File>();\n    let oldAssets: Array<StaticAsset>;\n    let newAssets: Array<StaticAsset>;\n    for (const entry of staticAssetsZipEntries) {\n      if (entry.filename === this.brandings.fileNames.manifest) {\n        continue;\n      }\n      if (entry.filename === this.staticAssets.fileNames.contents) {\n        const fileContent = await (await firstValueFrom(this.zip.getData(entry))).text();\n        oldAssets = JSON.parse(fileContent);\n        continue;\n      }\n      const file = await firstValueFrom(this.zip.getData(entry));\n      filesToAdd.push(new File([file], entry.filename));\n    }\n    if (filesToAdd.length > 0) {\n      const currentStaticAssets = await this.staticAssets.listFilesCached('branding', true);\n      newAssets = await this.staticAssets.addFilesToStaticAssets(\n        'branding',\n        filesToAdd,\n        currentStaticAssets,\n        false\n      );\n    }\n\n    const publicOptionsEntry = importedZipEntries.find(\n      entry => entry.filename === this.brandings.fileNames.exportZipName\n    );\n    if (!publicOptionsEntry) {\n      throw Error(`Missing \"${this.brandings.fileNames.exportZipName}\" file in the uploaded zip.`);\n    }\n    const publicOptionsZip = await firstValueFrom(this.zip.getData(publicOptionsEntry));\n    const publicOptionsZipFile = new File([publicOptionsZip], publicOptionsEntry.filename);\n\n    const publicOptionsFiles = await firstValueFrom(this.zip.getEntries(publicOptionsZipFile));\n    const optionsFileEntry = publicOptionsFiles.find(\n      entry => entry.filename === this.brandings.fileNames.options\n    );\n    if (!optionsFileEntry) {\n      throw Error(\n        `Missing \"${this.brandings.fileNames.options}\" file in \"${this.brandings.fileNames.exportZipName}\" file of the uploaded zip.`\n      );\n    }\n\n    const optionsFile = await firstValueFrom(this.zip.getData(optionsFileEntry));\n    let options = JSON.parse(await optionsFile.text());\n\n    if (oldAssets.length && newAssets.length) {\n      options = this.brandings.replaceBrandingAssetsInBrandingOptions(\n        options,\n        oldAssets,\n        newAssets\n      );\n    }\n\n    const zip = await this.brandings.getBrandingZip(options);\n\n    await this.brandings.saveBranding(zip, `${versionDetails.brandingName}-1`, [\n      versionDetails.brandingName\n    ]);\n  }\n\n  cancel() {\n    this._reject();\n  }\n}\n","<c8y-modal\n  [title]=\"'Import branding variant'\"\n  [headerClasses]=\"'dialog-header'\"\n  (onDismiss)=\"cancel()\"\n  [labels]=\"{ cancel: 'Cancel' }\"\n>\n  <ng-container c8y-modal-title>\n    <span c8yIcon=\"import\"></span>\n  </ng-container>\n  <div class=\"p-t-16 p-b-16 p-l-24 p-r-24 separator-bottom\">\n    <p\n      class=\"text-medium text-center text-16\"\n      translate\n    >\n      Easily copy any branding variant from any tenant\n    </p>\n    <p translate class=\"p-t-8\">\n      Export the branding variant from the source tenant and import the .zip file here. This process\n      allows you to maintain consistent branding across multiple tenants efficiently.\n    </p>\n  </div>\n  <div\n    class=\"p-24 m-r-auto m-l-auto\"\n    style=\"max-width: 300px\"\n  >\n    <c8y-drop-area\n      [icon]=\"'upload'\"\n      (dropped)=\"droppedFile($event)\"\n      [files]=\"files\"\n      [accept]=\"'.zip'\"\n      [maxAllowedFiles]=\"1\"\n      [loading]=\"loading\"\n    ></c8y-drop-area>\n  </div>\n</c8y-modal>\n"]}
111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"branding-import-modal.component.js","sourceRoot":"","sources":["../../../../../../branding/shared/lazy/branding-import-modal/branding-import-modal.component.ts","../../../../../../branding/shared/lazy/branding-import-modal/branding-import-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild } from '@angular/core';\nimport { CoreModule, DroppedFile, ModalComponent, ZipService } from '@c8y/ngx-components';\nimport { AddBrandingModalService } from '@c8y/ngx-components/branding/shared/lazy/add-branding-modal';\nimport { firstValueFrom } from 'rxjs';\nimport { StaticAsset, StaticAssetsService } from '@c8y/ngx-components/static-assets/data';\nimport { StoreBrandingService } from '@c8y/ngx-components/branding/shared/data';\n\n@Component({\n  selector: 'c8y-branding-import-modal',\n  templateUrl: './branding-import-modal.component.html',\n  standalone: true,\n  imports: [CoreModule]\n})\nexport class BrandingImportModalComponent {\n  @ViewChild(ModalComponent, { static: true }) modal: ModalComponent;\n\n  result = new Promise<void>((resolve, reject) => {\n    this._resovle = resolve;\n    this._reject = reject;\n  });\n  files: DroppedFile[] = [];\n  loading = false;\n\n  private _resovle: () => void;\n  private _reject: (reason?: any) => void;\n\n  constructor(\n    private addBrandingModalService: AddBrandingModalService,\n    private zip: ZipService,\n    private staticAssets: StaticAssetsService,\n    private brandings: StoreBrandingService\n  ) {}\n\n  async droppedFile(event: DroppedFile[]) {\n    this.loading = true;\n    try {\n      this.files = event;\n      await this.import(event[0].file);\n    } catch (e) {\n      console.error(e);\n      this.files = [];\n      this.loading = false;\n      return;\n    }\n    this.modal._close();\n    this._resovle();\n  }\n\n  async import(file: File) {\n    const versionDetails = await this.addBrandingModalService.openAddBrandingModal();\n    if (!versionDetails) {\n      throw Error('No version details provided');\n    }\n\n    // verify if branding is already present\n    const { variants } = await this.brandings.loadBrandingVariants();\n    if (!variants?.length) {\n      await this.brandings.getStartedUsingBranding();\n    }\n\n    const importedZipEntries = await firstValueFrom(this.zip.getEntries(file));\n    const staticAssetsEntry = importedZipEntries.find(\n      entry => entry.filename === this.staticAssets.fileNames.exportZipName\n    );\n    if (!staticAssetsEntry) {\n      throw Error(\n        `Missing \"${this.staticAssets.fileNames.exportZipName}\" file in the uploaded zip.`\n      );\n    }\n    const staticAssetsZip = await firstValueFrom(this.zip.getData(staticAssetsEntry));\n    const staticAssetsZipFile = new File([staticAssetsZip], staticAssetsEntry.filename);\n    const staticAssetsZipEntries = await firstValueFrom(this.zip.getEntries(staticAssetsZipFile));\n    const filesToAdd = new Array<File>();\n    let oldAssets: Array<StaticAsset>;\n    let newAssets: Array<StaticAsset>;\n    for (const entry of staticAssetsZipEntries) {\n      if (entry.filename === this.brandings.fileNames.manifest) {\n        continue;\n      }\n      if (entry.filename === this.staticAssets.fileNames.contents) {\n        const fileContent = await (await firstValueFrom(this.zip.getData(entry))).text();\n        oldAssets = JSON.parse(fileContent);\n        continue;\n      }\n      const file = await firstValueFrom(this.zip.getData(entry));\n      filesToAdd.push(new File([file], entry.filename));\n    }\n    if (filesToAdd.length > 0) {\n      const currentStaticAssets = await this.staticAssets.listFilesCached('branding', true);\n      newAssets = await this.staticAssets.addFilesToStaticAssets(\n        'branding',\n        filesToAdd,\n        currentStaticAssets,\n        false\n      );\n    }\n\n    const publicOptionsEntry = importedZipEntries.find(\n      entry => entry.filename === this.brandings.fileNames.exportZipName\n    );\n    if (!publicOptionsEntry) {\n      throw Error(`Missing \"${this.brandings.fileNames.exportZipName}\" file in the uploaded zip.`);\n    }\n    const publicOptionsZip = await firstValueFrom(this.zip.getData(publicOptionsEntry));\n    const publicOptionsZipFile = new File([publicOptionsZip], publicOptionsEntry.filename);\n\n    const publicOptionsFiles = await firstValueFrom(this.zip.getEntries(publicOptionsZipFile));\n    const optionsFileEntry = publicOptionsFiles.find(\n      entry => entry.filename === this.brandings.fileNames.options\n    );\n    if (!optionsFileEntry) {\n      throw Error(\n        `Missing \"${this.brandings.fileNames.options}\" file in \"${this.brandings.fileNames.exportZipName}\" file of the uploaded zip.`\n      );\n    }\n\n    const optionsFile = await firstValueFrom(this.zip.getData(optionsFileEntry));\n    let options = JSON.parse(await optionsFile.text());\n\n    if (oldAssets.length && newAssets.length) {\n      options = this.brandings.replaceBrandingAssetsInBrandingOptions(\n        options,\n        oldAssets,\n        newAssets\n      );\n    }\n\n    const zip = await this.brandings.getBrandingZip(options);\n\n    await this.brandings.saveBranding(zip, `${versionDetails.brandingName}-1`, [\n      versionDetails.brandingName\n    ]);\n  }\n\n  cancel() {\n    this._reject();\n  }\n}\n","<c8y-modal\n  [title]=\"'Import branding variant'\"\n  [headerClasses]=\"'dialog-header'\"\n  (onDismiss)=\"cancel()\"\n  [labels]=\"{ cancel: 'Cancel' }\"\n>\n  <ng-container c8y-modal-title>\n    <span c8yIcon=\"import\"></span>\n  </ng-container>\n  <div class=\"p-t-16 p-b-16 p-l-24 p-r-24 separator-bottom\">\n    <p\n      class=\"text-medium text-center text-16\"\n      translate\n    >\n      Easily copy any branding variant from any tenant\n    </p>\n    <p translate class=\"p-t-8\">\n      Export the branding variant from the source tenant and import the .zip file here. This process\n      allows you to maintain consistent branding across multiple tenants efficiently.\n    </p>\n  </div>\n  <div\n    class=\"p-24 m-r-auto m-l-auto\"\n    style=\"max-width: 300px\"\n  >\n    <c8y-drop-area\n      [icon]=\"'upload'\"\n      (dropped)=\"droppedFile($event)\"\n      [files]=\"files\"\n      [accept]=\"'.zip'\"\n      [maxAllowedFiles]=\"1\"\n      [loading]=\"loading\"\n    ></c8y-drop-area>\n  </div>\n</c8y-modal>\n"]}
@@ -169,12 +169,9 @@ class BrandingImportModalComponent {
169
169
  if (!versionDetails) {
170
170
  throw Error('No version details provided');
171
171
  }
172
- try {
173
- // verify if branding is already present
174
- await this.brandings.getBrandingOptionsForVersion();
175
- }
176
- catch (e) {
177
- // otherwise get started using branding
172
+ // verify if branding is already present
173
+ const { variants } = await this.brandings.loadBrandingVariants();
174
+ if (!variants?.length) {
178
175
  await this.brandings.getStartedUsingBranding();
179
176
  }
180
177
  const importedZipEntries = await firstValueFrom(this.zip.getEntries(file));