@milaboratories/milaboratories.ui-examples.model 1.1.18 → 1.1.20

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/dist/index.cjs CHANGED
@@ -9,35 +9,51 @@ var $BlockArgs = zod.z.object({
9
9
  });
10
10
  var platforma = model.BlockModel.create("Heavy").withArgs({ numbers: [1, 2, 3, 4] }).withUiState({ dataTableState: void 0, dynamicSections: [] }).output("numbers", (ctx) => ctx.outputs?.resolve("numbers")?.getDataAsJson()).output("pt", (ctx) => {
11
11
  if (!ctx.uiState?.dataTableState?.tableState.pTableParams?.filters) return void 0;
12
- return model.createPlDataTable(ctx, [
13
- {
14
- id: "example",
15
- spec: {
16
- kind: "PColumn",
17
- valueType: "String",
18
- name: "example",
19
- annotations: {
20
- "pl7.app/label": "String column"
21
- },
22
- axesSpec: [
23
- {
24
- type: "Int",
25
- name: "index",
26
- annotations: {
27
- "pl7.app/label": "Int axis"
12
+ return model.createPlDataTable(
13
+ ctx,
14
+ [
15
+ {
16
+ id: "example",
17
+ spec: {
18
+ kind: "PColumn",
19
+ valueType: "String",
20
+ name: "example",
21
+ annotations: {
22
+ "pl7.app/label": "String column",
23
+ "pl7.app/discreteValues": '["up","down"]'
24
+ },
25
+ axesSpec: [
26
+ {
27
+ type: "Int",
28
+ name: "index",
29
+ annotations: {
30
+ "pl7.app/label": "Int axis",
31
+ "pl7.app/discreteValues": "[1,2]"
32
+ }
33
+ },
34
+ {
35
+ type: "Float",
36
+ name: "value",
37
+ annotations: {
38
+ "pl7.app/label": "Float axis"
39
+ }
28
40
  }
29
- }
41
+ ]
42
+ },
43
+ data: [
44
+ { key: [1, 1.1], val: "1" },
45
+ { key: [2, 2.2], val: "2" }
30
46
  ]
31
- },
32
- data: [
33
- { key: [1], val: "1" },
34
- { key: [2], val: "2" }
47
+ }
48
+ ],
49
+ ctx.uiState.dataTableState.tableState,
50
+ {
51
+ filters: [
52
+ ...ctx.uiState.dataTableState.tableState.pTableParams?.filters ?? [],
53
+ ...ctx.uiState.dataTableState.filterModel?.filters ?? []
35
54
  ]
36
55
  }
37
- ], ctx.uiState.dataTableState.tableState, [
38
- ...ctx.uiState.dataTableState.tableState.pTableParams?.filters ?? [],
39
- ...ctx.uiState.dataTableState.filterModel?.filters ?? []
40
- ]);
56
+ );
41
57
  }).sections((ctx) => {
42
58
  const dynamicSections = (ctx.uiState.dynamicSections ?? []).map((it) => ({
43
59
  type: "link",
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts"],"names":["z","BlockModel","createPlDataTable"],"mappings":"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","file":"index.cjs","sourcesContent":["import type {\n InferHrefType,\n InferOutputsType,\n PlDataTableState,\n PlTableFiltersModel,\n PColumn,\n PColumnValues,\n PObjectId } from '@platforma-sdk/model';\nimport {\n BlockModel,\n createPlDataTable,\n} from '@platforma-sdk/model';\nimport { z } from 'zod';\n\nexport const $BlockArgs = z.object({\n numbers: z.array(z.coerce.number()),\n});\n\nexport type BlockArgs = z.infer<typeof $BlockArgs>;\n\nexport type TableState = {\n tableState: PlDataTableState;\n filterModel: PlTableFiltersModel;\n};\n\nexport type UiState = {\n dataTableState: TableState | undefined;\n dynamicSections: {\n id: string;\n label: string;\n }[];\n};\n\nexport const platforma = BlockModel.create('Heavy')\n\n .withArgs<BlockArgs>({ numbers: [1, 2, 3, 4] })\n\n .withUiState<UiState>({ dataTableState: undefined, dynamicSections: [] })\n\n .output('numbers', (ctx) => ctx.outputs?.resolve('numbers')?.getDataAsJson<number[]>())\n\n .output('pt', (ctx) => {\n if (!ctx.uiState?.dataTableState?.tableState.pTableParams?.filters) return undefined;\n return createPlDataTable(ctx, [\n {\n id: 'example' as PObjectId,\n spec: {\n kind: 'PColumn',\n valueType: 'String',\n name: 'example',\n annotations: {\n 'pl7.app/label': 'String column',\n },\n axesSpec: [\n {\n type: 'Int',\n name: 'index',\n annotations: {\n 'pl7.app/label': 'Int axis',\n },\n },\n ],\n },\n data: [\n { key: [1], val: '1' },\n { key: [2], val: '2' },\n ],\n } satisfies PColumn<PColumnValues>,\n ], ctx.uiState.dataTableState.tableState, [\n ...(ctx.uiState.dataTableState.tableState.pTableParams?.filters ?? []),\n ...(ctx.uiState.dataTableState.filterModel?.filters ?? []),\n ]);\n })\n\n .sections((ctx) => {\n const dynamicSections = (ctx.uiState.dynamicSections ?? []).map((it) => ({\n type: 'link' as const,\n href: `/section?id=${it.id}` as const,\n label: it.label,\n }));\n\n return [\n { type: 'link', href: '/loaders', label: 'Loaders' },\n { type: 'link', href: '/', label: 'Icons/Masks' },\n { type: 'link', href: '/layout', label: 'Layout' },\n { type: 'link', href: '/form-components', label: 'Form Components' },\n { type: 'link', href: '/log-view', label: 'PlLogView' },\n { type: 'link', href: '/modals', label: 'Modals' },\n { type: 'link', href: '/select-files', label: 'Select Files' },\n { type: 'link', href: '/inject-env', label: 'Inject env' },\n { type: 'link', href: '/use-watch-fetch', label: 'useWatchFetch' },\n { type: 'link', href: '/typography', label: 'Typography' },\n { type: 'link', href: '/ag-grid-vue', label: 'AgGridVue' },\n { type: 'link', href: '/pl-ag-data-table', label: 'PlAgDataTable' },\n { type: 'link', href: '/pl-splash-page', label: 'PlSplashPage' },\n { type: 'link', href: '/errors', label: 'Errors' },\n { type: 'link', href: '/text-fields', label: 'PlTextField' },\n { type: 'link', href: '/tabs', label: 'PlTabs' },\n { type: 'link', href: '/stacked-bar', label: 'PlChartStackedBar' },\n { type: 'link', href: '/histogram', label: 'PlChartHistogram' },\n { type: 'link', href: '/buttons', label: 'ButtonsPage' },\n { type: 'link', href: '/notifications', label: 'Notifications' },\n { type: 'link', href: '/drafts', label: 'Drafts' },\n ...(dynamicSections.length\n ? [\n { type: 'delimiter' },\n ...dynamicSections,\n { type: 'delimiter' }] as const\n : []),\n {\n type: 'link',\n href: '/add-section',\n appearance: 'add-section',\n label: 'New Dynamic section',\n },\n ];\n })\n\n .done();\n\nexport type BlockOutputs = InferOutputsType<typeof platforma>;\nexport type Href = InferHrefType<typeof platforma>;\n"]}
1
+ {"version":3,"sources":["../src/index.ts"],"names":["z","BlockModel","createPlDataTable"],"mappings":"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","file":"index.cjs","sourcesContent":["import type {\n InferHrefType,\n InferOutputsType,\n PlDataTableState,\n PlTableFiltersModel,\n PColumn,\n PColumnValues,\n PObjectId } from '@platforma-sdk/model';\nimport {\n BlockModel,\n createPlDataTable,\n} from '@platforma-sdk/model';\nimport { z } from 'zod';\n\nexport const $BlockArgs = z.object({\n numbers: z.array(z.coerce.number()),\n});\n\nexport type BlockArgs = z.infer<typeof $BlockArgs>;\n\nexport type TableState = {\n tableState: PlDataTableState;\n filterModel: PlTableFiltersModel;\n};\n\nexport type UiState = {\n dataTableState: TableState | undefined;\n dynamicSections: {\n id: string;\n label: string;\n }[];\n};\n\nexport const platforma = BlockModel.create('Heavy')\n\n .withArgs<BlockArgs>({ numbers: [1, 2, 3, 4] })\n\n .withUiState<UiState>({ dataTableState: undefined, dynamicSections: [] })\n\n .output('numbers', (ctx) => ctx.outputs?.resolve('numbers')?.getDataAsJson<number[]>())\n\n .output('pt', (ctx) => {\n if (!ctx.uiState?.dataTableState?.tableState.pTableParams?.filters) return undefined;\n return createPlDataTable(\n ctx,\n [\n {\n id: 'example' as PObjectId,\n spec: {\n kind: 'PColumn',\n valueType: 'String',\n name: 'example',\n annotations: {\n 'pl7.app/label': 'String column',\n 'pl7.app/discreteValues': '[\"up\",\"down\"]',\n },\n axesSpec: [\n {\n type: 'Int',\n name: 'index',\n annotations: {\n 'pl7.app/label': 'Int axis',\n 'pl7.app/discreteValues': '[1,2]',\n },\n },\n {\n type: 'Float',\n name: 'value',\n annotations: {\n 'pl7.app/label': 'Float axis',\n },\n },\n ],\n },\n data: [\n { key: [1, 1.1], val: '1' },\n { key: [2, 2.2], val: '2' },\n ],\n } satisfies PColumn<PColumnValues>,\n ],\n ctx.uiState.dataTableState.tableState,\n {\n filters: [\n ...(ctx.uiState.dataTableState.tableState.pTableParams?.filters ?? []),\n ...(ctx.uiState.dataTableState.filterModel?.filters ?? []),\n ],\n },\n );\n })\n\n .sections((ctx) => {\n const dynamicSections = (ctx.uiState.dynamicSections ?? []).map((it) => ({\n type: 'link' as const,\n href: `/section?id=${it.id}` as const,\n label: it.label,\n }));\n\n return [\n { type: 'link', href: '/loaders', label: 'Loaders' },\n { type: 'link', href: '/', label: 'Icons/Masks' },\n { type: 'link', href: '/layout', label: 'Layout' },\n { type: 'link', href: '/form-components', label: 'Form Components' },\n { type: 'link', href: '/log-view', label: 'PlLogView' },\n { type: 'link', href: '/modals', label: 'Modals' },\n { type: 'link', href: '/select-files', label: 'Select Files' },\n { type: 'link', href: '/inject-env', label: 'Inject env' },\n { type: 'link', href: '/use-watch-fetch', label: 'useWatchFetch' },\n { type: 'link', href: '/typography', label: 'Typography' },\n { type: 'link', href: '/ag-grid-vue', label: 'AgGridVue' },\n { type: 'link', href: '/pl-ag-data-table', label: 'PlAgDataTable' },\n { type: 'link', href: '/pl-splash-page', label: 'PlSplashPage' },\n { type: 'link', href: '/errors', label: 'Errors' },\n { type: 'link', href: '/text-fields', label: 'PlTextField' },\n { type: 'link', href: '/tabs', label: 'PlTabs' },\n { type: 'link', href: '/stacked-bar', label: 'PlChartStackedBar' },\n { type: 'link', href: '/histogram', label: 'PlChartHistogram' },\n { type: 'link', href: '/buttons', label: 'ButtonsPage' },\n { type: 'link', href: '/notifications', label: 'Notifications' },\n { type: 'link', href: '/drafts', label: 'Drafts' },\n ...(dynamicSections.length\n ? [\n { type: 'delimiter' },\n ...dynamicSections,\n { type: 'delimiter' }] as const\n : []),\n {\n type: 'link',\n href: '/add-section',\n appearance: 'add-section',\n label: 'New Dynamic section',\n },\n ];\n })\n\n .done();\n\nexport type BlockOutputs = InferOutputsType<typeof platforma>;\nexport type Href = InferHrefType<typeof platforma>;\n"]}
package/dist/index.js CHANGED
@@ -7,35 +7,51 @@ var $BlockArgs = z.object({
7
7
  });
8
8
  var platforma = BlockModel.create("Heavy").withArgs({ numbers: [1, 2, 3, 4] }).withUiState({ dataTableState: void 0, dynamicSections: [] }).output("numbers", (ctx) => ctx.outputs?.resolve("numbers")?.getDataAsJson()).output("pt", (ctx) => {
9
9
  if (!ctx.uiState?.dataTableState?.tableState.pTableParams?.filters) return void 0;
10
- return createPlDataTable(ctx, [
11
- {
12
- id: "example",
13
- spec: {
14
- kind: "PColumn",
15
- valueType: "String",
16
- name: "example",
17
- annotations: {
18
- "pl7.app/label": "String column"
19
- },
20
- axesSpec: [
21
- {
22
- type: "Int",
23
- name: "index",
24
- annotations: {
25
- "pl7.app/label": "Int axis"
10
+ return createPlDataTable(
11
+ ctx,
12
+ [
13
+ {
14
+ id: "example",
15
+ spec: {
16
+ kind: "PColumn",
17
+ valueType: "String",
18
+ name: "example",
19
+ annotations: {
20
+ "pl7.app/label": "String column",
21
+ "pl7.app/discreteValues": '["up","down"]'
22
+ },
23
+ axesSpec: [
24
+ {
25
+ type: "Int",
26
+ name: "index",
27
+ annotations: {
28
+ "pl7.app/label": "Int axis",
29
+ "pl7.app/discreteValues": "[1,2]"
30
+ }
31
+ },
32
+ {
33
+ type: "Float",
34
+ name: "value",
35
+ annotations: {
36
+ "pl7.app/label": "Float axis"
37
+ }
26
38
  }
27
- }
39
+ ]
40
+ },
41
+ data: [
42
+ { key: [1, 1.1], val: "1" },
43
+ { key: [2, 2.2], val: "2" }
28
44
  ]
29
- },
30
- data: [
31
- { key: [1], val: "1" },
32
- { key: [2], val: "2" }
45
+ }
46
+ ],
47
+ ctx.uiState.dataTableState.tableState,
48
+ {
49
+ filters: [
50
+ ...ctx.uiState.dataTableState.tableState.pTableParams?.filters ?? [],
51
+ ...ctx.uiState.dataTableState.filterModel?.filters ?? []
33
52
  ]
34
53
  }
35
- ], ctx.uiState.dataTableState.tableState, [
36
- ...ctx.uiState.dataTableState.tableState.pTableParams?.filters ?? [],
37
- ...ctx.uiState.dataTableState.filterModel?.filters ?? []
38
- ]);
54
+ );
39
55
  }).sections((ctx) => {
40
56
  const dynamicSections = (ctx.uiState.dynamicSections ?? []).map((it) => ({
41
57
  type: "link",
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts"],"names":[],"mappings":"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","file":"index.js","sourcesContent":["import type {\n InferHrefType,\n InferOutputsType,\n PlDataTableState,\n PlTableFiltersModel,\n PColumn,\n PColumnValues,\n PObjectId } from '@platforma-sdk/model';\nimport {\n BlockModel,\n createPlDataTable,\n} from '@platforma-sdk/model';\nimport { z } from 'zod';\n\nexport const $BlockArgs = z.object({\n numbers: z.array(z.coerce.number()),\n});\n\nexport type BlockArgs = z.infer<typeof $BlockArgs>;\n\nexport type TableState = {\n tableState: PlDataTableState;\n filterModel: PlTableFiltersModel;\n};\n\nexport type UiState = {\n dataTableState: TableState | undefined;\n dynamicSections: {\n id: string;\n label: string;\n }[];\n};\n\nexport const platforma = BlockModel.create('Heavy')\n\n .withArgs<BlockArgs>({ numbers: [1, 2, 3, 4] })\n\n .withUiState<UiState>({ dataTableState: undefined, dynamicSections: [] })\n\n .output('numbers', (ctx) => ctx.outputs?.resolve('numbers')?.getDataAsJson<number[]>())\n\n .output('pt', (ctx) => {\n if (!ctx.uiState?.dataTableState?.tableState.pTableParams?.filters) return undefined;\n return createPlDataTable(ctx, [\n {\n id: 'example' as PObjectId,\n spec: {\n kind: 'PColumn',\n valueType: 'String',\n name: 'example',\n annotations: {\n 'pl7.app/label': 'String column',\n },\n axesSpec: [\n {\n type: 'Int',\n name: 'index',\n annotations: {\n 'pl7.app/label': 'Int axis',\n },\n },\n ],\n },\n data: [\n { key: [1], val: '1' },\n { key: [2], val: '2' },\n ],\n } satisfies PColumn<PColumnValues>,\n ], ctx.uiState.dataTableState.tableState, [\n ...(ctx.uiState.dataTableState.tableState.pTableParams?.filters ?? []),\n ...(ctx.uiState.dataTableState.filterModel?.filters ?? []),\n ]);\n })\n\n .sections((ctx) => {\n const dynamicSections = (ctx.uiState.dynamicSections ?? []).map((it) => ({\n type: 'link' as const,\n href: `/section?id=${it.id}` as const,\n label: it.label,\n }));\n\n return [\n { type: 'link', href: '/loaders', label: 'Loaders' },\n { type: 'link', href: '/', label: 'Icons/Masks' },\n { type: 'link', href: '/layout', label: 'Layout' },\n { type: 'link', href: '/form-components', label: 'Form Components' },\n { type: 'link', href: '/log-view', label: 'PlLogView' },\n { type: 'link', href: '/modals', label: 'Modals' },\n { type: 'link', href: '/select-files', label: 'Select Files' },\n { type: 'link', href: '/inject-env', label: 'Inject env' },\n { type: 'link', href: '/use-watch-fetch', label: 'useWatchFetch' },\n { type: 'link', href: '/typography', label: 'Typography' },\n { type: 'link', href: '/ag-grid-vue', label: 'AgGridVue' },\n { type: 'link', href: '/pl-ag-data-table', label: 'PlAgDataTable' },\n { type: 'link', href: '/pl-splash-page', label: 'PlSplashPage' },\n { type: 'link', href: '/errors', label: 'Errors' },\n { type: 'link', href: '/text-fields', label: 'PlTextField' },\n { type: 'link', href: '/tabs', label: 'PlTabs' },\n { type: 'link', href: '/stacked-bar', label: 'PlChartStackedBar' },\n { type: 'link', href: '/histogram', label: 'PlChartHistogram' },\n { type: 'link', href: '/buttons', label: 'ButtonsPage' },\n { type: 'link', href: '/notifications', label: 'Notifications' },\n { type: 'link', href: '/drafts', label: 'Drafts' },\n ...(dynamicSections.length\n ? [\n { type: 'delimiter' },\n ...dynamicSections,\n { type: 'delimiter' }] as const\n : []),\n {\n type: 'link',\n href: '/add-section',\n appearance: 'add-section',\n label: 'New Dynamic section',\n },\n ];\n })\n\n .done();\n\nexport type BlockOutputs = InferOutputsType<typeof platforma>;\nexport type Href = InferHrefType<typeof platforma>;\n"]}
1
+ {"version":3,"sources":["../src/index.ts"],"names":[],"mappings":"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","file":"index.js","sourcesContent":["import type {\n InferHrefType,\n InferOutputsType,\n PlDataTableState,\n PlTableFiltersModel,\n PColumn,\n PColumnValues,\n PObjectId } from '@platforma-sdk/model';\nimport {\n BlockModel,\n createPlDataTable,\n} from '@platforma-sdk/model';\nimport { z } from 'zod';\n\nexport const $BlockArgs = z.object({\n numbers: z.array(z.coerce.number()),\n});\n\nexport type BlockArgs = z.infer<typeof $BlockArgs>;\n\nexport type TableState = {\n tableState: PlDataTableState;\n filterModel: PlTableFiltersModel;\n};\n\nexport type UiState = {\n dataTableState: TableState | undefined;\n dynamicSections: {\n id: string;\n label: string;\n }[];\n};\n\nexport const platforma = BlockModel.create('Heavy')\n\n .withArgs<BlockArgs>({ numbers: [1, 2, 3, 4] })\n\n .withUiState<UiState>({ dataTableState: undefined, dynamicSections: [] })\n\n .output('numbers', (ctx) => ctx.outputs?.resolve('numbers')?.getDataAsJson<number[]>())\n\n .output('pt', (ctx) => {\n if (!ctx.uiState?.dataTableState?.tableState.pTableParams?.filters) return undefined;\n return createPlDataTable(\n ctx,\n [\n {\n id: 'example' as PObjectId,\n spec: {\n kind: 'PColumn',\n valueType: 'String',\n name: 'example',\n annotations: {\n 'pl7.app/label': 'String column',\n 'pl7.app/discreteValues': '[\"up\",\"down\"]',\n },\n axesSpec: [\n {\n type: 'Int',\n name: 'index',\n annotations: {\n 'pl7.app/label': 'Int axis',\n 'pl7.app/discreteValues': '[1,2]',\n },\n },\n {\n type: 'Float',\n name: 'value',\n annotations: {\n 'pl7.app/label': 'Float axis',\n },\n },\n ],\n },\n data: [\n { key: [1, 1.1], val: '1' },\n { key: [2, 2.2], val: '2' },\n ],\n } satisfies PColumn<PColumnValues>,\n ],\n ctx.uiState.dataTableState.tableState,\n {\n filters: [\n ...(ctx.uiState.dataTableState.tableState.pTableParams?.filters ?? []),\n ...(ctx.uiState.dataTableState.filterModel?.filters ?? []),\n ],\n },\n );\n })\n\n .sections((ctx) => {\n const dynamicSections = (ctx.uiState.dynamicSections ?? []).map((it) => ({\n type: 'link' as const,\n href: `/section?id=${it.id}` as const,\n label: it.label,\n }));\n\n return [\n { type: 'link', href: '/loaders', label: 'Loaders' },\n { type: 'link', href: '/', label: 'Icons/Masks' },\n { type: 'link', href: '/layout', label: 'Layout' },\n { type: 'link', href: '/form-components', label: 'Form Components' },\n { type: 'link', href: '/log-view', label: 'PlLogView' },\n { type: 'link', href: '/modals', label: 'Modals' },\n { type: 'link', href: '/select-files', label: 'Select Files' },\n { type: 'link', href: '/inject-env', label: 'Inject env' },\n { type: 'link', href: '/use-watch-fetch', label: 'useWatchFetch' },\n { type: 'link', href: '/typography', label: 'Typography' },\n { type: 'link', href: '/ag-grid-vue', label: 'AgGridVue' },\n { type: 'link', href: '/pl-ag-data-table', label: 'PlAgDataTable' },\n { type: 'link', href: '/pl-splash-page', label: 'PlSplashPage' },\n { type: 'link', href: '/errors', label: 'Errors' },\n { type: 'link', href: '/text-fields', label: 'PlTextField' },\n { type: 'link', href: '/tabs', label: 'PlTabs' },\n { type: 'link', href: '/stacked-bar', label: 'PlChartStackedBar' },\n { type: 'link', href: '/histogram', label: 'PlChartHistogram' },\n { type: 'link', href: '/buttons', label: 'ButtonsPage' },\n { type: 'link', href: '/notifications', label: 'Notifications' },\n { type: 'link', href: '/drafts', label: 'Drafts' },\n ...(dynamicSections.length\n ? [\n { type: 'delimiter' },\n ...dynamicSections,\n { type: 'delimiter' }] as const\n : []),\n {\n type: 'link',\n href: '/add-section',\n appearance: 'add-section',\n label: 'New Dynamic section',\n },\n ];\n })\n\n .done();\n\nexport type BlockOutputs = InferOutputsType<typeof platforma>;\nexport type Href = InferHrefType<typeof platforma>;\n"]}