This is an automated email from the ASF dual-hosted git repository.

kgabryje pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/superset.git


The following commit(s) were added to refs/heads/master by this push:
     new 8005b7f8c7 fix(plugin-chart-table): Upgrade old color formats (#21101)
8005b7f8c7 is described below

commit 8005b7f8c77fa96e0ff32958830ba307db74abff
Author: Kamil Gabryjelski <[email protected]>
AuthorDate: Tue Aug 16 22:05:53 2022 +0200

    fix(plugin-chart-table): Upgrade old color formats (#21101)
    
    * fix(plugin-chart-table): Upgrade old color formats
    
    * Bug fix
    
    * add comments
---
 ...665d_fix_table_chart_conditional_formatting_.py | 82 ++++++++++++++++++++++
 1 file changed, 82 insertions(+)

diff --git 
a/superset/migrations/versions/2022-08-16_15-23_6d3c6f9d665d_fix_table_chart_conditional_formatting_.py
 
b/superset/migrations/versions/2022-08-16_15-23_6d3c6f9d665d_fix_table_chart_conditional_formatting_.py
new file mode 100644
index 0000000000..30caf7efa1
--- /dev/null
+++ 
b/superset/migrations/versions/2022-08-16_15-23_6d3c6f9d665d_fix_table_chart_conditional_formatting_.py
@@ -0,0 +1,82 @@
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements.  See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership.  The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License.  You may obtain a copy of the License at
+#
+#   http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing,
+# software distributed under the License is distributed on an
+# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+# KIND, either express or implied.  See the License for the
+# specific language governing permissions and limitations
+# under the License.
+"""fix_table_chart_conditional_formatting_colors
+
+Revision ID: 6d3c6f9d665d
+Revises: ffa79af61a56
+Create Date: 2022-08-16 15:23:42.860038
+
+"""
+import json
+
+from alembic import op
+from sqlalchemy import Column, Integer, String, Text
+from sqlalchemy.ext.declarative import declarative_base
+
+from superset import db
+
+# revision identifiers, used by Alembic.
+revision = "6d3c6f9d665d"
+down_revision = "ffa79af61a56"
+
+Base = declarative_base()
+
+
+class Slice(Base):
+    __tablename__ = "slices"
+    id = Column(Integer, primary_key=True)
+    viz_type = Column(String(250))
+    params = Column(Text)
+
+
+def upgrade():
+    bind = op.get_bind()
+    session = db.Session(bind=bind)
+
+    for slc in session.query(Slice).filter(Slice.viz_type == "table"):
+        params = json.loads(slc.params)
+        conditional_formatting = params.get("conditional_formatting", [])
+        if conditional_formatting:
+            new_conditional_formatting = []
+            for formatter in conditional_formatting:
+                color_scheme = formatter.get("colorScheme")
+                new_color_scheme = None
+                if color_scheme == "rgb(0,255,0)":
+                    # supersetTheme.colors.success.light1
+                    new_color_scheme = "#ACE1C4"
+                elif color_scheme == "rgb(255,255,0)":
+                    # supersetTheme.colors.alert.light1
+                    new_color_scheme = "#FDE380"
+                elif color_scheme == "rgb(255,0,0)":
+                    # supersetTheme.colors.error.light1
+                    new_color_scheme = "#EFA1AA"
+                if new_color_scheme:
+                    new_conditional_formatting.append(
+                        {**formatter, "colorScheme": new_color_scheme}
+                    )
+                else:
+                    new_conditional_formatting.append(formatter)
+            params["conditional_formatting"] = new_conditional_formatting
+            slc.params = json.dumps(params)
+            session.merge(slc)
+            session.commit()
+    session.close()
+
+
+# it fixes a bug, downgrading isn't really needed here
+def downgrade():
+    pass

Reply via email to