Graphite/editor/graphite-test-document.graphite
Keavon Chambers 9d56e86203 Refactor persistent data storage code and add button to wipe data on crash (#827)
* Organize persistence.ts

* Switch to simpler promise handling

* Switch document list storage from localStorage to IndexedDB

* Track document auto-save status to avoid re-auto-saving unnecessarily

* Add button to clear storage on crash

* Bump document version and test file

* Switch to IDB-Keyval instead of raw IDB transactions
2022-11-02 15:19:04 -07:00

1 line
16 KiB
Text

{"graphene_document":{"root":{"visible":true,"name":null,"data":{"Folder":{"next_assignment_id":15997858604048146086,"layer_ids":[17969178651777368768,3643066017826641933,16075447627426792792,10598788542653937530,6240415495114589106,5260049129070821769,6431150803620977111,13779825621578452744,3547353463246861192],"layers":[{"visible":true,"name":null,"data":{"Shape":{"shape":{"elements":[{"points":[{"position":[201.95915125256778,132.20589235454912],"manipulator_type":"Anchor"},{"position":[201.95915125256778,132.20589235454912],"manipulator_type":"InHandle"},{"position":[201.95915125256778,132.20589235454912],"manipulator_type":"OutHandle"}]},{"points":[{"position":[347.5538879474682,92.26397343824904],"manipulator_type":"Anchor"},{"position":[347.5538879474682,51.03360552464895],"manipulator_type":"InHandle"},{"position":[347.5538879474682,133.49434135184913],"manipulator_type":"OutHandle"}]},{"points":[{"position":[283.131438082468,237.85871013314937],"manipulator_type":"Anchor"},{"position":[337.2462959690681,281.6659760413495],"manipulator_type":"InHandle"},{"position":[229.01658019586787,194.05144422494925],"manipulator_type":"OutHandle"}]},{"points":[{"position":[154.28653835246766,246.87785311424938],"manipulator_type":"Anchor"},{"position":[154.28653835246766,246.87785311424938],"manipulator_type":"InHandle"},{"position":[154.28653835246766,246.87785311424938],"manipulator_type":"OutHandle"}]}],"element_ids":[1,2,3,4],"next_id":5},"style":{"stroke":{"color":{"red":0.0,"green":0.0,"blue":0.0,"alpha":1.0},"weight":5.0,"dash_lengths":[0.0],"dash_offset":0.0,"line_cap":"Butt","line_join":"Miter","line_join_miter_limit":4.0},"fill":"None"},"render_index":1}},"transform":{"matrix2":[1.0,0.0,0.0,1.0],"translation":[0.0,0.0]},"pivot":[0.5,0.5],"blend_mode":"Normal","opacity":1.0},{"visible":true,"name":null,"data":{"Shape":{"shape":{"elements":[{"points":[{"position":[433.87997076656836,163.73088039119517],"manipulator_type":"Anchor"},{"position":[433.87997076656836,163.73088039119517],"manipulator_type":"InHandle"},{"position":[433.87997076656836,163.73088039119517],"manipulator_type":"OutHandle"}]},{"points":[{"position":[592.3591974344687,156.68642330324917],"manipulator_type":"Anchor"},{"position":[592.3591974344687,156.68642330324917],"manipulator_type":"InHandle"},{"position":[592.3591974344687,156.68642330324917],"manipulator_type":"OutHandle"}]},{"points":[{"position":[463.51429770446845,311.3003029792495],"manipulator_type":"Anchor"},{"position":[463.51429770446845,311.3003029792495],"manipulator_type":"InHandle"},{"position":[463.51429770446845,311.3003029792495],"manipulator_type":"OutHandle"}]}],"element_ids":[1,2,3],"next_id":4},"style":{"stroke":{"color":{"red":0.0,"green":0.0,"blue":0.0,"alpha":1.0},"weight":5.0,"dash_lengths":[0.0],"dash_offset":0.0,"line_cap":"Butt","line_join":"Miter","line_join_miter_limit":4.0},"fill":"None"},"render_index":1}},"transform":{"matrix2":[1.0,0.0,0.0,1.0],"translation":[0.0,0.0]},"pivot":[0.5,0.5],"blend_mode":"Normal","opacity":1.0},{"visible":true,"name":null,"data":{"Shape":{"shape":{"elements":[{"points":[{"position":[801.087934997069,163.7308803911952],"manipulator_type":"Anchor"},{"position":[801.087934997069,163.7308803911952],"manipulator_type":"InHandle"},{"position":[801.087934997069,163.7308803911952],"manipulator_type":"OutHandle"}]},{"points":[{"position":[767.5882610672691,295.8389150116495],"manipulator_type":"Anchor"},{"position":[767.5882610672691,295.8389150116495],"manipulator_type":"InHandle"},{"position":[767.5882610672691,295.8389150116495],"manipulator_type":"OutHandle"}]},{"points":[{"position":[652.9163003075688,233.99336314124935],"manipulator_type":"Anchor"},{"position":[652.9163003075688,233.99336314124935],"manipulator_type":"InHandle"},{"position":[652.9163003075688,233.99336314124935],"manipulator_type":"OutHandle"}]},{"points":[{"position":[735.377036134769,74.22568747604898],"manipulator_type":"Anchor"},{"position":[735.377036134769,74.22568747604898],"manipulator_type":"InHandle"},{"position":[735.377036134769,74.22568747604898],"manipulator_type":"OutHandle"}]},{"points":[null,null,null]}],"element_ids":[1,2,3,4,6],"next_id":6},"style":{"stroke":{"color":{"red":0.0,"green":0.0,"blue":0.0,"alpha":1.0},"weight":5.0,"dash_lengths":[0.0],"dash_offset":0.0,"line_cap":"Butt","line_join":"Miter","line_join_miter_limit":4.0},"fill":"None"},"render_index":1}},"transform":{"matrix2":[1.0,0.0,0.0,1.0],"translation":[0.0,0.0]},"pivot":[0.5,0.5],"blend_mode":"Normal","opacity":1.0},{"visible":true,"name":null,"data":{"Shape":{"shape":{"elements":[{"points":[{"position":[106.61392545236757,387.3187938199497],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[107.90237444966755,387.3187938199497],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[125.94066041186761,374.43430384694966],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[140.11359938216765,364.12671186854965],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[152.99808935516768,355.10756888744964],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[167.17102832546772,348.6653239009496],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[177.47862030386773,347.3768749036496],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[189.07466127956775,357.68446688204966],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[198.09380426066778,374.43430384694966],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[210.9782942336678,402.78018178754974],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[222.57433520936783,428.5491617335498],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[232.88192718776784,434.99140672004984],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[244.47796816346786,437.56830471464986],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[274.112295101368,431.1260597281498],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[324.3618059960681,402.78018178754974],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[361.7268269177682,373.1458548496497],"manipulator_type":"Anchor"},null,null]}],"element_ids":[1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16],"next_id":16},"style":{"stroke":{"color":{"red":0.0,"green":0.0,"blue":0.0,"alpha":1.0},"weight":5.0,"dash_lengths":[0.0],"dash_offset":0.0,"line_cap":"Butt","line_join":"Miter","line_join_miter_limit":4.0},"fill":{"Gradient":{"start":[0.6212121212121211,0.9857142857142858],"end":[0.6212121212121211,0.9857142857142858],"transform":[198.00000000000006,0.0,0.0,70.00000000000004,133.0,328.0],"positions":[[0.0,{"red":1.0,"green":1.0,"blue":1.0,"alpha":1.0}],[1.0,{"red":0.7647059,"green":0.2627451,"blue":0.5921569,"alpha":1.0}]],"uuid":2843271626210251322,"gradient_type":"Linear"}}},"render_index":0}},"transform":{"matrix2":[1.0,0.0,0.0,1.0],"translation":[37.365020921700086,6.442244986499993]},"pivot":[0.5,0.5],"blend_mode":"Normal","opacity":1.0},{"visible":true,"name":null,"data":{"Shape":{"shape":{"elements":[{"points":[{"position":[643.8971573264688,410.5108757713498],"manipulator_type":"Anchor"},null,{"position":[594.5066124299686,427.50613159287843],"manipulator_type":"OutHandle"}]},{"points":[{"position":[553.7057275154685,420.8184677497498],"manipulator_type":"Anchor"},{"position":[545.1160675334686,444.501387414407],"manipulator_type":"InHandle"},{"position":[562.2953874974685,397.1355480850926],"manipulator_type":"OutHandle"}]},{"points":[{"position":[673.5314842643688,339.6461809198496],"manipulator_type":"Anchor"},{"position":[628.8652523579686,332.7744529342495],"manipulator_type":"InHandle"},{"position":[718.197716170769,346.5179089054497],"manipulator_type":"OutHandle"}]},{"points":[{"position":[766.2998120699691,438.85675371194986],"manipulator_type":"Anchor"},{"position":[740.960315123069,424.62246002749276],"manipulator_type":"InHandle"},{"position":[791.6393090168692,453.09104739640696],"manipulator_type":"OutHandle"}]},{"points":[{"position":[847.4720988998693,353.81911989014964],"manipulator_type":"Anchor"},{"position":[819.5557039583692,403.4550836432783],"manipulator_type":"InHandle"},null]}],"element_ids":[1,2,3,4,5],"next_id":5},"style":{"stroke":{"color":{"red":0.6627451,"green":0.003921569,"blue":0.34509805,"alpha":1.0},"weight":5.0,"dash_lengths":[0.0],"dash_offset":0.0,"line_cap":"Butt","line_join":"Miter","line_join_miter_limit":4.0},"fill":"None"},"render_index":0}},"transform":{"matrix2":[1.0,0.0,0.0,1.0],"translation":[0.0,0.0]},"pivot":[0.5,0.5],"blend_mode":"Normal","opacity":1.0},{"visible":true,"name":null,"data":{"Shape":{"shape":{"elements":[{"points":[{"position":[0.0,0.0],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[1.0,0.0],"manipulator_type":"Anchor"},null,null]}],"element_ids":[1,2],"next_id":2},"style":{"stroke":{"color":{"red":0.29803923,"green":0.14901961,"blue":0.91764706,"alpha":1.0},"weight":5.0,"dash_lengths":[0.0],"dash_offset":0.0,"line_cap":"Butt","line_join":"Miter","line_join_miter_limit":4.0},"fill":"None"},"render_index":1}},"transform":{"matrix2":[-79.8838378326002,220.22380660417988,-1.211224462609144,-0.439358759808626],"translation":[1008.5282235623696,221.10887316824932]},"pivot":[0.5,0.5],"blend_mode":"Normal","opacity":1.0},{"visible":true,"name":null,"data":{"Shape":{"shape":{"elements":[{"points":[{"position":[0.0,0.0],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[0.0,1.0],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[1.0,1.0],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[1.0,0.0],"manipulator_type":"Anchor"},null,null]},{"points":[null,null,null]}],"element_ids":[1,2,3,4,5],"next_id":5},"style":{"stroke":null,"fill":{"Gradient":{"start":[0.050724637681159424,0.3625000000000007],"end":[0.9492753623188404,0.6375000000000002],"transform":[138.0,0.0,0.0,80.0,183.0,455.0],"positions":[[0.0,{"red":0.21568628,"green":0.61960787,"blue":0.015686275,"alpha":1.0}],[1.0,{"red":0.03137255,"green":0.16470589,"blue":0.22352941,"alpha":1.0}]],"uuid":16297296248403562943,"gradient_type":"Linear"}}},"render_index":1}},"transform":{"matrix2":[177.80596162740042,0.0,-0.0,103.07591978400025],"translation":[208.4013962390678,517.45214254725]},"pivot":[0.5,0.5],"blend_mode":"Normal","opacity":1.0},{"visible":true,"name":null,"data":{"Shape":{"shape":{"elements":[{"points":[{"position":[0.5,1.0],"manipulator_type":"Anchor"},{"position":[0.7761415,1.0],"manipulator_type":"InHandle"},{"position":[0.22385850000000002,1.0],"manipulator_type":"OutHandle"}]},{"points":[{"position":[0.0,0.5],"manipulator_type":"Anchor"},{"position":[0.0,0.7761415],"manipulator_type":"InHandle"},{"position":[0.0,0.22385850000000002],"manipulator_type":"OutHandle"}]},{"points":[{"position":[0.5,0.0],"manipulator_type":"Anchor"},{"position":[0.22385850000000002,0.0],"manipulator_type":"InHandle"},{"position":[0.7761415,0.0],"manipulator_type":"OutHandle"}]},{"points":[{"position":[1.0,0.5],"manipulator_type":"Anchor"},{"position":[1.0,0.22385850000000002],"manipulator_type":"InHandle"},{"position":[1.0,0.7761415],"manipulator_type":"OutHandle"}]},{"points":[null,null,null]}],"element_ids":[1,2,3,4,5],"next_id":5},"style":{"stroke":null,"fill":{"Solid":{"red":0.8039216,"green":0.2784314,"blue":0.29803923,"alpha":1.0}}},"render_index":1}},"transform":{"matrix2":[119.51669546055449,0.0,-0.0,132.71024672190032],"translation":[552.7263398065144,576.7207964230502]},"pivot":[0.5,0.5],"blend_mode":"Normal","opacity":1.0},{"visible":true,"name":null,"data":{"Shape":{"shape":{"elements":[{"points":[{"position":[1.0,0.5],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[0.75,0.9330127018922193],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[0.2500000000000001,0.9330127018922194],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[0.0,0.5000000000000001],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[0.24999999999999978,0.06698729810778076],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[0.75,0.0669872981077807],"manipulator_type":"Anchor"},null,null]},{"points":[null,null,null]}],"element_ids":[1,2,3,4,5,6,7],"next_id":7},"style":{"stroke":{"color":{"red":0.39607844,"green":0.0,"blue":0.0,"alpha":1.0},"weight":10.0,"dash_lengths":[20.0,40.0],"dash_offset":1.0,"line_cap":"Round","line_join":"Round","line_join_miter_limit":4.0},"fill":{"Solid":{"red":0.21568628,"green":0.61960787,"blue":0.015686275,"alpha":1.0}}},"render_index":1}},"transform":{"matrix2":[166.2099206517004,0.0,-0.0,171.3637166409004],"translation":[745.6846281131691,553.5287144716501]},"pivot":[0.5,0.5],"blend_mode":"Normal","opacity":1.0}]}},"transform":{"matrix2":[0.7057368997889272,0.12039914794770572,-0.12039914794770572,0.7057368997889272],"translation":[153.8440535943912,71.2188920841819]},"pivot":[0.5,0.5],"blend_mode":"Normal","opacity":1.0}},"saved_document_identifier":14549722863065794262,"auto_saved_document_identifier":0,"name":"Untitled Document","version":"0.0.15","document_mode":"DesignMode","view_mode":"Normal","snapping_enabled":true,"overlays_visible":true,"layer_metadata":[[[3547353463246861192],{"selected":false,"expanded":false}],[[16075447627426792792],{"selected":false,"expanded":false}],[[],{"selected":false,"expanded":true}],[[3643066017826641933],{"selected":false,"expanded":false}],[[5260049129070821769],{"selected":false,"expanded":false}],[[17969178651777368768],{"selected":false,"expanded":false}],[[6240415495114589106],{"selected":false,"expanded":false}],[[6431150803620977111],{"selected":false,"expanded":false}],[[13779825621578452744],{"selected":false,"expanded":false}],[[10598788542653937530],{"selected":false,"expanded":false}]],"layer_range_selection_reference":[],"navigation_handler":{"pan":[-937.5907856355655,-408.64517115079275],"panning":false,"snap_tilt":false,"snap_tilt_released":false,"tilt":0.1689738423032222,"tilting":false,"zoom":0.7159333254921297,"zooming":false,"snap_zoom":false,"mouse_position":[1198.0,253.0]},"artboard_message_handler":{"artboards_graphene_document":{"root":{"visible":true,"name":null,"data":{"Folder":{"next_assignment_id":10154885448817245701,"layer_ids":[4835915792681996579,10154885448817245700],"layers":[{"visible":true,"name":null,"data":{"Shape":{"shape":{"elements":[{"points":[{"position":[0.0,0.0],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[0.0,1.0],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[1.0,1.0],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[1.0,0.0],"manipulator_type":"Anchor"},null,null]},{"points":[null,null,null]}],"element_ids":[1,2,3,4,5],"next_id":5},"style":{"stroke":null,"fill":{"Solid":{"red":1.0,"green":1.0,"blue":1.0,"alpha":1.0}}},"render_index":1}},"transform":{"matrix2":[1920.0,0.0,-0.0,1080.0],"translation":[0.0,0.0]},"pivot":[0.5,0.5],"blend_mode":"Normal","opacity":1.0},{"visible":true,"name":null,"data":{"Shape":{"shape":{"elements":[{"points":[{"position":[0.0,0.0],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[0.0,1.0],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[1.0,1.0],"manipulator_type":"Anchor"},null,null]},{"points":[{"position":[1.0,0.0],"manipulator_type":"Anchor"},null,null]},{"points":[null,null,null]}],"element_ids":[1,2,3,4,5],"next_id":5},"style":{"stroke":null,"fill":{"Solid":{"red":1.0,"green":1.0,"blue":1.0,"alpha":1.0}}},"render_index":1}},"transform":{"matrix2":[222.0,0.0,-0.0,213.0],"translation":[941.0,-398.0]},"pivot":[0.5,0.5],"blend_mode":"Normal","opacity":1.0}]}},"transform":{"matrix2":[0.7057368997889272,0.12039914794770572,-0.12039914794770572,0.7057368997889272],"translation":[153.8440535943912,71.2188920841819]},"pivot":[0.5,0.5],"blend_mode":"Normal","opacity":1.0}},"artboard_ids":[4835915792681996579,10154885448817245700]},"properties_panel_message_handler":{"active_selection":null}}